Changes for version 0.04 - 2004-09-12
- eg (example application):
- Add CGI interface ('ticket.cgi') to example application, and move most of the logic into App::Web, which is now a full object instead of a bunch of class methods. Both the standalone web server ('ticket_web.pl') and the CGI script use the same logic, templates, template processing, etc.
- Workflow::Config
- Move Perl/XML configuration parsers to separate classes and make this class a factory.
- Add class method 'parse_all_files()' to allow you to pass in a list of mixed-type files (some XML, some Perl) and have them be parsed properly.
- Add documentation about implementing your own configuration reader
- Workflow::Config::Perl
- New class: code moved from Workflow::Config for perl-only parsing
- Workflow::Config::XML
- New class: code moved from Workflow::Config for XML-only parsing
- Workflow::Factory
- Invoke class method in Workflow::Config to deal with potentially different types of configuration (e.g., mixing and matching 'xml' and 'perl' files).
- Workflow::Persister::DBI::AutoGeneratedId:
- Fix typo bug spotted by Martin Winkler (winkler-martin@web.de)
Modules
Simple, flexible system to implement workflows
Base class for Workflow actions
Metadata about information required by an Action
Base class with constructor
Evaluate a condition depending on the workflow state and environment
Condition to determine if a user is available
Parse configuration files for the workflow components
Parse workflow configurations as Perl data structures
Parse workflow configurations from XML content
Data blackboard for Workflows, Actions, Conditions and Validators
Base class for workflow exceptions
Generates new workflow and supporting objects
Recorded work on a workflow action or workflow itself
Base class for workflow persistence
Persist workflow and history to DBI database
Pull IDs from databases that autogenerate them
Fetch extra data with each workflow and put it into the context
Persister to fetch ID from a sequence
Persist workflow and history to the filesystem
Persister to generate random ID
Persist workflows using SPOPS
Persister to generate Universally Unique Identifiers
Information about an individual state in a workflow
Ensure data are valid
Validator to ensure certain data are in the context
Ensure a value is one of a declared set of values
Ensure a stringified date matches a given pattern
Examples
- eg/ticket/App/Action/TicketComment.pm
- eg/ticket/App/Action/TicketCreate.pm
- eg/ticket/App/Action/TicketUpdate.pm
- eg/ticket/App/Condition/HasUserAndTicket.pm
- eg/ticket/App/Condition/IsCreator.pm
- eg/ticket/App/Condition/IsWorker.pm
- eg/ticket/App/Ticket.pm
- eg/ticket/App/User.pm
- eg/ticket/App/Web.pm
- eg/ticket/README
- eg/ticket/log4perl.conf
- eg/ticket/ticket.cgi
- eg/ticket/ticket.pl
- eg/ticket/ticket.sql
- eg/ticket/ticket_csv.sql
- eg/ticket/ticket_web.pl
- eg/ticket/web_templates/error.tmpl
- eg/ticket/web_templates/error_message.tmpl
- eg/ticket/web_templates/index.tmpl
- eg/ticket/web_templates/ticket_comment.tmpl
- eg/ticket/web_templates/ticket_form.tmpl
- eg/ticket/web_templates/workflow_actions.tmpl
- eg/ticket/web_templates/workflow_created.tmpl
- eg/ticket/web_templates/workflow_fetched.tmpl
- eg/ticket/web_templates/workflow_history.tmpl
- eg/ticket/web_templates/workflow_summary.tmpl
- eg/ticket/web_workflow.xml
- eg/ticket/workflow.xml
- eg/ticket/workflow_action.xml
- eg/ticket/workflow_condition.xml
- eg/ticket/workflow_persister.xml
- eg/ticket/workflow_validator.xml