All Classes and Interfaces
Class
Description
Non JPA version of Extended State Entity.
A super class to instantiate a service.
Given that there are a bunch of activities that can be accomplished in a State and that
all these activities are tracked by the state entity, this strategy checks if all these
activities are completed.
Specifies the metadata for the actions that are allowed for this entity.
Uses a Spring controller with additional annotations to initiate a Chenile Service.
Uses a special bean to configure all trajectories.
A command becomes an attachable command if other commands can attach themselves to it using an attachment descriptor.
Contains the meta data about the attachment of a command to another.
Implement this interface to supply a list of authorities that we would like to validate
against the Principal to see if this service can be accessed.
ErrorNumException
with HTTP status code of 400.A generic interceptor for other Chenile Interceptors to override.
Extend this action if it is desired to obtain access to properties that have been set up per state descriptor in the STD.
Extend this to initialize anything like event definitions etc.
Implementation of query store.
A security test container initiating class.
Interface defines a contract for classes that look up objects from various DI frameworks (aka Bean factories)
This annotation specifies that this particular method needs a body type selector for
determining the type that the body needs to convert to.
Implement this interface if a command can be bypassed.
Implement this interface if you want to create your own custom key out of the
input params passed to a method.
Builds all caches that have been configured during startup
Values that can be used to configure a cache.
Caches an operation return value using the service name, operation name and the parameters
that were passed to the operation.
The key for a cache constructed using input parameters for a method.
Retrieve and store canned reports.
A chain is a command that executes a chain of other commands.
This class is used by
FilterChain
.This class specifies a save point.
The context that is required to be passed to filter chain.
Marker annotation to make a new annotation.
The core class that contains the entire ChenileConfiguration.
Annotate all chenile controllers with this annotation.
Class creates a bunch of Spring Beans.
The entry point to the Chenile highway.
Chenile keeps track of events.
Picks up all the event resources and registers all the events in Chenile.
Runs after all the events and services are registered in Chenile.
Handles all exceptions by:
Translating all errors and warnings to international language.
A bidirectional exchange that navigates between different Chenile Interceptors.
Builds an exchange from a service name and an operation name
Picks up all the file watch resources and registers all of them in
ChenileConfiguration
ChenileConfiguration provides for extension
points for registering new type of resources.This interface emits information about a Chenile Service.
This class provides information about all services registered in this running instance of Chenile.
Annotate a class in a Chenile service controller to make it listen to MQ-TT topics.
This will bind the topic to an invocation of this service/operation.
This will bind the topic to an invocation of this service/operation.
The ChenileParamType is required when the method signature of a service does
not match the method signature of the controller.
This is required to state the possible response codes for successful responses.
This is not required for error responses since the exception will already have the response code for error responses.
This is not required for error responses since the exception will already have the response code for error responses.
This communicates with SpringRestTemplate to find the errors from the returned response.
Picks up all the file watch resources and registers all of them in
ChenileConfiguration
ChenileConfiguration provides for extension
points for registering new type of resources.Defines a chenile service.
Concrete class for initializing services from Json resources
Initializes a trajectory definition.
This file exists for transferring version information to ChenileConfiguration.
This interceptor, if configured, acts like an edge switch for a service i.e.
A command is designed to be a unit of work.
Custom digester rule to process either the command or attach Descriptor.
Base class to implement command functionality.
Stores the meta data about all the commands that have been configured in the system.
Actions (both actions and transition actions) implement this interface to obtain access to custom properties that can be set.
A helper class to obtain the properties for the current action (as passed in the flow context).
This annotation will need to be used at the spring
Configuration
class
This annotation does the same thing as ConditionalOnTrajectory
However it does this behaviour for health checkers rather than the services
You can then use this annotation to accomplish this.This annotation helps to replace service references with new ones.
Provides an enablement strategy based on configuration.
ErrorNumException
with HTTP status code of 500 meant for configuration errors.Constants for HTTP module.
Chenile MQTT constants
Find the correct service to invoke.
This is a class that can be used to obtain access to headers passed in the transport.
This class must be extended by Chenile controllers who use annotation to configure a service.
Useful as an enhancement over the ObjectCreateRule for digester.
Useful as an enhancement over the ObjectCreateRule for digester.
Read a CSV file with the first line as the header.
A singleton object that is used in all the methods to store and retrieve values
Cucumber recommends an enum since it acts like a perfect singleton.
Cucumber recommends an enum since it acts like a perfect singleton.
Cucumber steps to facilitate running tests using normal IN-VM testing (NOT REST based)
These steps are generic since they leverage the scripting language and JSON PATH etc.
These steps are generic since they leverage the scripting language and JSON PATH etc.
This object stores the various tags that are supported by the XML configurator along
with their associated properties.
This object stores the various tags that are supported by the XML configurator along
with their associated properties.
This Command delegates control to a method of an underlying object whose reference is
passed to this command.
This command does nothing.
Implementations of this interface enable/disable states and events based out of various criteria.
ALl the errors that have been defined for Chenile core.
Chenile MQTT error codes.
Chenile Proxy error codes
An exception that has a HTTP status code and a custom subErrorCode (which can be a specific
error)
These two errors make the exception very specific
It can contain further errors that are supported by the
ResponseMessage
Values for the severity field in
ResponseMessage
This is a specific subclass of
Router
that uses OGNL to evaluate a boolean expression
on the context.An abstraction to extract actions and their meta data and share them across transitions.
A sequential way of processing an event within the same thread.
This annotation specifies that this particular method subscribes to an event.
Calls the exception handler that is defined in Chenile properties.
FileProcessor knows to handle each file that was discovered by the file watcher
This would process the file and finally dispose it off from the watched folder to the processed
folder.
Builds the file watcher module.
The main file for file watch
This allows the handler to register
FileWatchDefinition
.Uses the
EventLogger
to log eventsRuns after all the file watches and services are registered in Chenile.
A variation of the Chain for AOP like surround processing.
Repeatedly, execute the attached commands till the expression specified by
condition evaluates to false.
A generic response that would be returned for all the services.
Constructs a generic response from the response and exception that has been thrown.
Any class that copies headers from the existing context to the new
ChenileExchange
Defines all the header names in one place.
All Health Checkers must implement this interface
Health Checker can be attached to any service
Health checkers will be exposed via a GET method
A base class that provides basic health check info about all services.
Bind a parameter of an Operation to a message.
This is a generic controller that is used if JSON is used to configure a Chenile service.
Invokes the remote service using HTTP
The HTTP Method that is supported by the service.
Uses JSON configurations to initiate Chenile HTTP.
Generates IDs given a request context.
Implements an IF action using the same expression language as the one supported by the
ScriptingStrategy
.A DTO that provides a condensed version of services along with the operations that they support
Health checker for the ChenileInfoService
This is a "dummy" command which needs to be attached to a parent command that
supports this type of command.
Read a JSON file.
Key for the tenant specific cache.
Used to connect to Keycloak.
Invokes the Chenile Entry point locally since this service is local.
Logs the output from the response object.
This is the version of the
GenericResponse
for asynchronous processing.Implement this interface if you are able to persist a log record.
Describes the manual state.
Allows Ognl to support an object that is a map with a few properties defined like normal
java beans.
Allows Ognl to support an object that is a map with a few properties defined like normal
java beans.
Given an OperationDefinition and a service class, this class computes the java.lang.reflect.Method
Defines the MIME type supported by the particular service.
Sets up Eclipse Paho for communicating with MQ-TT broker using configurations
The entry point that is invoked by the Mqtt subscriber when a message arrives at a topic.
A collection of general purpose utilities for MQ-TT.
Detects the
ChenileMqtt
annotated classes in the Application Context and
populates the mqttConfig for later use by MqttEntryPoint
Topic and Qos can be configured at the service level.Used to publish MQTT messages.
MQTT subscription call back that supports receiving messages, reconnects etc.
This can be used in lieu of the default Message Source.
An implementation of the query service using Mybatis.
Avoids creation of multiple routers by allowing an expression that can be utilized on the
context to obtain the route.
Contains details about the particular operation of a service.
Interpolates all the operation specific processors on the client side for Chenile Proxy
Calls a bunch of interceptors defined at the level of the particular operation.
Reads the configuration of the Orchestration possibly from multiple sources and makes it available for anyone to use it.
A base implementation of OrchConfigurator that stores all the relevant information in internal variables and provides
the services as expected by OrchConfigurator.
Applicable for commands that choose to be aware of their orchestration configuration.
The execution interface of the orchestrator.
This command triggers the chain of responsibility by storing and executing the first
command in the chain.
Internal class used to preserve the order of execution of commands.
Links OWIZ to the Spring framework.
Defines an individual parameter that is accepted by an operation of a sevice.
Wrapper around Ognl.parseExpression() which uses caching.
This class can act as a
HeaderCopier
Calls a bunch of interceptors called as "post processors".
Calls a bunch of interceptors called as "pre processors".
Creates a proxy for a chenile interface.
Sets up the beans for Chenile Proxy and registers them in Spring.
Returns the correct route based on if the service is local or remote
Registers query beans in Spring
This sets up a query service.
Reads the query definitions from a JSON file that has been passed to it.
Unused for now
For specific queries, we should restrict the results only to authorized
users.
This class calculates the correct type for the response body.
A detailed response message that contains a bunch of information.
Cucumber steps to facilitate injection of security tokens into the MVC request header.
See the methods below for the precise Gherkin language that has been created.
See the methods below for the precise Gherkin language that has been created.
Cucumber steps to facilitate running tests using Spring MOCK MVC.
These steps are generic since they leverage the scripting language and JSON PATH etc.
These steps are generic since they leverage the scripting language and JSON PATH etc.
A router is a command that executes one of several commands based on a routing string.
Set up the scheduler for the relevant services if applicable
Schedule definition.
Mimics a script.
Actions implement this interface to get hold of a scripting strategy that is set by the STM framework.
A base class for all script aware generic actions.
This provides the authorities that are required to access this service.
The value() of the class is the enum which specifies if the given resource is PROTECTED or UNPROTECTED.
The value() of the class is the enum which specifies if the given resource is PROTECTED or UNPROTECTED.
This interceptor uses
SecurityConfig
to secure this particular resource.It first looks at the
SecurityConfig to see if there are any guarding authorities for this service.ErrorNumException
with HTTP status code of 500 for runtime errors.This command invokes a service gathering inputs from
ChenileExchange
.Interpolates all the service specific processors on the client side for Chenile Proxy
Calls a bunch of interceptors defined at the level of the particular service.
Sets specific parts of the context to a value.
Implements a split aggregate functionality.
Utilities that allow testing of Aurora errors and warnings
An encapsulation of what constitutes a state.
Every entity that has a state that should be tracked must implement this interface.
All workflow entities (aka State entities) are managed using this interface.
Workflow entities contain state.
Workflow entities contain state.
A generic implementation of the
StateEntityService
for all state entities.This object stores the various tags that are supported by the XML configurator along
with their associated properties.
An implementation of a state transition machine.
Implement this interface to become an STM entry or exit action
A base action that can serve as a "do nothing" action.
Provides information about available actions for a given state etc.
This class returns the applicable authorities for the
StateEntityServiceImpl.processById(String, String, Object)
method.Selects the body type of the
ChenileExchange
based on the event Id passed
This should be used as the body type selector for the StateEntityServiceImpl.process(org.chenile.stm.StateEntity, String, Object)
method.Custom exception for the STM framework.
An interface that is used by a State Transition Machine implementation to obtain the
State Transition Diagram configuration.
A base implementation of STMFlowStore FlowStoreReaders parse various
representations of the flow (such as in an xml or in a db) and call the
addflow() method in this class.
The main STM implementation.
An interface that is available for the STM Transition action.
Generates a PLANT UML state diagram for the State Transition Diagram
An interface that would be used to invoke a security strategy.
This interface is useful to implement the actual logic to update the state to the new state ID.
Resolves bean name for the STM transition action in spring using the event ID and a prefix which
is specific to the workflow.
SubclassBodyTypeSelector uses the Subclass registry to determine the appropriate subclass based on the type to distinguish
between subclasses.
This is a registry of mapping base classes to the appropriate subclasses.
For example, if there is a base class
For example, if there is a base class
Vehicle
which is subclassed by Car.The combination of service and operation that are mapped to a Chenile event.
Emulates a switch construct.
A class that looks for a specific resource (using
TenantSpecificResourceLoader.tenantSpecificPath
) from the class path.The trajectory definition details.
For a given service, map a new Spring bean reference for a particular trajectory.
Processes all the trajectories
ConditionalOnTrajectory
annotations.Determines the target type for the body of the ChenileExchange and populates that into
ChenileExchange.getBodyType()
Uses registered bodyTypeSelectors either at ChenileServiceDefinition
or OperationDefinition
Performs a transformation from JSON to the
ChenileExchange.getBodyType()
mentioned in the
ChenileExchange
Interface implemented by the descriptors that support transient actions.
Registers the beans that are needed for chenile-http
As per HTTP convention, all custom headers start with "x-"
This interceptor copies all headers that start with "x-" into the context.
Extract and set warnings to response objects (either objects or maps)
Keeps the different components attached to various work flows in a registry.
Provides an xml implementation of the FlowStoreReader.
Chief class for the framework.