No project description provided
Project description
SCF_FSM_PACKAGE
A resuable python django package that can handle transition and workflow's in your django application .
Description
- The finflo package is designed to take over all the complexity in FSM building for a workflow scenario
- Your transition's are made easy with finflo
- customizable Actions and states with on_flow interchangable
Authors
Prerequisite
- python
- Django
- Django-rest-framework
1. Installation
1.1 Initial setup
- Install finflo using pip
pip install finflo
- In your django application , browse to installed_apps section in settings.py and add this ,
INSTALLED_APPS = [
'finflo',
'rest_framework'
]
- Add this in your settings.py
FINFLO = {
'WORK_MODEL' : ['MyApp.Model','MyApp2.Model2']
}
- Navigate to the middleware section in your settings.py and add the finflo middleware
MIDDLEWARE = [
'finflo.middleware.TransitionUserMiddleware',
]
- Now add this peice of code in your urls.py
urlpatterns = [
path('', include('finflo.urls'))
]
1.2 Migrations
- once all the steps done from the above section 1.1 .
- now we can apply the migrations for the database using ,
- python manage.py makemigrations
- python manage.py migrate
1.3 Re-migrate
- scenario 1 : if any new values is added to the WORK_MODEL
- example for scenario 1 :
# see 1.1
FINFLO = {
'WORK_MODEL' : ['MyApp.Model','MyApp2.Model2','MyApp3.Model3']
}
- you can remigrate the database without droping it using the below command .
- python manage.py migrate finflo 0002_remigrate
Usage
-
Once your setup is completed , whenever the objects in WORK_MODEL is created , the finflo automatically creates :
- Transition manager
- workflowitems
- workevents
-
The transition for each model can be carried out with :
- t_id (transition_id)
- type (model_type)
- action
- example
-
Some important information for transition are as follows :
Arguments Data_Type type str action str t_id int source (optional) str interim (optional) str target (optional) str from_party (optional) str to_party (optional) str
Additional API's
Api urls
Api URL's | METHOD | QUERY_PARAMS |
---|---|---|
localhost/model/ | GET | ?type=PROGRAM & t_id = 1 |
localhost/action/ | GET | NONE |
localhost/action/ | POST | NONE |
localhost/workflowitems/ | GET | NONE |
localhost/workevents/ | GET | NONE |
Support
For support, email support@venzo.com .
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
finflo-1.9.6.tar.gz
(15.4 kB
view details)
Built Distribution
finflo-1.9.6-py3-none-any.whl
(18.9 kB
view details)
File details
Details for the file finflo-1.9.6.tar.gz
.
File metadata
- Download URL: finflo-1.9.6.tar.gz
- Upload date:
- Size: 15.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 45b5a1c84d15abea76bc5520364029498ca0149c3c41ea0c52ca955a847dd959 |
|
MD5 | c24bb6a5563d0b46693e59048b26a9ca |
|
BLAKE2b-256 | e3ff530a34762af6c76ab8fb3d977211f6e91be4b54e60016af5ad1f5fc9e2db |
File details
Details for the file finflo-1.9.6-py3-none-any.whl
.
File metadata
- Download URL: finflo-1.9.6-py3-none-any.whl
- Upload date:
- Size: 18.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e333744ed46bd545c99ce0d48d6c939e1255e4bedeac46d14327a2752a79196e |
|
MD5 | 6b23bc99913f477275706b19803edb15 |
|
BLAKE2b-256 | d1b54da9786216a59b8375bd3484d7b25872c46e3c3c082cbeb5e6b5ee43acac |