-
Notifications
You must be signed in to change notification settings - Fork 0
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Feat disable duplicate user or group permission #242
Feat disable duplicate user or group permission #242
Conversation
Signed-off-by: Lin Wang <[email protected]>
Signed-off-by: Lin Wang <[email protected]>
d203dd4
to
ab9465e
Compare
Codecov Report
@@ Coverage Diff @@
## workspace #242 +/- ##
==========================================
Coverage 66.21% 66.21%
==========================================
Files 3438 3438
Lines 66262 66269 +7
Branches 10691 10693 +2
==========================================
+ Hits 43878 43883 +5
- Misses 19703 19705 +2
Partials 2681 2681
Flags with carried forward coverage won't be shown. Click here to find out more.
... and 1 file with indirect coverage changes 📣 We’re building smart automated test selection to slash your CI/CD build times. Learn more |
permissions: WorkspaceRoutePermissionItem[]; | ||
} | ||
attributes: Omit<WorkspaceAttribute, 'id'>, | ||
permissions: WorkspaceRoutePermissionItem[] |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Maybe not in the scope, but should permissions
be optional? Because user may not have permission control turned on.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sure, the permissions could be optional.
combination.length === permissionModes.length && | ||
combination.every((mode) => permissionModes.includes(mode)) | ||
); | ||
const isValidatePermissions = (permissions: Permissions) => { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If we move convertToACL
to workspace_client
, and passing the raw permissions(type is WorkspaceRoutePermissionItem[]
) to create/update, perhaps we don't need to convert the data here? It would be much easier to validate a flatten array of WorkspaceRoutePermissionItem[]
.
Not only make it easier to validate the permission mode combinations, but also make it easier to validate the user/group duplications here as well.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That's a good idea. The WorkspaceRoutePermissionItem[]
in route level was only used in the front end page. I kept the ACL
parameter in case of passing ACL
to workspace client directly. From current implementation, the create
or update
method only be used in workspace routes. I think we can change to parameter type to WorkspaceRoutePermissionItem[]
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
we also can rename WorkspaceRoutePermissionItem
to not include word Route
so that it's more generic,
Signed-off-by: Lin Wang <[email protected]>
Signed-off-by: Lin Wang <[email protected]>
Description
Issues Resolved
Screenshot
Testing the changes
Check List
yarn test:jest
yarn test:jest_integration
yarn test:ftr