mirror of
https://github.com/sartography/spiff-arena.git
synced 2025-02-24 07:08:16 +00:00
* fix * rename files * rename titles * rename * pluralize * fix * sub-process * sub-process * sub-process * renames * rename --------- Co-authored-by: burnettk <burnettk@users.noreply.github.com>
125 lines
7.0 KiB
Markdown
125 lines
7.0 KiB
Markdown
# Data Objects
|
|
|
|
In BPMN (Business Process Model and Notation), a data object represents the information or data used and produced by activities within a business process.
|
|
It signifies the data elements or artifacts that are relevant to the process and provides a means to model the flow of data through the process.
|
|
They aid in elucidating the data flow and dependencies within the process, thus making it more straightforward to comprehend how information is utilized and transformed throughout the process execution.
|
|
|
|
**Reasons to use data objects:**
|
|
|
|
- To represent and manage data within a business process.
|
|
|
|
- When it's necessary to make a specific reference to data being used.
|
|
|
|
- When dependencies exist between tasks or activities based on shared data.
|
|
|
|
- When data changes within a process.
|
|
|
|
- If data needs to be stored or retrieved for use in a process.
|
|
|
|
## Data Object Types
|
|
|
|
### Data Input
|
|
|
|
data:image/s3,"s3://crabby-images/a10c2/a10c21dc07e46235f22ec88669abbe95374ba9f0" alt="data_input"
|
|
|
|
This represents the data or information that is needed as an input to initiate or carry out a specific task or process.
|
|
BPMN input defines the data elements that must be provided or available for the task to be performed.
|
|
|
|
### Data Output
|
|
|
|
data:image/s3,"s3://crabby-images/ff535/ff535097d2b3f3dc4752de62165aa6538403aab5" alt="data_output"
|
|
|
|
This signifies the data or information that is created or generated as a result of executing a task or process.
|
|
BPMN output describes the data elements that are produced or altered during the execution of the task.
|
|
|
|
### Data Object Reference
|
|
|
|
data:image/s3,"s3://crabby-images/c4c3d/c4c3db4302254915249aa2b21ec9ceb02c6e11c2" alt="data_object_reference"
|
|
|
|
A Data Object in BPMN typically signifies a particular piece of information or a data entity that is exchanged or manipulated during the course of a business process.
|
|
It can represent both physical and digital data.
|
|
Examples of Data Objects include documents, forms, reports, databases, or any other data entity relevant to the process.
|
|
|
|
## Data Input Configuration
|
|
|
|
| 💻 Form | ⌨ Field Input | 📝 Description |
|
|
| ------------------------------------------------------- | ---------------------------------------------------- | ------------------------------------------------------------------------------------------------------ |
|
|
| data:image/s3,"s3://crabby-images/cb70a/cb70af10c3315fb17cc573ba86e454a42312f5ae" alt="name_field" | **Name:** Update Customer Information | An identifier used to uniquely identify the element within the BPMN model. |
|
|
| data:image/s3,"s3://crabby-images/f8964/f8964159c3381f5b4ef7ee18e220d1fbb937d576" alt="id_field" | **ID:** Example - updateCustomerInformation | A descriptive name given to the element, providing a human-readable label or title. |
|
|
| data:image/s3,"s3://crabby-images/94d15/94d15444432a9a7e40d2ccfba71e1d289fb45cc9" alt="documentation_field" | **Element Documentation:** URL, Raw Data, Plain Text | Additional information or documentation related to the element, such as URLs, plain text, or raw data. |
|
|
| data:image/s3,"s3://crabby-images/4b50b/4b50bff5eed486b78cc7cbc69dba278759ba21ea" alt="data_object_prop" | **Element Documentation:** inventory_items | Enter an existing data object ID |
|
|
|
|
## Handling Sensitive Data Using Data Objects
|
|
|
|
Handling sensitive data, such as credit card numbers and passwords, requires careful management to ensure security and privacy.
|
|
This documentation outlines the process of creating and managing sensitive data objects within SpiffWorkflow, along with setting appropriate permissions.
|
|
|
|
### Process Breakdown
|
|
|
|
#### 1. Identifying Sensitive Data
|
|
|
|
- Determine what constitutes sensitive data within your workflow.
|
|
This could include personal information, financial details, or confidential business information.
|
|
|
|
#### 2. Data Object Creation and Script Task Integration
|
|
|
|
- **Script Task Setup**: Develop a script task that interacts with the data object.
|
|
The script should be designed to handle the sensitive data securely, ensuring it's not exposed or logged inadvertently.
|
|
- **Data Object Creation**: Create a data object in the workflow to store the sensitive data.
|
|
This object acts as a container for the data, separating it from the main workflow logic.
|
|
|
|
#### 3. Assigning Data Categories
|
|
|
|
- **Categorization**: Assign a specific category to the data object that reflects its sensitive nature.
|
|
For example, categories like `confidential` or `private` or the name of the field can be used.
|
|
|
|
#### 4. Implementing Access Controls
|
|
|
|
- **Permission Rules**: Establish permission rules, using a Decision Model and Notation (DMN) table or another mechanism as described under [Admin and Permissions](/how_to_guides/deployment/manage_permissions).
|
|
This step involves specifying who can access the sensitive data.
|
|
- **Access Restrictions**: Define the access level (e.g., read, write, deny) for different user groups or roles.
|
|
For instance, you might restrict read access to certain groups while denying it to others.
|
|
- **URL-Based Permissions**: Use URL patterns to enforce permissions.
|
|
For example, a URL pattern like `/process-data/confidential/*` can be used to control access to all data objects categorized as confidential.
|
|
|
|
### Example: Steps to Handle Sensitive Data
|
|
|
|
#### 1. Creating a Script Task with Sensitive Data
|
|
|
|
- **Initial Setup**: Start by creating a script task where the script sets a variable (e.g., `a=1`).
|
|
This variable `a` could represent sensitive data like a credit card number.
|
|
- **Execution**: Run the task to observe the value of `a`.
|
|
data:image/s3,"s3://crabby-images/7a2e1/7a2e12fc299bed173fed149ed4c48e72f2c33804" alt="image"
|
|
|
|
#### 2. Converting to a Data Object
|
|
|
|
- **Data Object Creation**: Create a data object and name it (e.g., `a`).
|
|
Link this data object to the script task and set the data object ID to `a`.
|
|
- **Assign a Category**: Assume the data object represents a credit card number.
|
|
Assign a category to this data object, such as `creditcards`.
|
|
- **Visibility**: The credit card data is visible until permissions are set to restrict access.
|
|
data:image/s3,"s3://crabby-images/f441a/f441a808d38a6930b9e22d2479ad8f3723a02a44" alt="image"
|
|
- **Process Execution**: Upon running the process, the value of the data object will be `1`.
|
|
data:image/s3,"s3://crabby-images/4dad6/4dad68e653580561fe5c4e80197031fa19a53722" alt="image"
|
|
|
|
#### 3. Setting Permissions with DMN Table
|
|
|
|
- **Access Control**: To control who can see the credit card data, you could set permissions in a DMN Table.
|
|
- **Permission Configuration**: Set the following permissions:
|
|
- `permission_groups` to `"everybody"`
|
|
- `permissions` to `"DENY:read"`
|
|
- `permission_urls` to `"/process-data/creditcards/"`
|
|
|
|
data:image/s3,"s3://crabby-images/2eff4/2eff441769a837cc7af1bf62293b7cec8e351960" alt="image"
|
|
|
|
#### 4. Implementing Restricted Access
|
|
|
|
With these permissions, access to the credit card data is denied to everyone, ensuring that no unauthorized individuals can view this sensitive information.
|
|
|
|
By following these steps, SpiffWorkflow users can securely handle sensitive data within their processes.
|
|
The combination of data objects, categorization, and precise permission settings ensures that sensitive information like credit card numbers is protected and accessible only to those with the necessary authorization.
|
|
|
|
```{tags} reference, building_diagrams
|
|
|
|
```
|