Access control model

The following model describes the schema objects related to the user RBAC access control system in OpenIAM.

Note: You should not develop processes that write directly to the schema. The schema will evolve with each release and you should use the OpenIAM API to shield your processes from these schema changes.

User data model

Table: GRP

Column NameData TypeDescription
GRP_IDVARCHAR(32)Unique identifier for the group.
GRP_NAMEVARCHAR(255)Name of the group.
CREATE_DATEDATETIMETimestamp when the group was created.
CREATED_BYVARCHAR(32)User ID of the person who created the group.
GROUP_DESCVARCHAR(512)Description of the group.
STATUSVARCHAR(20)Current status of the group (e.g., Active, Inactive).
LAST_UPDATEDATETIMETimestamp of the last update.
LAST_UPDATED_BYVARCHAR(32)User ID of the last person who updated the group.
MANAGED_SYS_IDVARCHAR(32)Foreign key referencing MANAGED_SYS.MANAGED_SYS_ID, indicating the managed system.
TYPE_IDVARCHAR(32)Foreign key referencing METADATA_TYPE.TYPE_ID, defining the group type.
GRP_CLASSIFICATIONVARCHAR(32)Foreign key referencing METADATA_TYPE.TYPE_ID, classifying the group.
AD_GRP_TYPEVARCHAR(32)Foreign key referencing METADATA_TYPE.TYPE_ID, defining the Active Directory group type.
AD_GRP_SCOPEVARCHAR(32)Foreign key referencing METADATA_TYPE.TYPE_ID, defining the Active Directory group scope.
GRP_RISKVARCHAR(32)Foreign key referencing METADATA_TYPE.TYPE_ID, indicating the risk level of the group.
MAX_USER_NUMBERINT(11)Maximum number of users allowed in the group.
MEMBERSHIP_DURATION_SECONDSBIGINT(20)Duration of membership in the group (in seconds).
POLICY_IDVARCHAR(32)Foreign key referencing POLICY.POLICY_ID, defining the policy linked to the group.
ASSIGN_TO_ALLCHAR(1)Indicates if the group is assigned to all users (Y or N).
IS_VISIBLECHAR(1)Indicates if the group is visible (Y or N).
PARTICIPANT_CERTIFICATIONCHAR(1)Indicates if the group requires participant certification (Y or N).
GRAPH_IDVARCHAR(100)Identifier used for graphical representation of relationships.

Table: GRP_ATTRIBUTES

Column NameData TypeDescription
IDVARCHAR(32)Unique identifier for the group attribute.
GRP_IDVARCHAR(32)Foreign key referencing GRP.GRP_ID, identifying the associated group.
METADATA_IDVARCHAR(32)Foreign key referencing METADATA_ELEMENT.METADATA_ID, defining the attribute type.
NAMEVARCHAR(100)Name of the attribute (e.g., Department, Cost Center).

Table: GRP_GRP_MEMBERSHIP_RIGHTS

Column NameData TypeDescription
MEMBERSHIP_IDVARCHAR(32)Foreign key referencing grp_to_grp_membership.MEMBERSHIP_ID, identifying the group membership.
ACCESS_RIGHT_IDVARCHAR(32)Foreign key referencing ACCESS_RIGHTS.ACCESS_RIGHT_ID, defining specific access rights granted.
EDGE_IDVARCHAR(40)Identifier used for graphical representation of relationships.

Table: GRP_ROLE

Column NameData TypeDescription
GRP_IDVARCHAR(32)Foreign key referencing GRP.GRP_ID, identifying the group.
ROLE_IDVARCHAR(32)Foreign key referencing ROLE.ROLE_ID, identifying the assigned role.
MEMBERSHIP_IDVARCHAR(32)Unique identifier for the group's role membership.
START_DATEDATETIMEStart date of the group's role assignment.
END_DATEDATETIMEEnd date of the group's role assignment.
DESCRIPTIONVARCHAR(255)Additional details about the role assignment.
EDGE_IDVARCHAR(40)Identifier used for graphical representation of relationships.

Table: GRP_ROLE_MEMBERSHIP_RIGHTS

Column NameData TypeDescription
MEMBERSHIP_IDVARCHAR(32)Foreign key referencing GRP_ROLE.MEMBERSHIP_ID, linking the rights to a group role membership.
ACCESS_RIGHT_IDVARCHAR(32)Foreign key referencing ACCESS_RIGHTS.ACCESS_RIGHT_ID, defining specific access rights granted.
EDGE_IDVARCHAR(40)Identifier used for graphical representation of relationships.

Table: METADATA_TYPE

