Configuring approval workflows

This guide explains how to create approval workflows (also known as Approver Associations) for roles, groups, and resources in OpenIAM.

Defining an Approval workflow

OpenIAM allows you to define approval workflows at two levels:

  1. Application Level (Managed System or Manual Managed System).
  2. Entitlement Level (Roles, Groups, or Resources).

For applications with a large number of entitlements, defining the approval flow at the application level is recommended. However, you can override this at the entitlement level if necessary.

To define approvers, follow the steps below.

  1. Locate the Application or Entitlement

For Applications

  1. Go to WebConsole > Access Control > Resource.
  2. Filter by Managed System or Manual Managed System in the Type column.
  3. Find your application by searching in the Name column.
  4. Click the Actions button to view the application details.

For Entitlements

  1. Enable Entitlement-Level Approvals.

    • Go to WebConsole > Administration > System Configuration.
    • Navigate to the Workflow tab.
    • Enable the Use approver association or role/group instead of resource checkbox.
  2. Find the Entitlement.

    • Determine the entitlement type (Role, Resource, or Group).
    • Go to WebConsole > Access Control > [Entitlement Type].
    • Filter by Managed System name in the Managed System column.
    • (Optional) Further filter by Metadata Type.
    • Find your entitlement by searching in the Name column.
    • Click the Actions button to view entitlement details.
  3. Define the Approval flow

    • Click on Approval Associations from the sidebar.
    • Click the + button to add an approver.

Add Approver

  1. Configure the Approval flow Fill in the following fields:
  • Approver: Select the approver type and name.
  • Notify on Approval: Choose who will be notified if this step is approved.
  • Notify on Reject: Choose who will be notified if this step is rejected.
  • Request Service Level Agreement (SLA) Parameters:
    • Number of Reminders: How many reminders to send.
    • Days Before Sending Reminder: When to send the first reminder.
    • Total Time to Complete (Calculated Value).
Important: Each row must be saved before saving the entire page.

Approval Flow

Approval flow field descriptions

FieldDescription
Is MandatoryIf enabled, the step must be completed. If no approver is set, the request is sent to a default approver.
Approver TypeDefines who will approve or reject access. (See Approver Types section below.)
ApproverAuto-filled based on the selected approver type.
Notify on Approve TypeSpecifies who receives an additional notification when this step is approved.
Notify on ApprovalAuto-filled based on the previous field.
Notify on Reject TypeSpecifies who receives an additional notification when this step is rejected.
Notify on RejectionAuto-filled based on the previous field.
Number of RemindersHow many reminders are sent to the approver.
Days Before Sending ReminderWhen to send the first reminder.
Days to EscalationThe total time allowed before escalation.

Adding additional approval steps

To add another step:

  1. Save the first approver.
  2. Click the + button again.
  3. Repeat the configuration process.

Approver Types

Approver TypeDescription
SupervisorThe direct manager of the user making the request.
Note: If the manager initiates the request, this step is skipped.
UserA specific individual assigned as the approver.
GroupA group of users who can approve (anyone in the group can claim and approve the request).
RoleAny user with a specific role can approve.
OwnerThe owner assigned to the Managed System or Manual Managed System.
AdminThe administrator assigned to the Managed System or Manual Managed System.

Escalations

If a request is not approved or rejected within the defined timeframe, it can either:

  • Be automatically rejected by the system.
  • Be escalated to a higher-level approver.

To configure escalations:

  1. Open the Approver Association screen.
  2. Click the blue escalation button.

Escalation Button

  1. In the Escalation List window:
    • Select the user or group to escalate to.
    • Click Add.
    • Configure reminder frequency and days before escalation.

Escalation List

If the initial approver does not take action, the request is escalated based on these settings. If it remains unapproved past the expiration date, it is automatically rejected.

Enabling escalation processing

Escalations are managed by a batch task. To enable it:

  1. Go to WebConsole > Administration > Batch Tasks.
  2. Find Escalation of Expired Requests.
  3. Click Edit and enable the Is Enabled flag.

Notifications

Approvers can receive notifications about pending requests. However, for notifications to be sent, the corresponding batch task must be enabled.

Enabling approval notifications

  1. Go to WebConsole > Administration > Batch Tasks.
  2. Find Notification Reminders for Approvers.
  3. Click Edit and enable the Is Enabled flag.

This batch task handles reminder notifications. Standard email notifications are sent by default.


Email notifications

Standard email templates are used to notify users about request statuses.

Template NameDescription
CREATE_USER_REQUESTNotifies the approver of a pending request.
ACCESS_REQUESTED_ON_BEHALFNotifies the user that access has been requested on their behalf.
CREATE_USER_REQUEST_REJECTEDNotifies the user that their request was rejected.
CREATE_USER_REQUEST_ACCEPTEDNotifies the user that their request was approved.
CREATE_USER_REQUEST_STEP_APPROVEDNotifies the user that a preliminary approval step was completed.

Example email notifications

Request created on behalf of a user

Request on Behalf

Pending request for approval

Pending Approval

Request approved

Request Approved

Preliminary approval notification

Preliminary Approval