NAME
Hyper::Config::Reader::Flow - ini style Flow Control config reader
VERSION
This document describes Hyper::Config::Reader::Flow 0.01
SYNOPSIS
use Hyper::Config::Reader::Flow;
my $object = Hyper::Config::Reader::Flow->new({
base_path => '/srv/web/www.example.com/',
file => 'etc/MyPortal/Control/Flow/FTest.ini',
});
DESCRIPTION
This module is used for reading ini config files into Hyper config objects.
ATTRIBUTES
- steps :get :default<{}>
- validators :get :default<{}>
- controls :get :default<{}>
- attributes :get :default<[]>
SUBROUTINES/METHODS
_read_config :PROTECTED
Internally used to read the config file into an object hierarchy.
DIAGNOSTICS
CONFIGURATION AND ENVIRONMENT
The ini style configuration files are stored within the following structure:
$BASE_PATH/etc/$NAMESPACE/Control/Flow/$SERVICE/$USECASE.ini
CONFIG FILE SYNTAX
The config file syntax is UNIX-Style .ini-Files. They are a bit different from Windows-style .ini files - the most notable difference is heredoc-support:
attribute=<<EOT
first_value
second_value
third_value
EOT
The config file is split into several sections.
Config file sections
[Global]
Global configuration data goes here.
The attributes allowed in [Global] are described below.
- attributes
-
Attributes for this Control. Multiple attributes can be specified using the heredoc syntax.
Example:
[Global]
attributes=<<EOT
mMyAttribute
mAnotherOne
EOT
[Control] - embedded controls
You can embed Flow, Container and Primitive controls. Each embedded control needs a unique name and a class.
Controls are all subsections of the section [Control]:
[Control]
[Control $NAME]
Controls have the following attributes:
- class :MANDATORY
-
Class of the embedded control. Perl class name with all '::' replaced by '.' and without the leading Hyper namespace
Example:
[Control cSampleControl] ; use Hyper::Control::Container::CSample as Perl class class=Control.Container.CSample
- template :OPTIONAL
-
Available for Container, Base and Primitive Controls. Template used for rendering a control. You may either specify a path relative to base_path or an absolute path.
- dispatch :OPTIONAL
-
You can specify a class where a method named DISPATCH exists. This method is called very early in our Hyper workflow, before anything was printed to the client. You can change the Hyper application for example if you won't send any HTML Headers. This is needed for example if you'd like to implement a download.
Full example:
[Control]
[Control cExampleControl]
class=ControlType.myService.myUsecase
template=/path/to/template
[Step] - workflow steps
A workflow consist of a number of steps. Steps may have actions (code) to be executed and controls to be displayed.
Steps are connected via transitions which may have conditions to be met.
All steps are subsections of the section [Step]:
[Step]
[Step myStep]
Steps may have the following attributes:
- action :OPTIONAL
-
Actions are executed before your own code is executed. In actions, you may assign data to embedded controls by reading out other controls' data or calling their methods.
Multiple actions can be specified using the heredoc syntax. Each action must be terminated by ';'.
Elements of the action syntax are described below.
this
The special control "this" refers to an instance of the current object itself:
this.mAccount=cAccount.value();
This corresponds to $self used as a convention in perl classes.
Constants
Numbers without any quotes or text with embraced by ' or ".
this.mNumericConstant=23; this.mStringConstant="Hello World"
Variables / Attributes
Variables can be nested with a '.' as seperator. Each variable must begin with a char A-Z, a-z as first sign. All other chars of the variable name can be A-Z, a-z, _ and 0-9.
this.mNumericConstant=this.someVariable; this.mStringConstant=cControl.anotherVariable2;
Methods
Each method name must begin with a char A-Z, a-z as first sign. All other chars of the variable name can be A-Z, a-z, _ and 0-9.
Methods can also be called on nested variables if the variable has this method.
Examples:
; assignment action=<<EOT this.mTextAttribute="This is a Constant"; this.mAnotherText='Another Constant'; this.mNumber=1234; cEmbeddedContainer.mValue=cAnotherContainer.mTest; EOT ; method call action=<<EOT this.callMe(); cEmbeddedContainer.mValue=cAnotherContainer.test(); EOT
[Step $SOURCE $DESTINATION] - transitions from one step to another
Each Step may have multiple transitions to other steps.
Transitions are written as sub-sections of the source step with the name of the destination step:
[Step SourceStep DestinationStep]
Transitions may only be performed when a condition is met. If no condition is specified, the transition will be performed automatically.
Transitions may have the following attributes:
- condition :OPTIONAL
-
You may use constants, variables, and method calls in conditions (see actions for more information). You can't make assignments but you may use the following logical operators.
Operator Description ------------------------------------ ! Logical not not Not operator == Numeric equal != Numeric uneuqal eq String equal ne String unequal && Logical and || Logical or and And operator or or operator
Operator precendence is equal to perl - see perlop for details.
Examples:
[Step One altTwo] condition=this.is_valid(); [Step One altTwo] condition=this.is_valid() && cControl.something.is_valid();
CODE GENERATION
use generate-flow.pl to generate a perl class for yout flow control with a shadow class and a basic template.
hyper.pl -b $BASE_PATH -s $SERVICE -u $USECASE -t flow
The following files will be generated:
if not existant:
$BASE_PATH/lib/Hyper/Control/Flow/$SERVICE/F$USECASE.pm
$BASE_PATH/var/Hyper/Control/Flow/$SERVICE/$USECASE.htc
always (previous files will be overwritten):
$BASE_PATH/lib/Hyper/Control/Flow/$SERVICE/_F$USECASE.pm
YOUR CODE
Each Step will call a method named action_$STEP_NAME if existant.
This methods may gather data from interfaces, perform interface calls etc.
You should place your code and template into
$BASE_PATH/lib/Hyper/Control/Flow/$SERVICE/F$USECASE.pm
$BASE_PATH/var/Hyper/Control/Flow/$SERVICE/$USECASE.htc
DEPENDENCIES
version
Hyper::Config::Reader
Class::Std::Storable
Hyper::Error
Hyper::Functions
Hyper::Config::Object::Step
Hyper::Config::Object::Control
Hyper::Config::Object::Transition
INCOMPATIBILITIES
BUGS AND LIMITATIONS
RCS INFORMATIONS
AUTHOR
Andreas Specht <ACID@cpan.org>
LICENSE AND COPYRIGHT
Copyright (c) 2007, Andreas Specht <ACID@cpan.org>
. All rights reserved.
This module is free software; you can redistribute it and/or modify it under the same terms as Perl itself.