Column NameData TypeDescription
TYPE_IDVARCHAR(32)Unique identifier for the metadata type.
NAMEVARCHAR(100)Name of the metadata type.
ACTIVECHAR(1)Indicates if the metadata type is active (Y or N).
SYNC_MANAGED_SYSCHAR(1)Indicates if the metadata should be synchronized with managed systems (Y or N).
GROUPINGVARCHAR(100)Grouping classification for the metadata type.
IS_BINARYCHAR(1)Indicates if the metadata type is binary (Y or N).
IS_SENSITIVECHAR(1)Indicates if the metadata type contains sensitive information (Y or N).
USED_FOR_SMS_OTPCHAR(1)Indicates if the metadata is used for SMS OTP authentication (Y or N).
CREATEABLECHAR(1)Indicates if this metadata type can be created dynamically (Y or N).

Table: METADATA_ELEMENT

Column NameData TypeDescription
METADATA_IDVARCHAR(32)Unique identifier for the metadata element.
TYPE_IDVARCHAR(32)Foreign key referencing METADATA_TYPE.TYPE_ID, linking the element to a metadata type.
ATTRIBUTE_NAMEVARCHAR(100)Name of the attribute represented by this metadata element.
NAMEVARCHAR(100)Display name for the metadata element.
DATA_TYPEVARCHAR(20)Data type of the metadata element (e.g., String, Integer).
AUDITABLECHAR(1)Indicates if changes to this metadata element should be audited (Y or N).
REQUIREDCHAR(1)Indicates if the metadata element is required (Y or N).
SELF_EDITABLECHAR(1)Indicates if users can edit this metadata element themselves (Y or N).
TEMPLATE_IDVARCHAR(32)Foreign key referencing METADATA_ELEMENT_PAGE_TEMPLATE.ID, linking to a page template.
RESOURCE_IDVARCHAR(32)Foreign key referencing RES.RESOURCE_ID, associating the element with a resource.
VALIDATORVARCHAR(150)Validation rule applied to the metadata element.
STATIC_DEFAULT_VALUEVARCHAR(4000)Default value assigned to this metadata element.
IS_PUBLICCHAR(1)Indicates if this metadata element is publicly visible (Y or N).
DATA_MODEL_URLVARCHAR(255)URL for additional data modeling information.
METADATA_TYPEVARCHAR(4000)Extended metadata type information.
PLACEHOLDERVARCHAR(255)Placeholder text for input fields related to this metadata element.

Table: ROLE

Column NameData TypeDescription
ROLE_NAMEVARCHAR(80)Unique name of the role.
CREATE_DATEDATETIMETimestamp when the role was created.
CREATED_BYVARCHAR(32)User ID of the person who created the role.
DESCRIPTIONVARCHAR(3072)Description of the role.
STATUSVARCHAR(20)Status of the role (e.g., Active, Inactive).
ROLE_IDVARCHAR(32)Unique identifier for the role.
MANAGED_SYS_IDVARCHAR(32)Foreign key referencing MANAGED_SYS.MANAGED_SYS_ID, linking the role to a managed system.
TYPE_IDVARCHAR(32)Foreign key referencing METADATA_TYPE.TYPE_ID, defining the role type.
POLICY_IDVARCHAR(32)Foreign key referencing POLICY.POLICY_ID, linking the role to a policy.
RISKVARCHAR(32)Foreign key referencing METADATA_TYPE.TYPE_ID, defining the risk level of the role.
MEMBERSHIP_DURATION_SECONDSBIGINT(20)Duration of role membership in seconds.
MAX_USER_NUMBERINT(11)Maximum number of users that can be assigned to this role.
ASSIGN_TO_ALLCHAR(1)Indicates if this role is assigned to all users (Y or N).
IS_VISIBLECHAR(1)Indicates if this role is visible in UI (Y or N).
PARTICIPANT_CERTIFICATIONCHAR(1)Indicates if role membership requires certification (Y or N).
GRAPH_IDVARCHAR(100)Identifier used for graphical representation of role relationships.
EXCLUDE_FROM_AUTHCHAR(1)Indicates if this role is excluded from authentication (Y or N).

Table: ROLE_ATTRIBUTE

Column NameData TypeDescription
ROLE_ATTR_IDVARCHAR(32)Unique identifier for the role attribute.
NAMEVARCHAR(100)Name of the role attribute.
METADATA_IDVARCHAR(32)Foreign key referencing METADATA_ELEMENT.METADATA_ID, defining metadata properties.
ROLE_IDVARCHAR(32)Foreign key referencing ROLE.ROLE_ID, linking the attribute to a role.

Table: ROLE_ATTRIBUTE_VALUES

