92 lines
2.3 KiB
JavaScript
92 lines
2.3 KiB
JavaScript
export const buildGroupsEndpoints = API => {
|
|
// underlying functionality of adding/removing users/apps to groups
|
|
async function updateGroupResource(groupId, resource, operation, ids) {
|
|
if (!Array.isArray(ids)) {
|
|
ids = [ids]
|
|
}
|
|
return await API.post({
|
|
url: `/api/global/groups/${groupId}/${resource}`,
|
|
body: {
|
|
[operation]: ids,
|
|
},
|
|
})
|
|
}
|
|
|
|
return {
|
|
/**
|
|
* Creates a user group.
|
|
* @param group the new group to create
|
|
*/
|
|
saveGroup: async group => {
|
|
return await API.post({
|
|
url: "/api/global/groups",
|
|
body: group,
|
|
})
|
|
},
|
|
/**
|
|
* Gets all the user groups
|
|
*/
|
|
getGroups: async () => {
|
|
return await API.get({
|
|
url: "/api/global/groups",
|
|
})
|
|
},
|
|
|
|
/**
|
|
* Gets a group by ID
|
|
*/
|
|
getGroup: async id => {
|
|
return await API.get({
|
|
url: `/api/global/groups/${id}`,
|
|
})
|
|
},
|
|
|
|
/**
|
|
* Deletes a user group
|
|
* @param id the id of the config to delete
|
|
* @param rev the revision of the config to delete
|
|
*/
|
|
deleteGroup: async ({ id, rev }) => {
|
|
return await API.delete({
|
|
url: `/api/global/groups/${id}/${rev}`,
|
|
})
|
|
},
|
|
|
|
/**
|
|
* Adds users to a group
|
|
* @param groupId The group to update
|
|
* @param userIds The user IDs to be added
|
|
*/
|
|
addUsersToGroup: async (groupId, userIds) => {
|
|
return updateGroupResource(groupId, "users", "add", userIds)
|
|
},
|
|
|
|
/**
|
|
* Removes users from a group
|
|
* @param groupId The group to update
|
|
* @param userIds The user IDs to be removed
|
|
*/
|
|
removeUsersFromGroup: async (groupId, userIds) => {
|
|
return updateGroupResource(groupId, "users", "remove", userIds)
|
|
},
|
|
|
|
/**
|
|
* Adds apps to a group
|
|
* @param groupId The group to update
|
|
* @param appArray Array of objects, containing the appId and roleId to be added
|
|
*/
|
|
addAppsToGroup: async (groupId, appArray) => {
|
|
return updateGroupResource(groupId, "apps", "add", appArray)
|
|
},
|
|
|
|
/**
|
|
* Removes apps from a group
|
|
* @param groupId The group to update
|
|
* @param appArray Array of objects, containing the appId to be removed
|
|
*/
|
|
removeAppsFromGroup: async (groupId, appArray) => {
|
|
return updateGroupResource(groupId, "apps", "remove", appArray)
|
|
},
|
|
}
|
|
}
|