mirror of
https://github.com/Unleash/unleash.git
synced 2025-02-19 00:15:43 +01:00
## About the changes Implements custom root roles, encompassing a lot of different areas of the project, and slightly refactoring the current roles logic. It includes quite a clean up. This feature itself is behind a flag: `customRootRoles` This feature covers root roles in: - Users; - Service Accounts; - Groups; Apologies in advance. I may have gotten a bit carried away 🙈 ### Roles We now have a new admin tab called "Roles" where we can see all root roles and manage custom ones. We are not allowed to edit or remove *predefined* roles. data:image/s3,"s3://crabby-images/72a62/72a62ac3d8a407db44c827b41d0bde7aac41cd51" alt="image" This meant slightly pushing away the existing roles to `project-roles` instead. One idea we want to explore in the future is to unify both types of roles in the UI instead of having 2 separate tabs. This includes modernizing project roles to fit more into our current design and decisions. Hovering the permissions cell expands detailed information about the role: data:image/s3,"s3://crabby-images/96279/96279fd35feff8ebb488aaff6470c3d825e323d4" alt="image" ### Create and edit role Here's how the role form looks like (create / edit): data:image/s3,"s3://crabby-images/aa303/aa303e22eca5bf43e120ece88f96a3073c07109b" alt="image" Here I categorized permissions so it's easier to visualize and manage from a UX perspective. I'm using the same endpoint as before. I tried to unify the logic and get rid of the `projectRole` specific hooks. What distinguishes custom root roles from custom project roles is the extra `root-custom` type we see on the payload. By default we assume `custom` (custom project role) instead, which should help in terms of backwards compatibility. ### Delete role When we delete a custom role we try to help the end user make an informed decision by listing all the entities which currently use this custom root role: data:image/s3,"s3://crabby-images/7c649/7c6490a66a322bc0e793346af6df960cf582ad82" alt="image" ~~As mentioned in the screenshot, when deleting a custom role, we demote all entities associated with it to the predefined `Viewer` role.~~ **EDIT**: Apparently we currently block this from the API (access-service deleteRole) with a message: data:image/s3,"s3://crabby-images/9d6cb/9d6cb12a664251a31b5e367e914d8f85b8ec446e" alt="image" What should the correct behavior be? ### Role selector I added a new easy-to-use role selector component that is present in: - Users data:image/s3,"s3://crabby-images/db7fa/db7fac8ee341a612e020b6ec1710c5dfba7f5d1d" alt="image" - Service Accounts data:image/s3,"s3://crabby-images/a6288/a6288942f71a3cb34041e4f5f05206ae3e460f2a" alt="image" - Groups data:image/s3,"s3://crabby-images/593b2/593b2529db761947c69a7bb9601b2b09ef9e5ce5" alt="image" ### Role description I also added a new role description component that you can see below the dropdown in the selector component, but it's also used to better describe each role in the respective tables: data:image/s3,"s3://crabby-images/800ae/800ae47ca4c421e1a8ebe9ab9cecc71a43ac9bfd" alt="image" I'm not listing all the permissions of predefined roles. Those simply show the description in the tooltip: data:image/s3,"s3://crabby-images/63790/637903998edf633cf4dcb86ca47fe0d978a91020" alt="image" ### Role badge Groups is a bit different, since it uses a list of cards, so I added yet another component - Role badge: data:image/s3,"s3://crabby-images/35f84/35f84e36737e56436d7b0a954433485954979aea" alt="image" I'm using this same component on the profile tab: data:image/s3,"s3://crabby-images/5babd/5babd85a3699e58501cb8ee0c65c153630d89f2d" alt="image" ## Discussion points - Are we being defensive enough with the use of the flag? Should we cover more? - Are we breaking backwards compatibility in any way? - What should we do when removing a role? Block or demote? - Maybe some existing permission-related issues will surface with this change: Are we being specific enough with our permissions? A lot of places are simply checking for `ADMIN`; - We may want to get rid of the API roles coupling we have with the users and SAs and instead use the new hooks (e.g. `useRoles`) explicitly; - We should update the docs; - Maybe we could allow the user to add a custom role directly from the role selector component; --------- Co-authored-by: Gastón Fournier <gaston@getunleash.io> |
||
---|---|---|
.. | ||
HtmlTooltip.tsx |