Wiki Markup |
---|
{scrollbar} |
The architecture is designed so that each component only needs to do the smallest amount of work necessary to perform its job. A component does not need to know anything about schedulers, workflow engines, audit logs, or other components.
Control Flow
BI Components are executed as a result of someone or something requesting the Pentaho Solution Engine to execute an action sequence. Action sequences can be executed by users, schedulers, web services, workflow engines and API calls. In all cases the caller can provide parameters to the action sequence. The action sequence can, in addition to parameters from the request, define parameters that are fulfilled from other places such as a session. This section and chart describes the order of events as an action sequence is executed.
- Start. A call is made to an object in the services layer requesting execution of an action sequence. These objects use a request handler object that implements org.pentaho.core.services.IActionRequestHandler, create an instance of org.pentaho.solution.SolutionEngine, or use the helper methods in org.pentaho.core.solution.SolutionHelper. In each of these cases, parameters providers are passed to the solution engine. The request handlers and solution helper create an instance of the SolutionEngine and call its 'execute' method specifying the path and name of the action sequence to be executed and the parameter provider.
Examples of objects that do this are:- Servlet: org.pentaho.ui.servlet.ViewAction
- UI Component: org.pentaho.ui.component.ActionComponent
- Web Service: org.pentaho.ui.servlet.HttpWebService
- Scheduler: org.pentaho.plugin.quartz.QuartzExecute
- API: org.pentaho.core.solution.SolutionHelper
- The Solution Engine's 'execute' method:
- Checks that both the action sequence path and name have been provided
- Creates an instance of an IRuntimeElement and an IRuntimeContext. The details of the creation of this instance are added to the audit log along with its association with the caller's session. The Runtime Element stores the state of the action sequence if the process is long running, and the Runtime Context will handle the execution of the components.
- Calls the Solution Repository to load the action sequence. If the action sequence cannot be found, an error is returned to the caller and the failure is audited.
- Calls the Runtime Context's 'validateSequence' method.
- The Runtime Context's 'validateSequence' method:
- Sets the logging level of the action sequence to the desired level (can be specified by the original caller).
- Creates an instance of a component for each action defined in the action sequence. If the sequence includes two actions which use the EmailComponent, two instances of the component will be created. The same instance of the component will not be used for both actions. The Runtime Context needs BI Components to have a default constructor that accepts no parameters.
- Provides each component with various objects such as the caller's session, the requested logging level, and the Runtime Context.
- Calls each component's 'validate' method.
- The component's 'validate' method:
- Calls its own 'validateSystemSettings' method to validate any system-wide settings it needs.
- Calls its own 'validateAction' method to validate that the inputs, resources, and outputs available to it (as defined in the action sequence) are sufficient for it to execute.
If either of these validations fail for any component, the execution of the action sequence is terminated and the status is returned to the caller.
- The Solution Engine's 'execute' method calls the Runtime Context's 'executeSequence' method.
- The Runtime Context's 'executeSequence' method:
Steps and loops through the action definitions in the action sequence calling its 'executeAction' method for each action defined. - The Runtime Context's 'executeAction' method:
- Audits the start of component execution.
- Resolves the parameters to be made available to the component as defined in the action sequence, e.g. from the request parameter provider from the session parameter provider or from the outputs of other components. #*c.
- Calls the component's 'init' method.
- The component's 'init' method performs any initialization steps it needs.
- The Runtime Context's 'executeAction' method calls its 'executeComponent' method.
- The Runtime Context's 'executeComponent' method calls the components 'execute' method.
- The component's 'execute' method performs the steps it needs to complete its function.
- The Runtime Context's 'executeComponent' method calls the components 'done method.
- The component's 'done' method performs any clean-up steps it needs.
- The Runtime Context's 'executeAction' method audits the end of the component execution.
- The Solution Engine's 'execute' method
- Audits the end of the action sequence execution
- Returns the Runtime Context to the caller.
- End. The caller can use the Runtime Context to
- Get the final status of the execution
- Get the output objects of the action sequence
- Get the debug or error messages
Solution Engine | Runtime Context | BI Component |
---|---|---|
1. start | 1. start | Same as Solution Engine column1. |
2. execute()
|
|
|
| 3. validateSequence()
|
|
|
| 4. validate()
|
5. execute() |
|
|
| 6. executeSequence() |
|
| 7. executeAction() |
|
|
| 8. init() |
| 9. executeAction() |
|
| 10. executeComponent() |
|
|
| 11. execute() |
| 12. executeComponent() |
|
|
| 13. done() |
| 14. executeAction() |
|
15. execute() |
|
|
16. end
|
|
|
...