Approval Types and Step Types
Approval Types and Step Types
This document describes all the available approval types and step types in ApprovalML, and how they behave in workflows.
Step Types
1. decision - Standard Approval Step
- Purpose: Single approver with approve/reject actions
- Behavior: Blocks workflow until action is taken
- Actions Available: Approve, Reject, Request More Information
- Use Case: Manager approvals, final decisions
2. parallel_approval - Multiple Approvers
- Purpose: Multiple approvers can work simultaneously
- Behavior: All approvers must complete (or configured strategy)
- Actions Available: Approve, Reject, Request More Information
- Use Case: Team reviews, committee approvals
3. conditional_split - Dynamic Routing
- Purpose: Route workflow based on form data or conditions
- Behavior: Automatically processes and routes to next step
- Actions Available: None (automatic)
- Use Case: Amount-based routing, department-specific flows
4. automatic - System Processing
- Purpose: System performs actions without human intervention
- Behavior: Automatically completes and continues
- Actions Available: None (automatic)
- Use Case: Data processing, system integrations, notifications
5. notification - Non-blocking Notification
- Purpose: Send notifications without requiring action
- Behavior: Automatically completes and continues
- Actions Available: None (automatic)
- Use Case: FYI notifications, status updates
Approval Types
1. needs_to_approve (Default)
Recipients with this role type... can do the following:
- Approve will move the workflow to the next recipient (if any)
- Decline will send the workflow back to the requestor for re-submission
- Request More Information will also send the workflow back to the requestor for re-submission
YAML Example:
manager_approval:
name: "manager_approval"
type: "decision"
approver: "${requestor.manager}"
approval_type: "needs_to_approve" # Optional, this is the default
on_approve:
continue_to: "next_step"
on_reject:
end_workflow: true2. needs_to_sign
Recipients with this role type... can do the following:
- Provide Signature will capture the recipient's signature and move the workflow to the next recipient (if any)
- Decline will send the workflow back to the requestor for re-submission
- Request More Information will also send the workflow back to the requestor for re-submission
YAML Example:
legal_signature:
name: "legal_signature"
type: "decision"
approver: "legal_team"
approval_type: "needs_to_sign"
on_approve:
continue_to: "next_step"
on_reject:
end_workflow: trueExternal/Unregistered Approvers
For external users (vendors, clients, contractors) who don't have accounts, use the approver object format:
vendor_signature:
name: "vendor_signature"
type: "decision"
approver:
email: "vendor@external.com"
name: "Jane Smith"
position: "Vendor Representative"
employee_type: "external" # Options: internal, external, contractor
approval_type: "needs_to_sign"
on_approve:
continue_to: "next_step"
on_reject:
end_workflow: trueFeatures:
- Automatically creates employee record if email doesn't exist
- No pre-registration required
- Signature stored against employee record
- Supports template variables from form data
Dynamic approvers from form fields:
client_acknowledgement:
name: "client_acknowledgement"
type: "decision"
approver:
email: "${form.client_email}"
name: "${form.client_name}"
position: "${form.client_company}"
employee_type: "external"
approval_type: "needs_to_sign"
on_approve:
continue_to: "completion"Signature Display Format:
Before signing:
Signed by ________________
Jane Smith
Vendor Representative • ExternalAfter signing:
Signed by [Signature Image/Text]
Jane Smith
Vendor Representative • External
Signed on: March 8, 2026, 10:30 AMUse Cases:
- Vendor sign-offs on purchase orders
- Client acknowledgements on contracts
- Contractor certifications
- Partner approvals
- Third-party validations
Signature Field Mapping
Link the captured signature to a specific form field using signature_field:
form:
fields:
- name: authorized_signature
type: signature
label: "Authorized Signature"
required: true
workflow:
finance_approval:
type: decision
approver: finance_manager
approval_type: needs_to_sign
signature_field: authorized_signature # Maps signature to this form field
on_approve:
continue_to: approved_endHow it works:
- When the approver signs, their signature automatically populates the specified form field
- The form field must be of type
signature - The signature is stored both in the approval step and in the form data
- Useful for contracts requiring multiple specific signatures in designated locations
Example with multiple signature fields:
form:
fields:
- name: manager_signature
type: signature
label: "Manager Signature"
- name: director_signature
type: signature
label: "Director Signature"
- name: legal_signature
type: signature
label: "Legal Department Signature"
workflow:
manager_review:
approver: department_manager
approval_type: needs_to_sign
signature_field: manager_signature # Populates manager_signature field
on_approve:
continue_to: director_review
director_review:
approver: director
approval_type: needs_to_sign
signature_field: director_signature # Populates director_signature field
on_approve:
continue_to: legal_review
legal_review:
approver: legal_team
approval_type: needs_to_sign
signature_field: legal_signature # Populates legal_signature field
on_approve:
end_workflow: true3. needs_to_recommend
Recipients with this role type... can do the following:
- Recommend will move the workflow to the next recipient (if any)
- Not Recommend will also move the workflow to the next recipient (if any)
- Request More Information will send the workflow back to the requestor for re-submission
Note: This role is designed specifically for recipients that do not have authority to decline a request. If you want the recipient to be able to decline the request back to the requestor, use the needs_to_approve role instead.
YAML Example:
finance_review:
name: "finance_review"
type: "decision"
approvers:
- role: "finance_manager"
approval_type: "needs_to_recommend"
- role: "budget_analyst"
approval_type: "needs_to_recommend"
# Important: define both paths to keep flow moving
on_approve:
continue_to: "next_step"
on_reject: # when they choose Not Recommend
continue_to: "next_step" # Still proceeds4. needs_to_acknowledge
Recipients with this role type... can do the following:
- Acknowledge will move the workflow to the next recipient (if any)
- Request More Information will send the workflow back to the requestor for re-submission
YAML Example:
policy_acknowledgment:
name: "policy_acknowledgment"
type: "decision"
approver: "${requestor.supervisor}"
approval_type: "needs_to_acknowledge"
on_approve:
continue_to: "next_step"
on_reject:
end_workflow: true5. needs_to_call_action
Recipients with this role type... can do the following:
- Complete Action will execute the action and move to the next workflow node
- Fail Action will go back to the previous node
- Request More Information will send the workflow back to the requestor for re-submission
Note: This can be an API call or manual task. If it's a manual task, the action creates the task, and once the task is completed, it proceeds. If it's an API call, on success it moves to the next workflow node, if it fails, it goes back to the previous node.
YAML Example:
it_action:
name: "it_action"
type: "decision"
approver: "it_team"
approval_type: "needs_to_call_action"
on_approve:
continue_to: "next_step"
on_reject:
continue_to: "next_step" # Action completed6. receives_a_copy
Recipients with this role type... receive a copy of the request only. No action is required.
YAML Example:
stakeholder_notification:
name: "stakeholder_notification"
type: "decision"
approvers:
- role: "requestor"
approval_type: "receives_a_copy"
- role: "department_head"
approval_type: "receives_a_copy"
on_complete:
continue_to: "next_step"Non-blocking Steps
notification Step Type
This step type automatically completes without requiring any action:
notify_supervisor:
name: "notify_supervisor"
type: "notification"
description: "Supervisor receives notification of request"
recipients:
- email: "${requestor.supervisor_email}"
notification:
message:
subject: "Request Submitted"
body: "A new request has been submitted by your team member."
on_complete:
continue_to: "next_step"receives_a_copy Approval Type
This approval type automatically completes without requiring any action:
stakeholder_copy:
name: "stakeholder_copy"
type: "decision"
approver: "stakeholders"
approval_type: "receives_a_copy"
on_complete:
continue_to: "next_step"Best Practices
- Use
notificationfor pure FYI notifications that shouldn't block the workflow - Use
receives_a_copywhen you want to send copies but still have a step in the workflow - Use
needs_to_recommendfor advisory roles that shouldn't have veto power - Use
needs_to_signfor legal or compliance requirements - Use
needs_to_call_actionfor steps that require system integration or manual task completion - Use
needs_to_acknowledgewhen you need confirmation but don't need full approval
Example Workflow with Mixed Types
workflow:
# Non-blocking notification
notify_supervisor:
type: "notification"
recipients:
- email: "${requestor.supervisor_email}"
notification:
message:
subject: "Request Submitted"
body: "A new request has been submitted."
on_complete:
continue_to: "manager_approval"
# Standard approval
manager_approval:
type: "decision"
approver: "${requestor.manager}"
approval_type: "needs_to_approve"
on_approve:
continue_to: "finance_review"
on_reject:
end_workflow: true
# Advisory review
finance_review:
type: "decision"
approver: "finance_team"
approval_type: "needs_to_recommend"
on_approve:
continue_to: "legal_signature"
on_reject:
continue_to: "legal_signature" # Proceeds regardless
# Legal signature
legal_signature:
type: "decision"
approver: "legal_team"
approval_type: "needs_to_sign"
on_approve:
continue_to: "completion"
on_reject:
end_workflow: true
# Copy to stakeholders
completion:
type: "decision"
approvers:
- role: "requestor"
approval_type: "receives_a_copy"
- role: "department_head"
approval_type: "receives_a_copy"
on_complete:
end_workflow: true