-
Notifications
You must be signed in to change notification settings - Fork 253
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat(backend): Introduce OrganizationRoleAPI (#2177)
* feat(backend): Introduce OrganizationRoleAPI * test(backend): Update exports.test.ts * test(clerk-sdk-node): Update exports * test(nextjs): Update exports.test.ts.snap * feat(backend): Address PR comments * chore(backend): Rename OrganizationRole to Role
- Loading branch information
1 parent
0ce0edc
commit b3a3dcd
Showing
11 changed files
with
190 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
--- | ||
'@clerk/backend': patch | ||
--- | ||
|
||
Add OrganizationRoleAPI for CRUD operations regarding instance level organization roles. |
138 changes: 138 additions & 0 deletions
138
packages/backend/src/api/endpoints/OrganizationRoleApi.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,138 @@ | ||
import { joinPaths } from '../../util/path'; | ||
import type { DeletedObject, Role } from '../resources'; | ||
import { AbstractAPI } from './AbstractApi'; | ||
|
||
const basePath = '/organizations_roles'; | ||
|
||
type GetRoleListParams = { | ||
limit?: number; | ||
offset?: number; | ||
query?: string; | ||
order_by?: string; | ||
}; | ||
|
||
type CreateParams = { | ||
/** | ||
* A name of a role in a readable friendly format. | ||
* F.e. `Teacher` or `Administrator` | ||
*/ | ||
name: string; | ||
|
||
/** | ||
* A unique identifier that represents the role. | ||
* F.e. `org:administrator` | ||
*/ | ||
key: string; | ||
|
||
/** | ||
* A brief description of what the role represents or its intended use. | ||
*/ | ||
description: string; | ||
|
||
/** | ||
* An array of permission ids that will be assigned to this role. | ||
*/ | ||
permissions: string[]; | ||
}; | ||
|
||
type GetOrganizationRoleParams = { roleId: string }; | ||
|
||
type UpdateParams = { | ||
/** | ||
* A name of a role in a readable friendly format. | ||
* F.e. `Teacher` or `Administrator` | ||
* Passing undefined has no effect to the existing value. | ||
*/ | ||
name?: string; | ||
|
||
/** | ||
* A unique identifier that represents the role. | ||
* F.e. `org:administrator` | ||
* Passing undefined has no effect to the existing value. | ||
*/ | ||
key?: string; | ||
|
||
/** | ||
* A brief description of what the role represents or its intended use. | ||
* Passing undefined has no effect to the existing value. | ||
*/ | ||
description?: string; | ||
|
||
/** | ||
* An array of permission ids that will be assigned to this role. | ||
* Passing undefined has no effect to the permission that already exist. | ||
* Passing an empty array will override the existing permissions. | ||
*/ | ||
permissions?: string[]; | ||
}; | ||
|
||
type RemovePermissionParams = { | ||
permissionId: string; | ||
roleId: string; | ||
}; | ||
|
||
type AssignPermissionParams = RemovePermissionParams; | ||
|
||
export class OrganizationRoleAPI extends AbstractAPI { | ||
public async getOrganizationRoleList(params?: GetRoleListParams) { | ||
return this.request<Role[]>({ | ||
method: 'GET', | ||
path: basePath, | ||
queryParams: params, | ||
}); | ||
} | ||
|
||
public async createOrganizationRole(params: CreateParams) { | ||
return this.request<Role>({ | ||
method: 'POST', | ||
path: basePath, | ||
bodyParams: params, | ||
}); | ||
} | ||
|
||
public async getOrganizationRole(params: GetOrganizationRoleParams) { | ||
this.requireId(params.roleId); | ||
|
||
return this.request<Role>({ | ||
method: 'GET', | ||
path: joinPaths(basePath, params.roleId), | ||
}); | ||
} | ||
|
||
public async updateOrganizationRole(roleId: string, params: UpdateParams) { | ||
this.requireId(roleId); | ||
return this.request<Role>({ | ||
method: 'PATCH', | ||
path: joinPaths(basePath, roleId), | ||
bodyParams: params, | ||
}); | ||
} | ||
|
||
public async deleteOrganizationRole(roleId: string) { | ||
this.requireId(roleId); | ||
return this.request<DeletedObject>({ | ||
method: 'DELETE', | ||
path: joinPaths(basePath, roleId), | ||
}); | ||
} | ||
|
||
public async assignPermissionToRole(params: AssignPermissionParams) { | ||
const { roleId, permissionId } = params; | ||
this.requireId(roleId); | ||
this.requireId(permissionId); | ||
return this.request<Role>({ | ||
method: 'POST', | ||
path: joinPaths(basePath, roleId, 'permission', permissionId), | ||
}); | ||
} | ||
|
||
public async removePermissionFromRole(params: RemovePermissionParams) { | ||
const { roleId, permissionId } = params; | ||
this.requireId(roleId); | ||
this.requireId(permissionId); | ||
return this.request<Role>({ | ||
method: 'DELETE', | ||
path: joinPaths(basePath, roleId, 'permission', permissionId), | ||
}); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
import type { RoleJSON } from './JSON'; | ||
import { Permission } from './Permission'; | ||
|
||
export class Role { | ||
constructor( | ||
readonly id: string, | ||
readonly name: string, | ||
readonly key: string, | ||
readonly description: string, | ||
readonly permissions: Permission[] = [], | ||
readonly createdAt: number, | ||
readonly updatedAt: number, | ||
) {} | ||
|
||
static fromJSON(data: RoleJSON): Role { | ||
return new Role( | ||
data.id, | ||
data.name, | ||
data.key, | ||
data.description, | ||
(data.permissions || []).map(x => Permission.fromJSON(x)), | ||
data.created_at, | ||
data.updated_at, | ||
); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters