Groups
A group is a set of users who represent a single business unit or who are assigned a single body of work.
Querying for groups
To retrieve information about a group, use the following endpoints:
- GET
/admin/v1/groups
- GET
/admin/v1/groups/{groupId}
For example, the following is the snippet of the response payload when retrieving the information for group demo_sample:31.
GET /admin/v1/users/demo_sample:31
{
"data": {
"attributes": {
"displayName": "Alexandria Branch",
"groupType": {
"code": "branch",
"name": "Branch office"
},
"id": "demo_sample:31",
"name": "Alexandria Branch",
"parent": {
"displayName": "Eastern Region",
"id": "demo_sample:29",
"type": "Group",
"uri": "/admin/v1/groups/demo_sample:29"
},
"securityZone": {
"displayName": "Auto and Property",
"id": "default_data:1"
},
"supervisor": {
"displayName": "Sue Smith",
"id": "demo_sample:2",
"type": "User",
"uri": "/admin/v1/users/demo_sample:2"
}
},
...
}
}
Creating groups
To create a group, use the following endpoint:
- POST
/admin/v1/groups
When creating a group, you must specify the following values:
groupType
- a value from theGroupType
typelist, such as generalname
- a string valueparent
- A JSON object with an id field that references the id of the parent groupsecurityZone
- A JSON object with an id field that references the id of the group's security zonesupervisor
- A JSON object with an id field that references the id of the user who is the supervisor
As of this release, there is no endpoint for retrieving information about security zones. To identify the ID of the desired security zone, you must use some other method.
The user who is designated as the supervisor of the group is not required to be a member of the group. Also, designated a user as the supervisor does not automatically add the user to the group as a member.
POST /admin/v1/groups
{
"data": {
"attributes": {
"groupType": {
"code": "general"
},
"name": "Cloud API Group 1",
"parent": {
"id": "systemTables:1"
},
"securityZone": {
"id": "default_data:1"
},
"supervisor": {
"id": "demo_sample:7"
}
}
}
}
Assigning users to a group
You cannot assign a user to a group using the /admin/v1/users
endpoint. You must use the /admin/v1/groups/{groupId}/users
endpoint. For more information, see Assigning users to groups
.
Assigning users to groups
The GroupUser
entity
In BillingCenter, users and groups are tracked as separate
User
and Group
entities. There is a third
entity, GroupUser
, whose purpose is to track information about one
assignment of a user to a group. For example, if an instance of GenericCenter has
two groups and three users and every user belongs to every group:
- There would be two instances of
Group
- There would be three instances of
User
- There would be six instances of
GroupUser
(user 1 to group A, user 1 to group B, user 2 to group A, and so on)
In addition to tracking a single user assignment to a group, the
GroupUser
entity also tracks information about the user’s
capabilities within the group. This includes the following fields:
manager
- Boolean indicating whether the user has permission to view the activity of others in the groupmember
- Boolean indicating whether the user is a working member of the group (for purposes of work assignment), as opposed to simply being associated with the group as a manager or other auxiliary personloadFactor
- Percent of work that can be assigned to the user
Querying for group/user information
To retrieve information about user assignments for a group, use the following endpoints:
- GET
/admin/v1/groups/{groupId}/users
- Returns a collection of user assignments for the group
- GET
/admin/v1/groups/{groupId}/users/[groupUserId}
- Returns information about a specific user assignment to the group
For example, the following is the snippet of the response payload when retrieving the information for the GroupUser assignments in group demo_sample:31. Note that the count is 12, which means the group has 12 users. Information is then provided about each GroupUser assignment, including who the user is, and whether the user is a member or a manager.
GET /admin/v1/users/demo_sample:31/users
{
"count": 12,
"data": [
{
"attributes": {
"id": "cc:SfZwdri9ldAAUgR46xZT7",
"manager": false,
"member": true,
"user": {
"displayName": "Andy Applegate",
"id": "demo_sample:1",
"type": "User",
"uri": "/admin/v1/users/demo_sample:1"
}
},
...
},
{
"attributes": {
"id": "cc:SZPhG_CUIA3E1sO2AiZ_s",
"manager": false,
"member": true,
"user": {
"displayName": "Betty Baker",
"id": "demo_sample:8",
"type": "User",
"uri": "/admin/v1/users/demo_sample:8"
}
},
...
},
...
Adding a user to a group
To add a user to a group, use the following endpoint:
- POST
/admin/v1/groups/{groupId}/users
In the request, you must specify the user to be added to the group. You can optionally specify other attributes. If you do not, the following default values are used:
member
: truemanager
: falseloadFactor
: null
For example, the following request adds user demo_sample:18 to group demo_sample:31.
POST /admin/v1/groups/demo_sample:31/users
{
"data": {
"attributes": {
"user": {
"id": "demo_sample:18"
}
}
}
}
This assigns user demo_sample:18 to group demo_sample:31 as a member. The user is not a manager of the group and has a null load factor. (If a field’s value is null, the field is not included in Cloud API responses.)
Modifying information about a user’s GroupUser assignment
To modify a user’s GroupUser
assignment information, use the
following endpoint:
- PATCH
/admin/v1/groups/{groupId}/users/{groupID}
For example, suppose that user demo_sample:18 has been added to group demo_sample:31
through a GroupUser
object whose id is xc:55. This user is a
member
of the group and not a manager
of the
group. The following PATCHes the GroupUser
assignment so that the
user is a manager
of the group and not a member
.
(They can view work assigned to other users in the group, and they will not have
work assigned to them.)
PATCH /admin/v1/groups/demo_sample:31/users/xc:55
{
"data": {
"attributes": {
"manager": true,
"member": false
}
}
}
Removing a user from a group
To remove a user from a group, you must delete the corresponding
GroupUser
assignment. To do this, use the following
endpoint:
- DELETE
/admin/v1/groups/{groupId}/users/{groupUserId}
For example, suppose that user demo_sample:18 has been added to group demo_sample:31 through a GroupUser object whose id is xc:55. The following request removes user demo_sample:18 to group demo_sample:31.
DELETE /admin/v1/groups/demo_sample:31/users/xc:55
<no request body>
Updating groups
Use the following endpoint to modify an existing group:
- PATCH
/admin/v1/groups/{groupId}
PATCH /admin/v1/groups/xc:202
{
"data": {
"attributes": {
"supervisor": {
"id": "demo_sample:6"
}
}
}
}
Deleting groups
Use the following endpoint to delete an existing group:
- DELETE
/admin/v1/groups/{groupId}
DELETE /admin/v1/groups/xc:202
<no request body>