mirror of
https://github.com/sartography/spiff-arena.git
synced 2025-03-01 09:30:46 +00:00
* ventilate prose * ventilate all the things --------- Co-authored-by: burnettk <burnettk@users.noreply.github.com>
91 lines
9.7 KiB
Markdown
91 lines
9.7 KiB
Markdown
# Understanding the terminology
|
|
|
|
## BPMN and SpiffWorkflow
|
|
|
|
Business Process Model and Notation (BPMN) is a diagramming language for specifying business processes.
|
|
BPMN bridges the gap between business and IT, creating a shared process language for both parties.
|
|
|
|
BPMN efficiently depicts the details of process behaviors in a diagram.
|
|
The precision of its meaning allows it to describe the technical details that control process execution in an automation engine.
|
|
SpiffWorkflow enables you to create code to execute a BPMN diagram directly.
|
|
|
|
By using SpiffWorkflow, a client can create the BPMN diagram and have their product work without the need for you to modify the Python code, thus improving response and turnaround time.
|
|
|
|
## Flow Objects
|
|
|
|
Flow objects are divided into three groups: Events, Gateways, and Tasks.
|
|
|
|
### Events
|
|
|
|
Events, represented by circles, describe occurrences during a process.
|
|
There are three main types of events in business process modeling: start events, intermediate events, and end events.
|
|
|
|
| **Event** | **Symbol**| **Description** |
|
|
|-----------|-----------|-----------------|
|
|
| Start Event |data:image/s3,"s3://crabby-images/f0e6b/f0e6bf15271409663097e7e57898acaebe55392e" alt="Untitled" | Signals the first step of a process. |
|
|
| Intermediate Event | data:image/s3,"s3://crabby-images/04f7b/04f7bf2a2144bc3ce26c3d0dd70db4a074170ced" alt="Untitled" | Represents any event that occurs between a start and end event. |
|
|
| End event | data:image/s3,"s3://crabby-images/faef5/faef5611bb94e5af2a08cedf93e3553d50613842" alt="Untitled" | Signals the final step in a process. |
|
|
|
|
### Gateways
|
|
|
|
Gateways represent decision points in a process.
|
|
Based on certain conditions or rules, they determine which path the process will follow.
|
|
There are various types of gateways:
|
|
|
|
| **Gateway** | **Symbol**| **Description** |
|
|
|---------------|-----------|-----------------|
|
|
| Exclusive gateway |data:image/s3,"s3://crabby-images/08c5e/08c5e7849fc7e44371757c83f02e600d29b027a6" alt="Untitled" | Evaluates the state of the business process and, based on the condition, diverges the flow into one or more mutually exclusive paths. |
|
|
| Event-based gateway | data:image/s3,"s3://crabby-images/5c2b1/5c2b19830d4603f160cce7b72f015d3fcc75cba4" alt="Untitled" | An event-based gateway is similar to an exclusive gateway in that both involve one path in the flow. However, with an event-based gateway, you evaluate which event has occurred, not which condition has been met. |
|
|
| Inclusive gateway | data:image/s3,"s3://crabby-images/646a5/646a59a11b771ca59571c2a250b317a55bc2822c" alt="Untitled" | An inclusive gateway diverges the process flow into one or more flows. |
|
|
| Complex gateway | data:image/s3,"s3://crabby-images/b3b50/b3b5071a1fcdf8fcc3c1a89239a7600e10ed64f6" alt="Untitled" | Complex gateways are used only for the most intricate flows in the business process. They use words instead of symbols and thus require more descriptive text. |
|
|
|
|
### Tasks
|
|
|
|
Tasks represent activities or work that needs to be done as part of a process.
|
|
They can either be manual tasks that require human intervention or automated tasks that are performed by systems or applications.
|
|
|
|
| **Task** | **Symbol** | **Description** |
|
|
|---------------|------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|
|
| Service | data:image/s3,"s3://crabby-images/b051d/b051dfc7e3078775d01e0a9e5d8d6ff07d597234" alt="Untitled" | A task that utilizes a Web service, an automated application, or other types of service to complete the task. |
|
|
| Send |data:image/s3,"s3://crabby-images/02063/0206319f7358dcdd86a00ad7400a63256548e609" alt="Untitled" | A 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/98e68/98e68f2e5cd3bed0f632d30ccec5f6c02bd644c9" 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 been received. |
|
|
| User | data:image/s3,"s3://crabby-images/fc3bc/fc3bc22fd41bb0c8ad224aaea98f20dd75744f60" alt="Untitled" | A User Task denotes that a human performer completes the task with the help of a software application. |
|
|
| Manual | data:image/s3,"s3://crabby-images/9d9a9/9d9a99fa81f7abcf93a1b3a76832f5f0a0591d4e" alt="Untitled" | A Manual Task is a task performed without the aid of any business process execution engine or application. |
|
|
| Business Rule |data:image/s3,"s3://crabby-images/2a5ca/2a5ca9748868c461a1c0de95ba0c5a4bdc318a24" alt="Untitled"| A Business Rule Task provides a mechanism for a process to supply input to a Business Rules Engine and then obtain the output provided by the Business Rules Engine. |
|
|
| Script | data:image/s3,"s3://crabby-images/db6b7/db6b71ab8a23c8710b6976a4b91a187c001555ee" alt="Untitled" | A Script Task defines a script that the engine can interpret. |
|
|
| Call Activity | data:image/s3,"s3://crabby-images/d1753/d17533d20c53ac3d5c61ffe9000f33802db70a72" alt="Untitled" | A call activity allows you to call and invoke another process as part of this process. |
|
|
| Sub-Process | data:image/s3,"s3://crabby-images/93499/93499705a57e54efe656e2677770e6761fd5471d" alt="Untitled" | Sub-processes allow you to collapse and expand tasks to convey information quickly. |
|
|
|
|
## Connecting Objects
|
|
|
|
Connecting objects are lines that connect BPMN flow objects.
|
|
Three different types exist: sequence flows, message flows, and associations.
|
|
|
|
| **Connecting Objects** | **Symbol** | **Description** |
|
|
|---------------|------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|
|
| Sequence flow symbol | data:image/s3,"s3://crabby-images/a1f84/a1f84da2c09df7d14e1bcda4ed1c50c64a7dbbe3" alt="Untitled" | Connects flow objects in the proper sequential order. |
|
|
| Message flow symbol |data:image/s3,"s3://crabby-images/5b0a5/5b0a5a4b549f0eac652c8463eded72b585e969ef" alt="Untitled" | Represents messages sent from one process participant to another. |
|
|
| Association symbol | data:image/s3,"s3://crabby-images/d64ff/d64ffd18375e70df34c9af6c2c3f8ded35761fe2" alt="Untitled" | Illustrates relationships between artifacts and flow objects. |
|
|
|
|
## Artifacts
|
|
|
|
Artifacts are used to provide additional information or documentation within a process.
|
|
They include data objects (which represent information or data needed for the process), annotations (which provide explanatory or descriptive text), and groups (which are used to visually group related elements).
|
|
|
|
| **Artifact** | **Symbol** | **Description** |
|
|
|---------------|------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|
|
| Data Object |<div style="height:50px;width:50px"> data:image/s3,"s3://crabby-images/3cc0e/3cc0efca97db8ff3138ca0d3df6b8cf0f9712d72" alt="Untitled" | Data objects can represent data input to the process, data resulting from the process, or data that needs to be collected. |
|
|
| Data Storage |data:image/s3,"s3://crabby-images/bbac1/bbac189f57e210777bdeb759e0c42fa194491760" alt="Untitled" | Data storage facilitates the storage or access of data associated with a business model. If your process produces any data, it will become necessary to store that data. |
|
|
| Group | <div style="height:50px;width:50px"> data:image/s3,"s3://crabby-images/19c18/19c18582085c37816f2c218898c59598aafc65d8" alt="Untitled" | Groups organize tasks or processes that are significant in the overall process. |
|
|
| Annotation | <div style="height:50px;width:50px"> data:image/s3,"s3://crabby-images/f6fc3/f6fc3f3a478b1f5d793f1b673685a75f1dd93526" alt="Untitled" | Annotations allow you to describe the business process and flow objects in greater detail. |
|
|
|
|
## Swimlanes
|
|
|
|
Swimlanes are used in a BPMN diagram to organize aspects of a process.
|
|
They 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.
|
|
Not only do swimlanes organize activities into separate categories, but they also reveal delays, inefficiencies, and the individuals responsible for each step in a process.
|
|
|
|
data:image/s3,"s3://crabby-images/a9e7d/a9e7d4bd41ecfad8bf5ec1699dd68376d4ae7f39" alt="Untitled"
|