mirror of
https://github.com/sartography/spiff-arena.git
synced 2025-03-02 18:10:36 +00:00
* updating structure with proper file names * fixing build issues * build issues * fixing build errors * Adding support section * a little less noise on the index page - maybe we look into adding some intro content here. --------- Co-authored-by: danfunk <daniel.h.funk@gmail.com>
76 lines
9.8 KiB
Markdown
76 lines
9.8 KiB
Markdown
# Understand the terminology
|
||
|
||
## BPMN and SpiffWorkflow
|
||
|
||
Business Process Model and Notation (BPMN) is a diagramming language for specifying business processes. BPMN links the realms of business and IT, and creates a common process language that can be shared between the two.
|
||
|
||
BPMN describes details of process behaviors efficiently in a diagram. The meaning is precise enough to describe the technical details that control process execution in an automation engine. SpiffWorkflow allows you to create code to directly execute a BPMN diagram.
|
||
|
||
When using SpiffWorkflow, a client can create the BPMN diagram and still have their product work without a need for you to edit the Python code, improving response and turnaround time.
|
||
|
||
|
||
## Flow Objects
|
||
The flow objects are divided into the following three groups: Event, Gateways and Tasks.
|
||
|
||
### Events
|
||
Events, represented with circles, describe something that happens during the course of a process. There are three main events within business process modeling: start events, intermediate events, and end events.
|
||
|
||
| **Event** | **Symbol**| **Description** |
|
||
|-----------|-----------|-----------------|
|
||
| Start Event |data:image/s3,"s3://crabby-images/a865a/a865aaa721228ed067e29c0d9e7b39c492b78f9c" alt="Untitled" | Signals the first step of a process |
|
||
| Intermediate Event | data:image/s3,"s3://crabby-images/2dd98/2dd9834909d5cd92371d5468299b9765fdc684cf" alt="Untitled" | Represents any event that occurs between a start and end event. |
|
||
| End event | data:image/s3,"s3://crabby-images/289fc/289fcf2ef753f228deb4b08f48ba45fed309c3da" alt="Untitled" | Signals the final step in a process. |
|
||
|
||
### Gateways
|
||
Gateways represent decision points in a process. They determine which path the process will take based on certain conditions or rules. There are different types of gateways:
|
||
|
||
| **Gateway** | **Symbol**| **Description** |
|
||
|---------------|-----------|-----------------|
|
||
| Exclusive gateway |data:image/s3,"s3://crabby-images/bd3c4/bd3c400a5dc0e28a4ed5e4f22bab5803feeaaa26" alt="Untitled" | Evaluates the state of the business process and, based on the condition, breaks the flow into one or more mutually exclusive paths |
|
||
| Event-based gateway | data:image/s3,"s3://crabby-images/5d6d0/5d6d01ec12c6484cb946f5a7bae594527c2c6ffe" alt="Untitled" | An event-based gateway is similar to an exclusive gateway both involve one path in the flow. In the case of an event-based gateway, however, you evaluate which event has occurred, not which condition has been met. |
|
||
| Inclusive gateway | data:image/s3,"s3://crabby-images/6d612/6d612e23620f6ebaef8ccf57f6d6b55ba73c73f3" alt="Untitled" | An inclusive gateway breaks the process flow into one or more flows. |
|
||
| Complex gateway | data:image/s3,"s3://crabby-images/66aa9/66aa9cdc667310d0378198e096ccb6287ecee0e4" alt="Untitled" | Complex gateways are only used for the most complex flows in the business process. They use words in place of symbols and, therefore, require more descriptive text. |
|
||
|
||
### Tasks
|
||
Tasks represent activities or work that needs to be performed as part of a process. They can be manual tasks that require human intervention or automated tasks that are executed by systems or applications.
|
||
|
||
| **Task** | **Symbol** | **Description** |
|
||
|---------------|------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|
||
| Service | data:image/s3,"s3://crabby-images/3ee85/3ee8528bc481b9fa7544fe6082b3ccab9f65cebe" alt="Untitled" | Task that uses a Web service, an automated application, or other kinds of service in completing the task. |
|
||
| Send |data:image/s3,"s3://crabby-images/25834/2583462106e0049f3c3a1ad020594384cdce4019" alt="Untitled" | Task that sends a Message to another pool. The Task is completed once the Message has been sent. |
|
||
| Receive | data:image/s3,"s3://crabby-images/bee04/bee0483d51ccfaa97cb7c34be148a0f078fc73ae" alt="Untitled" | A Receive Task indicates that the process has to wait for a message to arrive in order to continue. The Task is completed once the| message has received. |
|
||
| User | data:image/s3,"s3://crabby-images/02c46/02c46ca059cf5cd53a3b24a5062792d875f5fa45" alt="Untitled" | A User Task represents that a human performer performs the Task with the use of a software application. |
|
||
| Manual | data:image/s3,"s3://crabby-images/ea3b4/ea3b44f4841e09ad4a4bc4effed4d62b40079d6c" alt="Untitled" | A Manual Task is a Task that is performed without the aid of any business process execution engine or any application. |
|
||
| Business Rule |data:image/s3,"s3://crabby-images/0f3a1/0f3a1a0728c23424fd8f58edac4794b6abf58079" alt="Untitled"| Business Rule Task provides a mechanism for a process to provide input to a Business Rules Engine and then obtain the output provided by the Business Rules Engine. |
|
||
| Script | data:image/s3,"s3://crabby-images/315a0/315a062b047d616e7d95a6c02aee0d4027690f46" alt="Untitled" | A Script Task defines a script that the engine can interpret. |
|
||
| Call Activity | data:image/s3,"s3://crabby-images/059ba/059ba12ba02ad1419e47eabf94f7a189810e03f2" alt="Untitled" | A call activity allows you to call and invoke another process as part of this process.processes. |
|
||
| Sub-Process | data:image/s3,"s3://crabby-images/2d851/2d851dbfd927a10a26b7dda7a5761a069e2a089d" alt="Untitled" | Sub-processes allow you to collapse and expand tasks to quickly convey information. |
|
||
|
||
|
||
## Connecting Objects
|
||
|
||
Connecting objects are lines that connect BPMN flow objects. There are three different types: sequence flows, message flows, and associations.
|
||
|
||
| **Connecting Objects** | **Symbol** | **Description** |
|
||
|---------------|------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|
||
| Sequence flow symbol | data:image/s3,"s3://crabby-images/5f7a7/5f7a7e472b3b9e4e4da23c9192454b6791a6bc46" alt="Untitled" | Connects flow objects in proper sequential order. |
|
||
| Message flow symbol |data:image/s3,"s3://crabby-images/d1f27/d1f2775e6c002fb76110934744b5ccc0b6f5969e" alt="Untitled" | Represents messages from one process participant to another. |
|
||
| Association symbol | data:image/s3,"s3://crabby-images/55a82/55a8226e65c4bf22fd0cc63ab1eaa8a74f2649cb" alt="Untitled" | Shows relationships between artifacts and flow objects. |
|
||
|
||
|
||
## Artifacts
|
||
Artifacts are used to provide additional information or documentation within a process. They include data objects (representing information or data needed for the process), annotations (providing explanatory or descriptive text), and groups (used to visually group related elements).
|
||
| **Artifact** | **Symbol** | **Description** |
|
||
|---------------|------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|
||
| Data Object |<div style="height:50px;width:50px"> data:image/s3,"s3://crabby-images/d1469/d1469e3e1e64b955a825e028230c75cfff9f8fef" alt="Untitled" | Data objects can represent data placed to the process, data resulting from the process, data that needs to be collected |
|
||
| Data Storage |data:image/s3,"s3://crabby-images/78c83/78c83ccd780583c1828166703ebf98605d786f6f" alt="Untitled" | Data storage provides the ability to store or access data that is associated with a business model. If your process outputs any data, it will become necessary to store that data. |
|
||
| Group | <div style="height:50px;width:50px"> data:image/s3,"s3://crabby-images/bf5e4/bf5e4ca26cc67837f3a3b3356174c473a6b09b22" alt="Untitled" | Groups organize tasks or processes that have significance in the overall process. |
|
||
| Annotation | <div style="height:50px;width:50px"> data:image/s3,"s3://crabby-images/7ede1/7ede177fbf365b9e66ab3bc86395c0d6bd13e2e3" alt="Untitled" | Annotations allow you to describe the business process and flow objects in more detail. |
|
||
|
||
## Swimlanes
|
||
Swimlanes are used to organize aspects of a process in a BPMN diagram. Swimlanes visually group objects into lanes, with each aspect of the process added to a separate lane.
|
||
|
||
These elements can be arranged either horizontally or vertically. Swimlanes not only organize activities into separate categories, they can reveal delays, inefficiencies, and the workers responsible for each step in a process.
|
||
|
||
data:image/s3,"s3://crabby-images/ebf7e/ebf7e20e502bcdbec392a179e7e6791e027ac3e2" alt="Untitled"
|