Download the PHP package gmorel/state-workflow-bundle without Composer

On this page you can find all versions of the php package gmorel/state-workflow-bundle. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.

FAQ

After the download, you have to make one include require_once('vendor/autoload.php');. After that you have to import the classes with use statements.

Example:
If you use only one package a project is not needed. But if you use more then one package, without a project it is not possible to import the classes with use statements.

In general, it is recommended to use always a project to download your libraries. In an application normally there is more than one library needed.
Some PHP packages are not free to download and because of that hosted in private repositories. In this case some credentials are needed to access such packages. Please use the auth.json textarea to insert credentials, if a package is coming from a private repository. You can look here for more information.

  • Some hosting areas are not accessible by a terminal or SSH. Then it is not possible to use Composer.
  • To use Composer is sometimes complicated. Especially for beginners.
  • Composer needs much resources. Sometimes they are not available on a simple webspace.
  • If you are using private repositories you don't need to share your credentials. You can set up everything on our site and then you provide a simple download link to your team member.
  • Simplify your Composer build process. Use our own command line tool to download the vendor folder as binary. This makes your build process faster and you don't need to expose your credentials for private repositories.
Please rate this library. Is it a good library?

Informations about the package state-workflow-bundle

StateWorkflowBundle logo

State Workflow Bundle

Build Status Scrutinizer Code Quality Code Coverage Dependency Status Latest Stable Version License

Symfony 2

Helping you implementing a complex yet easily maintainable workflow.

Keywords : State Design Pattern, Workflow, Finite State Machine, Symfony2

Workflow

Our StateWorkflow object is responsible for managing all your States and their Transitions for your given Entity implementing HasStateInterface. Every single State is a class implementing our StateInterface and is managing its own transitions.

Ubiquitous Language

Pros

Cons

 Usage

With this Service declarations

Implementation example

Booking Demo https://github.com/gmorel/StateWorkflowDemo

Details

It will allow you to manage States and especially their available Transitions for an Entity (for example a Booking class) implementing our interface HasStateInterface. It is aiming at helping implementing a complex Workflow where each State implementing our interface StateInterface is responsible for its Transitions (methods) to other States. Some Transitions being impossible (not part of your Workflow) and then throwing the exception UnsupportedStateTransitionException whenever called.

Each State has a Symfony2 service tag:

This way you will be able to manage available States for different Entities by using other Symfony2 tags since Booking, Content and Customer entities shall not share the same Workflow/States). You will then need to modify the Symfony2 CompilerPass in order to let your Workflow be aware of its States.

Adding new State:

In case you wish to add a new State you will need to create a new Class implementing our interface StateInterface.

Adding new Transition:

In case you wish to add a new Transition you will need to add a new method in your XXXStateInterface extending our StateInterface. You can also use our helper AbstractState which would implement default behavior ie. a method throwing our UnsupportedStateTransitionException.

Installation

Step 1: Download the Bundle

Open a command console, enter your project directory and execute the following command to download the latest stable version of this bundle:

This command requires you to have Composer installed globally, as explained in the installation chapter of the Composer documentation.

Step 2: Enable the Bundle

Then, enable the bundle by adding the following line in the app/AppKernel.php file of your project:

How it works internally

UML

Credits

Licence

MIT License (MIT)

Contributing

Feel free to enhance it and to share your ideas/enhancements.


All versions of state-workflow-bundle with dependencies

PHP Build Version
Package Version
Requires php Version >=5.3.3
symfony/symfony Version ~2.3
Composer command for our command line client (download client) This client runs in each environment. You don't need a specific PHP version etc. The first 20 API calls are free. Standard composer command

The package gmorel/state-workflow-bundle contains the following files

Loading the files please wait ....