mirror of
https://github.com/sartography/spiff-arena.git
synced 2025-02-21 21:58:21 +00:00
* let us proof everything * proof and ventilate everything * restore removed content * add back in some headers * add back more headers * restore header * fix header * fix backend * restore two long files from main to avoid mangling * update edit_all for testing * fix docs * notes * more spacing --------- 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/7fd65/7fd65830ad3b1cfdf394445348fd05bff1b7cbfd" alt="Untitled" | Signals the first step of a process. |
|
|
| Intermediate Event | data:image/s3,"s3://crabby-images/a6e31/a6e31225c433b34e771859941308f0ae07735ed7" alt="Untitled" | Represents any event that occurs between a start and end event. |
|
|
| End Event | data:image/s3,"s3://crabby-images/c36ad/c36ad1706ac4476b613e6f935da9970e8c9c2b23" 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/db983/db983edd8af3cd3bc52da81c235aac275d0fbba9" 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/3d069/3d069c246194a47f694a7f0d729dc5dc27a02ab9" 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/1ebb5/1ebb5b6c784a95e0deda096607535a7fa6db77cb" alt="Untitled" | An inclusive gateway diverges the process flow into one or more flows. |
|
|
| Complex Gateway | data:image/s3,"s3://crabby-images/55bb0/55bb0c9e9991c0504dc53a3d47a0eb0cfbe20bd3" 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/4a7ee/4a7ee90dec2f887f4a590f7aa3671b13d003d2a0" 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/e286c/e286cc752fbfef26eca2ac675ffd5180b991a9bb" 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/cbd9c/cbd9c43b8bcde835e95998374d79fec90d9f8346" 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/fe5ef/fe5efb97b3e3d6dd0cc2156a290b7b2d8266d01c" 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/2be66/2be665a3dea11d7377e964f2cc4f25ce9ca9f25d" 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/082d4/082d4ee2cba3f970cc251de7d5a95fe505075044" 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/b4d46/b4d46251d8944937bc0f5380539117de9e034e10" alt="Untitled" | A Script Task defines a script that the engine can interpret. |
|
|
| Call Activity | data:image/s3,"s3://crabby-images/72fb9/72fb976f37bf046ce1f5b5d352514b710d83d746" 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/6def6/6def660af478d3e9fa1ae8b0c6247366100e6a72" 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/f2c77/f2c778b42e2fd2b9c17d4256e59c5c69219c38ce" alt="Untitled" | Connects flow objects in the proper sequential order. |
|
|
| Message Flow Symbol |data:image/s3,"s3://crabby-images/f19d6/f19d66b6d0912517129b34146630c500fa82e4e2" alt="Untitled" | Represents messages sent from one process participant to another. |
|
|
| Association Symbol | data:image/s3,"s3://crabby-images/24389/24389ce2b634bcb53a9ccd6fb2898c888760968c" 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/a638a/a638a0a14bc0486519d117da407c1f6cccda0fa5" 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/1f2c9/1f2c9079f0fb21c3be62a0559780f028c78f2d1f" 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/ea0c0/ea0c0f8a413b0ec5b647028c6b4578947d11ec39" 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/1d5fb/1d5fb56acc445c67f2c369d42245db424cf1c8b2" 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/35104/35104d214c5a1b73ba82c6e4c7462f43851790bc" alt="Untitled"
|