Security Identity Definition Examples
Security Identity Definition Examples
The permission model of a secured item typically refers to existing security identities, which the Push API allows you to define and manage in a security identity provider.
A security identity definition must minimally contain the name of the defined security identity itself, as well as its entity type (that is, User
, Group
, VirtualGroup
, or Unknown
). Additionally, it may contain:
-
The name and entity type of each of its members, if the defined security identity is a group or virtual group.
-
The name and entity type (normally,
Group
orVirtualGroup
) of each of its granted identities.Granted identities used to be called well known groups.
For backwards compatibility reasons, the Push API still requires you to specify the granted identities of a security identity in an array property whose name is
wellKnowns
.
See Security Identity Models - IdentityBody.
The following security identity definition examples rely on one another and are increasingly complex.
Defining a Basic Group
A group typically has an array of Members
, unless this group is intended to be used as a granted identity (see Defining a Granted Identity).
{
"identity": {
"name": "SampleTeam1",
"type": "Group"
},
"members": [
{
"name": "asmith@example.com",
"type": "User"
},
{
"name": "bjones@example.com",
"type": "User"
}
]
}
In this example, the asmith@example.com
and bjones@example.com
users are explicitly included as members of the SampleTeam1
group.
You would typically create aliases on those members to map them to their respective corresponding identities in other security identity providers (see About the Email Security Provider and User Alias Definition Examples).
When pushing a group security identity, you overwrite the current version of that same group. Therefore, if you want to keep existing group members, be sure to include them in the new group configuration. If this isn’t viable, consider using granted identities instead.
Defining a Granted Identity
A granted identity is initially defined as a group or virtual group that doesn’t have an array of Members
.
{
"identity": {
"name": "Everyone",
"type": "Group"
}
}
While uncommon, it’s possible for a granted identity to have its own array of wellKnowns
.
In this example, the Everyone
group doesn’t have any members. Actually, those members will be included “the other way around” (see Defining a User with Granted Identities).
Defining a User with Granted Identities
A granted identity is essentially a group whose members are included “the other way around”.
Whenever you define a security identity, it automatically becomes a member of all granted identities included in its array of wellKnowns
.
In the following example, suppose that the Domain Users
group was previously defined exactly as the Everyone
group was (see Defining a Granted Identity).
{
"identity": {
"name": "cbrown@example.com",
"type": "User"
},
"wellKnowns": [
{
"name": "Domain Users",
"type": "Group"
},
{
"name": "Everyone",
"type": "Group"
}
]
}
In this example, the cbrown@example.com
user automatically becomes a member of the Domain Users
and Everyone
groups.
A user entity can also be defined with one or several aliases (see User Alias Definition Examples).
Example Cases of When to Use Granted Identities
It’s not always necessary to use granted identities in Coveo implementations. They should be considered when they can serve as a simplifying measure. Below are some example cases.
- A group named
Everyone
is attributed to all users by default. This group is meant to denote membership to a given organization. Every time a new member joins the organization, they must be added to the group, and inversely when a member leaves. This requires a lot of group management and can quickly lead to human errors. To prevent this scenario, the granted identityEveryone
can be systematically used when declaring new users:
{
"identity": {
"name": "newuser@example.com",
"type": "User"
},
"wellKnowns": [
{
"name": "Everyone",
"type": "Group"
}
]
}
- In a case where group membership eligibility can be determined based on a set of automated rules, it can be wise to link users to groups on user creation. Conversely, if the rule was applied on group creation, the system would need to iterate over every existing member to determine which ones qualify for group membership, for every group. A better design is to run the group membership rules on user creation and to use granted identities:
{
"identity": {
"name": "newuser@example.com",
"type": "User"
},
"wellKnowns": [
{
"name": "Everyone",
"type": "Group"
},
{
"name": "Security_Team",
"type": "Group"
},
{
"name": "Developer",
"type": "Group"
},
...
]
}
Defining a Group with Many Member Types
A group can have many security identity types in its array of Members.
{
"identity": {
"name": "SampleTeam2",
"type": "Group"
},
"members": [
{
"name": "Domain Users",
"type": "Group"
},
{
"name": "dmoore@example.com",
"type": "User"
}
]
}
In this example, since the Domain Users
group is included as a member of the SampleTeam2
group, all users who have the Domain Users
granted identity also become members of the SampleTeam2
group.
Consequently, the cbrown@example.com
user becomes a member of the SampleTeam2
group (see Defining a User with Granted Identities).
You would typically create an alias on dmoore@example.com
to map that identity to corresponding identities in other security identity providers (see About the Email Security Provider and User Alias Definition Examples).
When pushing a group security identity, you overwrite the current version of that same group. Therefore, if you want to keep existing group members, be sure to include them in the new group configuration. If this isn’t viable, consider using granted identities instead.
Defining a Group with Granted Identities
A group can have granted identities. Any security identity that’s a member of that group receives these granted identities.
In the following example, suppose that the Superuser
group was previously defined exactly as the Everyone
group was (see Defining a Granted Identity).
{
"identity": {
"name": "SampleGroup",
"type": "VirtualGroup"
},
"members": [
{
"name": "SampleTeam1",
"type": "Group"
},
{
"name": "SampleTeam2",
"type": "Group"
}
],
"wellKnowns": [
{
"name": "Superuser",
"type": "Group"
}
]
}
In this example, the SampleGroup
security identity is defined as a virtual group.
The only difference between a group and a virtual group is semantics: a virtual group doesn’t exist in the indexed enterprise system, whereas a group does.
In this example, the SampleGroup
virtual group ultimately resolves to the following individual user entities:
-
asmith@example.com
andbjones@example.com
Those two users are explicitly listed as members of theSampleTeam1
group (see Defining a Basic Group). -
cbrown@example.com
This user is defined as having theEveryone
granted identity (see Defining a User with Granted Identities), and all members of theEveryone
group are included as members of theSampleTeam2
group (see Defining a Group with Many Member Types). -
dmoore@example.com
This user is explicitly listed as member of theSampleTeam2
group (see Defining a Group with Many Member Types).
Each of those users automatically becomes a member of the Superuser
group.
How Security Identities and Permission Models Interact
Once all security identities in the security identity provider have been properly resolved to individual user entities, the index can evaluate the effective permissions of each item in the secured Push source (see Defining a Permission Model - Effective Permission Evaluation With Many Permission Sets).
Suppose that an item in a secured Push source has the following permission model (see Simple Permission Model Definition Examples):
[
{
"allowAnonymous": false,
"allowedPermissions": [
{
"identity": "Superusers",
"identityType": "Group"
}
],
"deniedPermissions": [
{
"identity": "MysteryUserX",
"identityType": "User"
}
]
}
]
Moreover, suppose that the MysteryUserX
alias has been defined as follows in the same security identity provider (see User Alias Definition Examples):
{
"identity": {
"name": "MysteryUserX",
"type": "User"
},
"mappings": [
{
"name": "asmith@example.com",
"type": "User",
"provider": "Email Security Provider"
}
]
}
In this example:
- The
Superusers
group resolves to theasmith@example.com
,bjones@example.com
,cbrown@example.com
, anddmoore@example.com
users (see Defining a Group with Many Member Types). - The
MysteryUserX
alias resolves to theasmith@example.com
user entity. - As a result, once effective permission have been evaluated, the
asmith@example.com
user is denied access to the item, and only thebjones@example.com
,cbrown@example.com
, anddmoore@example.com
users can see the item in their query results.