org.opentcs.access.KernelServicePortal Maven / Gradle / Ivy
/**
* Copyright (c) The openTCS Authors.
*
* This program is free software and subject to the MIT license. (For details,
* see the licensing information (LICENSE.txt) you should have received with
* this copy of the software.)
*/
package org.opentcs.access;
import jakarta.annotation.Nonnull;
import java.util.List;
import org.opentcs.components.kernel.services.DispatcherService;
import org.opentcs.components.kernel.services.NotificationService;
import org.opentcs.components.kernel.services.PeripheralDispatcherService;
import org.opentcs.components.kernel.services.PeripheralJobService;
import org.opentcs.components.kernel.services.PeripheralService;
import org.opentcs.components.kernel.services.PlantModelService;
import org.opentcs.components.kernel.services.QueryService;
import org.opentcs.components.kernel.services.RouterService;
import org.opentcs.components.kernel.services.TransportOrderService;
import org.opentcs.components.kernel.services.VehicleService;
/**
* Provides clients access to kernel services.
*/
public interface KernelServicePortal {
/**
* Logs in with/establishes a connection to the remote kernel service portal.
*
* @param hostName The host on which the remote portal is running.
* @param port The port at which we can reach the remote RMI registry.
* @throws KernelRuntimeException If there was a problem logging in with the remote portal.
*/
void login(
@Nonnull
String hostName,
int port
)
throws KernelRuntimeException;
/**
* Logs out from/clears the connection to the remote kernel service portal.
*
* @throws KernelRuntimeException If there was a problem logging out from the remote portal, i.e.
* it is no longer available.
*/
void logout()
throws KernelRuntimeException;
/**
* Returns the current state of the kernel.
*
* @return The current state of the kernel.
* @throws KernelRuntimeException In case there is an exception executing this method.
*/
Kernel.State getState()
throws KernelRuntimeException;
/**
* Fetches events buffered for the client.
*
* @param timeout A timeout (in ms) for which to wait for events to arrive.
* @return A list of events (in the order they arrived).
* @throws KernelRuntimeException In case there is an exception executing this method.
*/
List
© 2015 - 2025 Weber Informatics LLC | Privacy Policy