Column NameData TypeDescription
ROLE_ATTRIBUTE_IDVARCHAR(32)Foreign key referencing ROLE_ATTRIBUTE.ROLE_ATTR_ID, linking the value to an attribute.
ATTR_VALUETEXTValue assigned to the role attribute.

Table: ROLE_ORG_MEMBERSHIP

Column NameData TypeDescription
MEMBERSHIP_IDVARCHAR(32)Unique identifier for the role-organization membership.
ROLE_IDVARCHAR(32)Foreign key referencing ROLE.ROLE_ID, identifying the associated role.
COMPANY_IDVARCHAR(32)Foreign key referencing COMPANY.COMPANY_ID, identifying the associated company.
START_DATEDATETIMEStart date of the role assignment within the organization.
END_DATEDATETIMEEnd date of the role assignment within the organization.
DESCRIPTIONVARCHAR(255)Additional details about the role assignment.
EDGE_IDVARCHAR(40)Identifier used for graphical representation of role relationships.

Table: ROLE_ORG_MEMBERSHIP_RIGHTS

Column NameData TypeDescription
MEMBERSHIP_IDVARCHAR(32)Foreign key referencing ROLE_ORG_MEMBERSHIP.MEMBERSHIP_ID, linking the rights to a role-organization membership.
ACCESS_RIGHT_IDVARCHAR(32)Foreign key referencing ACCESS_RIGHTS.ACCESS_RIGHT_ID, defining specific access rights granted.
EDGE_IDVARCHAR(40)Identifier used for graphical representation of relationships.

Table: ROLE_ROLE_MEMBERSHIP_RIGHTS

Column NameData TypeDescription
MEMBERSHIP_IDVARCHAR(32)Foreign key referencing ROLE_TO_ROLE_MEMBERSHIP.MEMBERSHIP_ID, linking the rights to a role-role membership.
ACCESS_RIGHT_IDVARCHAR(32)Foreign key referencing ACCESS_RIGHTS.ACCESS_RIGHT_ID, defining specific access rights granted.
EDGE_IDVARCHAR(40)Identifier used for graphical representation of relationships.

Table: RES (Resource)

Column NameData TypeDescription
RESOURCE_IDVARCHAR(32)Unique identifier for the resource.
RESOURCE_TYPE_IDVARCHAR(32)Foreign key referencing RESOURCE_TYPE.RESOURCE_TYPE_ID, defining the type of resource.
DESCRIPTIONVARCHAR(512)Description of the resource.
NAMEVARCHAR(255)Name of the resource.
DISPLAY_ORDERINT(11)Order in which the resource appears in lists.
URLVARCHAR(255)URL associated with the resource.
MIN_AUTH_LEVELVARCHAR(32)Minimum authentication level required for access.
IS_PUBLICCHAR(1)Indicates if the resource is public (Y or N).
RISKVARCHAR(10)Risk level associated with the resource.
TYPE_IDVARCHAR(32)Foreign key referencing METADATA_TYPE.TYPE_ID, defining additional classification.
COORELATED_NAMEVARCHAR(250)Alternate name for correlation.
REFERENCE_IDVARCHAR(32)Reference identifier.
GROOVY_SCRIPTVARCHAR(255)Groovy script reference for resource behavior.
STATUSVARCHAR(20)Status of the resource (ACTIVE, INACTIVE).
IS_VISIBLECHAR(1)Indicates if the resource is visible (Y or N).
PARTICIPANT_CERTIFICATIONCHAR(1)Indicates if certification is required (Y or N).
DAYS_TO_COMPLETE_REQUESTINT(11)Number of days allowed to complete the resource request.
GRAPH_IDVARCHAR(100)Identifier for graphical representation of relationships.

Table: RESOURCE_GROUP

Column NameData TypeDescription
RESOURCE_IDVARCHAR(32)Foreign key referencing RES.RESOURCE_ID, identifying the associated resource.
GRP_IDVARCHAR(32)Foreign key referencing GRP.GRP_ID, identifying the associated group.
START_DATEDATETIMEStart date of the resource-group association.
MEMBERSHIP_IDVARCHAR(32)Unique identifier for the resource-group membership.
END_DATEDATETIMEEnd date of the resource-group association.
DESCRIPTIONVARCHAR(255)Additional details about the resource-group relationship.
EDGE_IDVARCHAR(40)Identifier used for graphical representation.

Table: RESOURCE_PROP (Resource Properties)

Column NameData TypeDescription
RESOURCE_PROP_IDVARCHAR(32)Unique identifier for the resource property.
RESOURCE_IDVARCHAR(32)Foreign key referencing RES.RESOURCE_ID, linking the property to a resource.
METADATA_IDVARCHAR(32)Foreign key referencing METADATA_ELEMENT.METADATA_ID, defining metadata properties.
NAMEVARCHAR(100)Name of the resource property.
PROP_GROUPVARCHAR(20)Property group classification.

Table: RESOURCE_ROLE

Column NameData TypeDescription
RESOURCE_IDVARCHAR(32)Foreign key referencing RES.RESOURCE_ID, identifying the associated resource.
START_DATEDATETIMEStart date of the resource-role association.
ROLE_IDVARCHAR(32)Foreign key referencing ROLE.ROLE_ID, identifying the assigned role.
MEMBERSHIP_IDVARCHAR(32)Unique identifier for the resource-role membership.
END_DATEDATETIMEEnd date of the resource-role association.
DESCRIPTIONVARCHAR(255)Additional details about the resource-role assignment.
EDGE_IDVARCHAR(40)Identifier used for graphical representation.

Table: RESOURCE_TYPE

Column NameData TypeDescription
RESOURCE_TYPE_IDVARCHAR(32)Unique identifier for the resource type.
DESCRIPTIONVARCHAR(100)Description of the resource type.
PROCESS_NAMEVARCHAR(80)Name of the process linked to this resource type.
SUPPORTS_HIERARCHYCHAR(1)Indicates if hierarchy is supported (Y or N).
SEARCHABLECHAR(1)Indicates if the resource type is searchable (Y or N).
URLMEDIUMTEXTURL associated with the resource type.
IMAGE_TYPEVARCHAR(16)Image type linked to the resource type.
PROVISION_RESOURCECHAR(1)Indicates if the resource type supports provisioning (Y or N).

Table: RES_ATTRIBUTE_VALUES

Column NameData TypeDescription
RESOURCE_PROP_IDVARCHAR(32)Foreign key referencing RESOURCE_PROP.RESOURCE_PROP_ID, linking the value to a property.
ATTR_VALUETEXTValue assigned to the resource property.

Table: RES_GRP_MEMBERSHIP_RIGHTS

Column NameData TypeDescription
MEMBERSHIP_IDVARCHAR(32)Foreign key referencing RESOURCE_GROUP.MEMBERSHIP_ID, linking the rights to a resource-group membership.
ACCESS_RIGHT_IDVARCHAR(32)Foreign key referencing ACCESS_RIGHTS.ACCESS_RIGHT_ID, defining specific access rights granted.
EDGE_IDVARCHAR(40)Identifier used for graphical representation of relationships.

Table: RES_ORG_MEMBERSHIP

Column NameData TypeDescription
MEMBERSHIP_IDVARCHAR(32)Unique identifier for the resource-organization membership.
RESOURCE_IDVARCHAR(32)Foreign key referencing RES.RESOURCE_ID, identifying the associated resource.
COMPANY_IDVARCHAR(32)Foreign key referencing COMPANY.COMPANY_ID, identifying the associated company.
START_DATEDATETIMEStart date of the resource-organization membership.
END_DATEDATETIMEEnd date of the resource-organization membership.
DESCRIPTIONVARCHAR(255)Additional details about the resource-organization relationship.
EDGE_IDVARCHAR(40)Identifier used for graphical representation of relationships.

Table: RES_ORG_MEMBERSHIP_RIGHTS

Column NameData TypeDescription
MEMBERSHIP_IDVARCHAR(32)Foreign key referencing RES_ORG_MEMBERSHIP.MEMBERSHIP_ID, linking the rights to a resource-organization membership.
ACCESS_RIGHT_IDVARCHAR(32)Foreign key referencing ACCESS_RIGHTS.ACCESS_RIGHT_ID, defining specific access rights granted.
EDGE_IDVARCHAR(40)Identifier used for graphical representation of relationships.

Table: RES_RES_MEMBERSHIP_RIGHTS

Column NameData TypeDescription
MEMBERSHIP_IDVARCHAR(32)Foreign key referencing RES_TO_RES_MEMBERSHIP.MEMBERSHIP_ID, linking the rights to a resource-to-resource membership.
ACCESS_RIGHT_IDVARCHAR(32)Foreign key referencing ACCESS_RIGHTS.ACCESS_RIGHT_ID, defining specific access rights granted.
EDGE_IDVARCHAR(40)Identifier used for graphical representation of relationships.

Table: RES_ROLE_MEMBERSHIP_RIGHTS

Column NameData TypeDescription
MEMBERSHIP_IDVARCHAR(32)Foreign key referencing RESOURCE_ROLE.MEMBERSHIP_ID, linking the rights to a resource-role membership.
ACCESS_RIGHT_IDVARCHAR(32)Foreign key referencing ACCESS_RIGHTS.ACCESS_RIGHT_ID, defining specific access rights granted.
EDGE_IDVARCHAR(40)Identifier used for graphical representation of relationships.