All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.statusmachina.core.api.Machine Maven / Gradle / Ivy

/*
 *
 * Copyright 2019 <---> Present Status Machina Contributors (https://github.com/entzik/status-machina/graphs/contributors)
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * This software is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
 * CONDITIONS OF ANY KIND, either express or implied. See the License for the
 * specific language governing permissions and limitations under the License.
 *
 */

package io.statusmachina.core.api;

import com.google.common.collect.ImmutableMap;
import io.statusmachina.core.stdimpl.TransitionRecord;

import java.util.List;
import java.util.Map;
import java.util.Optional;

/**
 * defines a state machine
 *
 * @param  the type of the machine's state
 * @param  the type of events the machine receives
 */
public interface Machine {
    /**
     * @return the machine's unique ID
     */
    String getId();

    /**
     * @return the state the machine is currently in
     */
    S getCurrentState();

    /**
     * @return the machine's context
     */
    ImmutableMap getContext();

    /**
     * @return the history of transitions executed on this state machine since it was created, to present
     */
    List> getHistory();

    /**
     * @return if the machine is in an error state, it returns the description. otherwise an empty optional
     */
    Optional getError();

    /**
     * returns this state machine's definition
     */
    MachineDefinition getDefinition();

    /**
     * @return true if the machine is in an error state, false otherwise
     */
    boolean isErrorState();

    Machine start();

    /**
     * delivers an event to the state machine.
     *
     * @param event the event to be delivered
     *
     * @throws TransitionException if there is no transition configured for this event out of the
     * current state or if an error occurs during the transition. this could happen while executing the action
     * associated with the transition.
     */
    Machine sendEvent(E event) throws TransitionException;

    /**
     * delivers an event to the state machine.
     *
     * @param event the event to be delivered
     * @param param a parameter that gives context to the event. the parameter will be passed on to the action associated
     *              with the transition,
     *
     * @throws TransitionException if there is no transition configured for this event out of the
     * current state or if an error occurs during the transition. An error could occur when while executing the action
     * associated with the transition.
     */
    

Machine sendEvent(E event, P param) throws TransitionException; /** * resets the machine to a particular state and context if it currently is in an error state. If this method is * called while the machine is not in an error state, {@link IllegalStateException} should be thrown. * * the provided context will completely * * @param state the state the machine will transition to * @param context the context to be applied */ Machine recoverFromError(S state, Map context); /** * returns true if the current state is a terminal one */ boolean isTerminalState(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy