SCIM Groups API
- List groups
- Get a single group
- Create a group
- Update a group
- Delete a group
- List response fields
- Fields
List group
GET /scim/v2/Groups
Response
status: 200 OK
{
"schemas": [
"urn:ietf:params:scim:api:messages:2.0:ListResponse"
],
"totalResults": 1,
"itemsPerPage": 25,
"startIndex": 1,
"Resources": [
{
"schemas": [
"urn:ietf:params:scim:schemas:core:2.0:Group"
],
"id": "1",
"externalId": "G1",
"displayName": "Widget Data Center",
"groupType": "Organization",
"meta": {
"resourceType": "Group",
"created": "2018-04-17T11:05:29-05:00",
"lastModified": "2018-04-17T11:05:29-05:00",
"location": "https://<account>.xurrent.com/scim/v2/Groups/1"
}
}
]
}
The response contains these fields.
Pagination
The SCIM Groups API supports filtering as defined in RFC 7644 - Pagination
- startIndex
- [integer], default:
1
— The 1-based index of the first query result. - count
- [integer], default:
25
— Non-negative integer between 1 and 25 indicating the desired maximum number of results per page, e.g., 10.
Examples:
GET /scim/v2/Groups?startIndex=10&count=10
Filtering
The SCIM Groups API partially supports filtering as defined in RFC 7644 - Filtering
- Filtering is available for the following attributes:
-
displayName
externalId
meta.lastModified
meta.created
- The following operators are available:
-
eq
Equal tone
Not equal tolt
Less thangt
Greater than
The logical operators and
and or
are also supported.
Examples:
GET /scim/v2/Groups?filter=displayName eq "Skimming Corp"
GET /scim/v2/Groups?filter=displayName ne "Skimming Corp"
GET /scim/v2/Groups?filter=externalId eq "SCIM1"
GET /scim/v2/Groups?filter=meta.lastModified lt "2018-04-19T13:47:13Z"
GET /scim/v2/Groups?filter=meta.created gt "2018-04-19T13:47:13Z"
GET /scim/v2/Groups?filter=meta.lastModified gt "2018-04-19T13:47:13Z" and displayName eq "Skimming Corp"
GET /scim/v2/Groups?filter=displayName eq "Skimming Corp" or displayName eq "Skim Holland"
Get a single group
GET /scim/v2/Groups/:id
Response
status: 200 OK
{
"schemas": [
"urn:ietf:params:scim:schemas:core:2.0:Group"
],
"id": "1",
"externalId": "G1",
"displayName": "Widget Data Center",
"groupType": "Organization",
"members": [
{
"display": "card.skimmer@scim.com",
"value": "1",
"$ref": "https://<account>.xurrent.com/scim/v2/Users/1"
},
{
"display": "jane.doe@scim.com",
"value": "2",
"$ref": "https://<account>.xurrent.com/scim/v2/Users/2"
}
],
"meta": {
"resourceType": "Group",
"created": "2018-04-17T11:05:29-05:00",
"lastModified": "2018-04-17T11:05:29-05:00",
"location": "https://<account>.xurrent.com/scim/v2/Groups/1"
}
}
The response contains these fields.
Create a group
POST /scim/v2/Groups
When creating a new group these fields are available.
Response
status: 201 Created
{
"schemas": [
"urn:ietf:params:scim:schemas:core:2.0:Group"
],
"id": "5",
"...": "..."
}
The response contains all fields of the created group and is similar to the response in Get a single group
Update a group
When using PUT
the members
will be replaced by the members provided in update call, if present.
PUT /scim/v2/Groups/:id
When using PATCH
the members provided in update call, if present, will be added to the list of members of the group. If the delete
operation is provided in the member hash, the member is removed from the list of members of the group. It behaves as described in this draft spec.
PATCH /scim/v2/Groups/:id
Response
status: 200 OK
{
"schemas": [
"urn:ietf:params:scim:schemas:core:2.0:Group"
],
"id": "5",
"...": "..."
}
The response contains all fields of the created group and is similar to the response in Get a single group
Delete a group
When a group is deleted, all members will be automatically removed from that group.
DELETE /scim/v2/Groups/:id
Response
status: 204 No Content
List response fields
Definitions taken from RFC 7644 - List Response
- totalResults
- Readonly [integer] — The number of results.
- itemsPerPage
- Readonly [integer] — The number of results per page.
- startIndex
- Readonly [integer] — The offset, or the number of results skipped.
- Resources
- Readonly [array] — A multi-valued list of complex objects containing the requested resources containing these fields.
Fields
As defined in the Group Schema
- displayName
- [string] — A human-readable name for the Group that is unique to the service provider.
- groupType
- [hash] — specific for xurrent The type of group. Typical values used might be ‘Organization’ or ‘Site’ but any string value may be used.
- members
- [array] — A list of members of the Group.
- members.value
- [string] — Identifier of the member of this Group.
- members.$ref
- [uri] — The URI corresponding to a SCIM resource that is a member of this Group.
- members.operation
- [string], default:
add
— Only available onPATCH
update. Valid values are: -
add
: Add the member to the group membersdelete
: Delete the member from the group members
- members.type
- [string] — specific for xurrent A label indicating the type of resource, e.g., ‘User’ or ‘Group’.
- meta.location
- [string] — The URI of this resource type.
- meta.resourceType
- [string] — The name of the resource type.