# 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/f338c/f338cb698073fbac076276b72441f288ca9d217c" alt="Untitled" | Signals the first step of a process. | | Intermediate Event | data:image/s3,"s3://crabby-images/6a7b3/6a7b3e066792eec5b1a27120c4566d24d496e868" alt="Untitled" | Represents any event that occurs between a start and end event. | | End event | data:image/s3,"s3://crabby-images/960e8/960e8838e616d9c77aab51f2a69b1e2c7d92cb9f" 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/4cc1e/4cc1ee07a13a49b6a7a537a538ca9113316dbb0d" 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/56f02/56f0262e78cc37dbd0f3fb114e799a21ca9facba" 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/004cc/004cce1d79b8d9e3e6650ed057777f5afa7727e4" alt="Untitled" | An inclusive gateway diverges the process flow into one or more flows. | | Complex gateway | data:image/s3,"s3://crabby-images/deac3/deac348fe0c2086af2bd1f026b604cf9569d90cd" 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/101e9/101e909bb6d0b608942a57c636ea137b1861bc22" 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/9ba35/9ba359eb4f35e0b8d19cf7ace92f6cf6b1ece838" 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/aff7a/aff7a6153c08a80ef6f15fb88db2c2f42c78114d" 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/56443/564439c3f9164ed64719aa42ab7cca6302fe3da6" 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/228ef/228ef5cebca657449bcad0b87ae5000e2e503d70" 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/08b9c/08b9c18dbe0f8dc53aaf17864fbbadce50be9b81" 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/b994a/b994a2f1f6f5eed779587327bfcfe286a8f3f54b" alt="Untitled" | A Script Task defines a script that the engine can interpret. | | Call Activity | data:image/s3,"s3://crabby-images/2b664/2b664cb0e42ffddf7bd34fdd1036fd7aac3e4510" 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/e0a6c/e0a6c40f2e0f18a5fe57be4bbfd2855062b50f62" 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/bd07e/bd07eaed7ff9e0e0c2263107cd09c188805680e3" alt="Untitled" | Connects flow objects in the proper sequential order. | | Message flow symbol |data:image/s3,"s3://crabby-images/8e75f/8e75f7a7a2d7a9e6a45724e59357f0bbed1a17c9" alt="Untitled" | Represents messages sent from one process participant to another. | | Association symbol | data:image/s3,"s3://crabby-images/1e036/1e0369e42a6f2d58ca5cdb3df107b36623dbc9b0" 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 |