mirror of
				https://github.com/strapi/strapi.git
				synced 2025-10-31 09:56:44 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			1141 lines
		
	
	
		
			41 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			1141 lines
		
	
	
		
			41 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| 'use strict';
 | |
| 
 | |
| const _ = require('lodash');
 | |
| 
 | |
| const { createAuthRequest } = require('api-tests/request');
 | |
| const { createStrapiInstance } = require('api-tests/strapi');
 | |
| 
 | |
| describe('Role CRUD End to End', () => {
 | |
|   let rq;
 | |
|   let strapi;
 | |
| 
 | |
|   beforeAll(async () => {
 | |
|     strapi = await createStrapiInstance();
 | |
|     rq = await createAuthRequest({ strapi });
 | |
|   });
 | |
| 
 | |
|   afterAll(async () => {
 | |
|     await strapi.destroy();
 | |
|   });
 | |
| 
 | |
|   test('Can get the existing permissions', async () => {
 | |
|     const res = await rq({
 | |
|       url: '/admin/permissions',
 | |
|       method: 'GET',
 | |
|     });
 | |
| 
 | |
|     expect(res.statusCode).toBe(200);
 | |
| 
 | |
|     // Data is sorted to avoid error with snapshot when the data is not in the same order
 | |
|     const sortedData = _.cloneDeep(res.body.data);
 | |
|     Object.keys(sortedData.sections).forEach((sectionName) => {
 | |
|       sortedData.sections[sectionName] = _.sortBy(sortedData.sections[sectionName], ['action']);
 | |
|     });
 | |
|     sortedData.conditions = sortedData.conditions.sort();
 | |
| 
 | |
|     // eslint-disable-next-line node/no-extraneous-require
 | |
|     const { features } = require('@strapi/strapi/lib/utils/ee');
 | |
|     const hasSSO = features.isEnabled('sso');
 | |
| 
 | |
|     if (hasSSO) {
 | |
|       expect(sortedData).toMatchInlineSnapshot(`
 | |
|           {
 | |
|             "conditions": [
 | |
|               {
 | |
|                 "category": "default",
 | |
|                 "displayName": "Is creator",
 | |
|                 "id": "admin::is-creator",
 | |
|               },
 | |
|               {
 | |
|                 "category": "default",
 | |
|                 "displayName": "Has same role as creator",
 | |
|                 "id": "admin::has-same-role-as-creator",
 | |
|               },
 | |
|             ],
 | |
|             "sections": {
 | |
|               "collectionTypes": [
 | |
|                 [
 | |
|                   {
 | |
|                     "actionId": "plugin::content-manager.explorer.create",
 | |
|                     "applyToProperties": [
 | |
|                       "fields",
 | |
|                       "locales",
 | |
|                     ],
 | |
|                     "label": "Create",
 | |
|                     "subjects": [
 | |
|                       "plugin::users-permissions.user",
 | |
|                     ],
 | |
|                   },
 | |
|                   {
 | |
|                     "actionId": "plugin::content-manager.explorer.read",
 | |
|                     "applyToProperties": [
 | |
|                       "fields",
 | |
|                       "locales",
 | |
|                     ],
 | |
|                     "label": "Read",
 | |
|                     "subjects": [
 | |
|                       "plugin::users-permissions.user",
 | |
|                     ],
 | |
|                   },
 | |
|                   {
 | |
|                     "actionId": "plugin::content-manager.explorer.update",
 | |
|                     "applyToProperties": [
 | |
|                       "fields",
 | |
|                       "locales",
 | |
|                     ],
 | |
|                     "label": "Update",
 | |
|                     "subjects": [
 | |
|                       "plugin::users-permissions.user",
 | |
|                     ],
 | |
|                   },
 | |
|                   {
 | |
|                     "actionId": "plugin::content-manager.explorer.delete",
 | |
|                     "applyToProperties": [
 | |
|                       "locales",
 | |
|                     ],
 | |
|                     "label": "Delete",
 | |
|                     "subjects": [
 | |
|                       "plugin::users-permissions.user",
 | |
|                     ],
 | |
|                   },
 | |
|                   {
 | |
|                     "actionId": "plugin::content-manager.explorer.publish",
 | |
|                     "applyToProperties": [
 | |
|                       "locales",
 | |
|                     ],
 | |
|                     "label": "Publish",
 | |
|                     "subjects": [],
 | |
|                   },
 | |
|                 ],
 | |
|                 [
 | |
|                   {
 | |
|                     "label": "user",
 | |
|                     "properties": [
 | |
|                       {
 | |
|                         "children": [
 | |
|                           {
 | |
|                             "label": "username",
 | |
|                             "required": true,
 | |
|                             "value": "username",
 | |
|                           },
 | |
|                           {
 | |
|                             "label": "email",
 | |
|                             "required": true,
 | |
|                             "value": "email",
 | |
|                           },
 | |
|                           {
 | |
|                             "label": "provider",
 | |
|                             "value": "provider",
 | |
|                           },
 | |
|                           {
 | |
|                             "label": "password",
 | |
|                             "value": "password",
 | |
|                           },
 | |
|                           {
 | |
|                             "label": "resetPasswordToken",
 | |
|                             "value": "resetPasswordToken",
 | |
|                           },
 | |
|                           {
 | |
|                             "label": "confirmationToken",
 | |
|                             "value": "confirmationToken",
 | |
|                           },
 | |
|                           {
 | |
|                             "label": "confirmed",
 | |
|                             "value": "confirmed",
 | |
|                           },
 | |
|                           {
 | |
|                             "label": "blocked",
 | |
|                             "value": "blocked",
 | |
|                           },
 | |
|                           {
 | |
|                             "label": "role",
 | |
|                             "value": "role",
 | |
|                           },
 | |
|                         ],
 | |
|                         "label": "Fields",
 | |
|                         "value": "fields",
 | |
|                       },
 | |
|                     ],
 | |
|                     "uid": "plugin::users-permissions.user",
 | |
|                   },
 | |
|                 ],
 | |
|               ],
 | |
|               "plugins": [
 | |
|                 {
 | |
|                   "action": "plugin::content-manager.collection-types.configure-view",
 | |
|                   "displayName": "Configure view",
 | |
|                   "plugin": "content-manager",
 | |
|                   "subCategory": "collection types",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "plugin::content-manager.components.configure-layout",
 | |
|                   "displayName": "Configure Layout",
 | |
|                   "plugin": "content-manager",
 | |
|                   "subCategory": "components",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "plugin::content-manager.single-types.configure-view",
 | |
|                   "displayName": "Configure view",
 | |
|                   "plugin": "content-manager",
 | |
|                   "subCategory": "single types",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "plugin::content-type-builder.read",
 | |
|                   "displayName": "Read",
 | |
|                   "plugin": "content-type-builder",
 | |
|                   "subCategory": "general",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "plugin::documentation.read",
 | |
|                   "displayName": "Access the Documentation",
 | |
|                   "plugin": "documentation",
 | |
|                   "subCategory": "general",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "plugin::documentation.settings.regenerate",
 | |
|                   "displayName": "Regenerate",
 | |
|                   "plugin": "documentation",
 | |
|                   "subCategory": "general",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "plugin::documentation.settings.update",
 | |
|                   "displayName": "Update and delete",
 | |
|                   "plugin": "documentation",
 | |
|                   "subCategory": "general",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "plugin::upload.assets.copy-link",
 | |
|                   "displayName": "Copy link",
 | |
|                   "plugin": "upload",
 | |
|                   "subCategory": "assets",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "plugin::upload.assets.create",
 | |
|                   "displayName": "Create (upload)",
 | |
|                   "plugin": "upload",
 | |
|                   "subCategory": "assets",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "plugin::upload.assets.download",
 | |
|                   "displayName": "Download",
 | |
|                   "plugin": "upload",
 | |
|                   "subCategory": "assets",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "plugin::upload.assets.update",
 | |
|                   "displayName": "Update (crop, details, replace) + delete",
 | |
|                   "plugin": "upload",
 | |
|                   "subCategory": "assets",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "plugin::upload.configure-view",
 | |
|                   "displayName": "Configure view",
 | |
|                   "plugin": "upload",
 | |
|                   "subCategory": "general",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "plugin::upload.read",
 | |
|                   "displayName": "Access the Media Library",
 | |
|                   "plugin": "upload",
 | |
|                   "subCategory": "general",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "plugin::users-permissions.advanced-settings.read",
 | |
|                   "displayName": "Read",
 | |
|                   "plugin": "users-permissions",
 | |
|                   "subCategory": "advancedSettings",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "plugin::users-permissions.advanced-settings.update",
 | |
|                   "displayName": "Edit",
 | |
|                   "plugin": "users-permissions",
 | |
|                   "subCategory": "advancedSettings",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "plugin::users-permissions.email-templates.read",
 | |
|                   "displayName": "Read",
 | |
|                   "plugin": "users-permissions",
 | |
|                   "subCategory": "emailTemplates",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "plugin::users-permissions.email-templates.update",
 | |
|                   "displayName": "Edit",
 | |
|                   "plugin": "users-permissions",
 | |
|                   "subCategory": "emailTemplates",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "plugin::users-permissions.providers.read",
 | |
|                   "displayName": "Read",
 | |
|                   "plugin": "users-permissions",
 | |
|                   "subCategory": "providers",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "plugin::users-permissions.providers.update",
 | |
|                   "displayName": "Edit",
 | |
|                   "plugin": "users-permissions",
 | |
|                   "subCategory": "providers",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "plugin::users-permissions.roles.create",
 | |
|                   "displayName": "Create",
 | |
|                   "plugin": "users-permissions",
 | |
|                   "subCategory": "roles",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "plugin::users-permissions.roles.delete",
 | |
|                   "displayName": "Delete",
 | |
|                   "plugin": "users-permissions",
 | |
|                   "subCategory": "roles",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "plugin::users-permissions.roles.read",
 | |
|                   "displayName": "Read",
 | |
|                   "plugin": "users-permissions",
 | |
|                   "subCategory": "roles",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "plugin::users-permissions.roles.update",
 | |
|                   "displayName": "Update",
 | |
|                   "plugin": "users-permissions",
 | |
|                   "subCategory": "roles",
 | |
|                 },
 | |
|               ],
 | |
|               "settings": [
 | |
|                 {
 | |
|                   "action": "admin::api-tokens.access",
 | |
|                   "category": "api tokens",
 | |
|                   "displayName": "Access the API tokens settings page",
 | |
|                   "subCategory": "api Tokens",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::api-tokens.create",
 | |
|                   "category": "api tokens",
 | |
|                   "displayName": "Create (generate)",
 | |
|                   "subCategory": "general",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::api-tokens.delete",
 | |
|                   "category": "api tokens",
 | |
|                   "displayName": "Delete (revoke)",
 | |
|                   "subCategory": "general",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::api-tokens.read",
 | |
|                   "category": "api tokens",
 | |
|                   "displayName": "Read",
 | |
|                   "subCategory": "general",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::api-tokens.regenerate",
 | |
|                   "category": "api tokens",
 | |
|                   "displayName": "Regenerate",
 | |
|                   "subCategory": "general",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::api-tokens.update",
 | |
|                   "category": "api tokens",
 | |
|                   "displayName": "Update",
 | |
|                   "subCategory": "general",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::audit-logs.read",
 | |
|                   "category": "audit logs",
 | |
|                   "displayName": "Read",
 | |
|                   "subCategory": "options",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::marketplace.read",
 | |
|                   "category": "plugins and marketplace",
 | |
|                   "displayName": "Access the marketplace",
 | |
|                   "subCategory": "marketplace",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::project-settings.read",
 | |
|                   "category": "project",
 | |
|                   "displayName": "Read the project level settings",
 | |
|                   "subCategory": "general",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::project-settings.update",
 | |
|                   "category": "project",
 | |
|                   "displayName": "Update the project level settings",
 | |
|                   "subCategory": "general",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::provider-login.read",
 | |
|                   "category": "single sign on",
 | |
|                   "displayName": "Read",
 | |
|                   "subCategory": "options",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::provider-login.update",
 | |
|                   "category": "single sign on",
 | |
|                   "displayName": "Update",
 | |
|                   "subCategory": "options",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::review-workflows.create",
 | |
|                   "category": "review workflows",
 | |
|                   "displayName": "Create",
 | |
|                   "subCategory": "options",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::review-workflows.delete",
 | |
|                   "category": "review workflows",
 | |
|                   "displayName": "Delete",
 | |
|                   "subCategory": "options",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::review-workflows.read",
 | |
|                   "category": "review workflows",
 | |
|                   "displayName": "Read",
 | |
|                   "subCategory": "options",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::review-workflows.update",
 | |
|                   "category": "review workflows",
 | |
|                   "displayName": "Update",
 | |
|                   "subCategory": "options",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::roles.create",
 | |
|                   "category": "users and roles",
 | |
|                   "displayName": "Create",
 | |
|                   "subCategory": "roles",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::roles.delete",
 | |
|                   "category": "users and roles",
 | |
|                   "displayName": "Delete",
 | |
|                   "subCategory": "roles",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::roles.read",
 | |
|                   "category": "users and roles",
 | |
|                   "displayName": "Read",
 | |
|                   "subCategory": "roles",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::roles.update",
 | |
|                   "category": "users and roles",
 | |
|                   "displayName": "Update",
 | |
|                   "subCategory": "roles",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::transfer.tokens.access",
 | |
|                   "category": "transfer tokens",
 | |
|                   "displayName": "Access the transfer tokens settings page",
 | |
|                   "subCategory": "transfer tokens",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::transfer.tokens.create",
 | |
|                   "category": "transfer tokens",
 | |
|                   "displayName": "Create (generate)",
 | |
|                   "subCategory": "general",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::transfer.tokens.delete",
 | |
|                   "category": "transfer tokens",
 | |
|                   "displayName": "Delete (revoke)",
 | |
|                   "subCategory": "general",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::transfer.tokens.read",
 | |
|                   "category": "transfer tokens",
 | |
|                   "displayName": "Read",
 | |
|                   "subCategory": "general",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::transfer.tokens.regenerate",
 | |
|                   "category": "transfer tokens",
 | |
|                   "displayName": "Regenerate",
 | |
|                   "subCategory": "general",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::transfer.tokens.update",
 | |
|                   "category": "transfer tokens",
 | |
|                   "displayName": "Update",
 | |
|                   "subCategory": "general",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::users.create",
 | |
|                   "category": "users and roles",
 | |
|                   "displayName": "Create (invite)",
 | |
|                   "subCategory": "users",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::users.delete",
 | |
|                   "category": "users and roles",
 | |
|                   "displayName": "Delete",
 | |
|                   "subCategory": "users",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::users.read",
 | |
|                   "category": "users and roles",
 | |
|                   "displayName": "Read",
 | |
|                   "subCategory": "users",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::users.update",
 | |
|                   "category": "users and roles",
 | |
|                   "displayName": "Update",
 | |
|                   "subCategory": "users",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::webhooks.create",
 | |
|                   "category": "webhooks",
 | |
|                   "displayName": "Create",
 | |
|                   "subCategory": "general",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::webhooks.delete",
 | |
|                   "category": "webhooks",
 | |
|                   "displayName": "Delete",
 | |
|                   "subCategory": "general",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::webhooks.read",
 | |
|                   "category": "webhooks",
 | |
|                   "displayName": "Read",
 | |
|                   "subCategory": "general",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "admin::webhooks.update",
 | |
|                   "category": "webhooks",
 | |
|                   "displayName": "Update",
 | |
|                   "subCategory": "general",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "plugin::documentation.settings.read",
 | |
|                   "category": "documentation",
 | |
|                   "displayName": "Access the documentation settings page",
 | |
|                   "subCategory": "general",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "plugin::email.settings.read",
 | |
|                   "category": "email",
 | |
|                   "displayName": "Access the Email Settings page",
 | |
|                   "subCategory": "general",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "plugin::i18n.locale.create",
 | |
|                   "category": "Internationalization",
 | |
|                   "displayName": "Create",
 | |
|                   "subCategory": "Locales",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "plugin::i18n.locale.delete",
 | |
|                   "category": "Internationalization",
 | |
|                   "displayName": "Delete",
 | |
|                   "subCategory": "Locales",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "plugin::i18n.locale.read",
 | |
|                   "category": "Internationalization",
 | |
|                   "displayName": "Read",
 | |
|                   "subCategory": "Locales",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "plugin::i18n.locale.update",
 | |
|                   "category": "Internationalization",
 | |
|                   "displayName": "Update",
 | |
|                   "subCategory": "Locales",
 | |
|                 },
 | |
|                 {
 | |
|                   "action": "plugin::upload.settings.read",
 | |
|                   "category": "media library",
 | |
|                   "displayName": "Access the Media Library settings page",
 | |
|                   "subCategory": "general",
 | |
|                 },
 | |
|               ],
 | |
|               "singleTypes": [
 | |
|                 [
 | |
|                   {
 | |
|                     "actionId": "plugin::content-manager.explorer.create",
 | |
|                     "applyToProperties": [
 | |
|                       "fields",
 | |
|                       "locales",
 | |
|                     ],
 | |
|                     "label": "Create",
 | |
|                     "subjects": [
 | |
|                       "plugin::users-permissions.user",
 | |
|                     ],
 | |
|                   },
 | |
|                   {
 | |
|                     "actionId": "plugin::content-manager.explorer.read",
 | |
|                     "applyToProperties": [
 | |
|                       "fields",
 | |
|                       "locales",
 | |
|                     ],
 | |
|                     "label": "Read",
 | |
|                     "subjects": [
 | |
|                       "plugin::users-permissions.user",
 | |
|                     ],
 | |
|                   },
 | |
|                   {
 | |
|                     "actionId": "plugin::content-manager.explorer.update",
 | |
|                     "applyToProperties": [
 | |
|                       "fields",
 | |
|                       "locales",
 | |
|                     ],
 | |
|                     "label": "Update",
 | |
|                     "subjects": [
 | |
|                       "plugin::users-permissions.user",
 | |
|                     ],
 | |
|                   },
 | |
|                   {
 | |
|                     "actionId": "plugin::content-manager.explorer.delete",
 | |
|                     "applyToProperties": [
 | |
|                       "locales",
 | |
|                     ],
 | |
|                     "label": "Delete",
 | |
|                     "subjects": [
 | |
|                       "plugin::users-permissions.user",
 | |
|                     ],
 | |
|                   },
 | |
|                   {
 | |
|                     "actionId": "plugin::content-manager.explorer.publish",
 | |
|                     "applyToProperties": [
 | |
|                       "locales",
 | |
|                     ],
 | |
|                     "label": "Publish",
 | |
|                     "subjects": [],
 | |
|                   },
 | |
|                 ],
 | |
|                 [],
 | |
|               ],
 | |
|             },
 | |
|           }
 | |
|         `);
 | |
|     } else {
 | |
|       expect(sortedData).toMatchInlineSnapshot(`
 | |
|         {
 | |
|           "conditions": [
 | |
|             {
 | |
|               "category": "default",
 | |
|               "displayName": "Is creator",
 | |
|               "id": "admin::is-creator",
 | |
|             },
 | |
|             {
 | |
|               "category": "default",
 | |
|               "displayName": "Has same role as creator",
 | |
|               "id": "admin::has-same-role-as-creator",
 | |
|             },
 | |
|           ],
 | |
|           "sections": {
 | |
|             "collectionTypes": [
 | |
|               [
 | |
|                 {
 | |
|                   "actionId": "plugin::content-manager.explorer.create",
 | |
|                   "applyToProperties": [
 | |
|                     "fields",
 | |
|                     "locales",
 | |
|                   ],
 | |
|                   "label": "Create",
 | |
|                   "subjects": [
 | |
|                     "plugin::users-permissions.user",
 | |
|                   ],
 | |
|                 },
 | |
|                 {
 | |
|                   "actionId": "plugin::content-manager.explorer.read",
 | |
|                   "applyToProperties": [
 | |
|                     "fields",
 | |
|                     "locales",
 | |
|                   ],
 | |
|                   "label": "Read",
 | |
|                   "subjects": [
 | |
|                     "plugin::users-permissions.user",
 | |
|                   ],
 | |
|                 },
 | |
|                 {
 | |
|                   "actionId": "plugin::content-manager.explorer.update",
 | |
|                   "applyToProperties": [
 | |
|                     "fields",
 | |
|                     "locales",
 | |
|                   ],
 | |
|                   "label": "Update",
 | |
|                   "subjects": [
 | |
|                     "plugin::users-permissions.user",
 | |
|                   ],
 | |
|                 },
 | |
|                 {
 | |
|                   "actionId": "plugin::content-manager.explorer.delete",
 | |
|                   "applyToProperties": [
 | |
|                     "locales",
 | |
|                   ],
 | |
|                   "label": "Delete",
 | |
|                   "subjects": [
 | |
|                     "plugin::users-permissions.user",
 | |
|                   ],
 | |
|                 },
 | |
|                 {
 | |
|                   "actionId": "plugin::content-manager.explorer.publish",
 | |
|                   "applyToProperties": [
 | |
|                     "locales",
 | |
|                   ],
 | |
|                   "label": "Publish",
 | |
|                   "subjects": [],
 | |
|                 },
 | |
|               ],
 | |
|               [
 | |
|                 {
 | |
|                   "label": "user",
 | |
|                   "properties": [
 | |
|                     {
 | |
|                       "children": [
 | |
|                         {
 | |
|                           "label": "username",
 | |
|                           "required": true,
 | |
|                           "value": "username",
 | |
|                         },
 | |
|                         {
 | |
|                           "label": "email",
 | |
|                           "required": true,
 | |
|                           "value": "email",
 | |
|                         },
 | |
|                         {
 | |
|                           "label": "provider",
 | |
|                           "value": "provider",
 | |
|                         },
 | |
|                         {
 | |
|                           "label": "password",
 | |
|                           "value": "password",
 | |
|                         },
 | |
|                         {
 | |
|                           "label": "resetPasswordToken",
 | |
|                           "value": "resetPasswordToken",
 | |
|                         },
 | |
|                         {
 | |
|                           "label": "confirmationToken",
 | |
|                           "value": "confirmationToken",
 | |
|                         },
 | |
|                         {
 | |
|                           "label": "confirmed",
 | |
|                           "value": "confirmed",
 | |
|                         },
 | |
|                         {
 | |
|                           "label": "blocked",
 | |
|                           "value": "blocked",
 | |
|                         },
 | |
|                         {
 | |
|                           "label": "role",
 | |
|                           "value": "role",
 | |
|                         },
 | |
|                       ],
 | |
|                       "label": "Fields",
 | |
|                       "value": "fields",
 | |
|                     },
 | |
|                   ],
 | |
|                   "uid": "plugin::users-permissions.user",
 | |
|                 },
 | |
|               ],
 | |
|             ],
 | |
|             "plugins": [
 | |
|               {
 | |
|                 "action": "plugin::content-manager.collection-types.configure-view",
 | |
|                 "displayName": "Configure view",
 | |
|                 "plugin": "content-manager",
 | |
|                 "subCategory": "collection types",
 | |
|               },
 | |
|               {
 | |
|                 "action": "plugin::content-manager.components.configure-layout",
 | |
|                 "displayName": "Configure Layout",
 | |
|                 "plugin": "content-manager",
 | |
|                 "subCategory": "components",
 | |
|               },
 | |
|               {
 | |
|                 "action": "plugin::content-manager.single-types.configure-view",
 | |
|                 "displayName": "Configure view",
 | |
|                 "plugin": "content-manager",
 | |
|                 "subCategory": "single types",
 | |
|               },
 | |
|               {
 | |
|                 "action": "plugin::content-type-builder.read",
 | |
|                 "displayName": "Read",
 | |
|                 "plugin": "content-type-builder",
 | |
|                 "subCategory": "general",
 | |
|               },
 | |
|               {
 | |
|                 "action": "plugin::documentation.read",
 | |
|                 "displayName": "Access the Documentation",
 | |
|                 "plugin": "documentation",
 | |
|                 "subCategory": "general",
 | |
|               },
 | |
|               {
 | |
|                 "action": "plugin::documentation.settings.regenerate",
 | |
|                 "displayName": "Regenerate",
 | |
|                 "plugin": "documentation",
 | |
|                 "subCategory": "general",
 | |
|               },
 | |
|               {
 | |
|                 "action": "plugin::documentation.settings.update",
 | |
|                 "displayName": "Update and delete",
 | |
|                 "plugin": "documentation",
 | |
|                 "subCategory": "general",
 | |
|               },
 | |
|               {
 | |
|                 "action": "plugin::upload.assets.copy-link",
 | |
|                 "displayName": "Copy link",
 | |
|                 "plugin": "upload",
 | |
|                 "subCategory": "assets",
 | |
|               },
 | |
|               {
 | |
|                 "action": "plugin::upload.assets.create",
 | |
|                 "displayName": "Create (upload)",
 | |
|                 "plugin": "upload",
 | |
|                 "subCategory": "assets",
 | |
|               },
 | |
|               {
 | |
|                 "action": "plugin::upload.assets.download",
 | |
|                 "displayName": "Download",
 | |
|                 "plugin": "upload",
 | |
|                 "subCategory": "assets",
 | |
|               },
 | |
|               {
 | |
|                 "action": "plugin::upload.assets.update",
 | |
|                 "displayName": "Update (crop, details, replace) + delete",
 | |
|                 "plugin": "upload",
 | |
|                 "subCategory": "assets",
 | |
|               },
 | |
|               {
 | |
|                 "action": "plugin::upload.configure-view",
 | |
|                 "displayName": "Configure view",
 | |
|                 "plugin": "upload",
 | |
|                 "subCategory": "general",
 | |
|               },
 | |
|               {
 | |
|                 "action": "plugin::upload.read",
 | |
|                 "displayName": "Access the Media Library",
 | |
|                 "plugin": "upload",
 | |
|                 "subCategory": "general",
 | |
|               },
 | |
|               {
 | |
|                 "action": "plugin::users-permissions.advanced-settings.read",
 | |
|                 "displayName": "Read",
 | |
|                 "plugin": "users-permissions",
 | |
|                 "subCategory": "advancedSettings",
 | |
|               },
 | |
|               {
 | |
|                 "action": "plugin::users-permissions.advanced-settings.update",
 | |
|                 "displayName": "Edit",
 | |
|                 "plugin": "users-permissions",
 | |
|                 "subCategory": "advancedSettings",
 | |
|               },
 | |
|               {
 | |
|                 "action": "plugin::users-permissions.email-templates.read",
 | |
|                 "displayName": "Read",
 | |
|                 "plugin": "users-permissions",
 | |
|                 "subCategory": "emailTemplates",
 | |
|               },
 | |
|               {
 | |
|                 "action": "plugin::users-permissions.email-templates.update",
 | |
|                 "displayName": "Edit",
 | |
|                 "plugin": "users-permissions",
 | |
|                 "subCategory": "emailTemplates",
 | |
|               },
 | |
|               {
 | |
|                 "action": "plugin::users-permissions.providers.read",
 | |
|                 "displayName": "Read",
 | |
|                 "plugin": "users-permissions",
 | |
|                 "subCategory": "providers",
 | |
|               },
 | |
|               {
 | |
|                 "action": "plugin::users-permissions.providers.update",
 | |
|                 "displayName": "Edit",
 | |
|                 "plugin": "users-permissions",
 | |
|                 "subCategory": "providers",
 | |
|               },
 | |
|               {
 | |
|                 "action": "plugin::users-permissions.roles.create",
 | |
|                 "displayName": "Create",
 | |
|                 "plugin": "users-permissions",
 | |
|                 "subCategory": "roles",
 | |
|               },
 | |
|               {
 | |
|                 "action": "plugin::users-permissions.roles.delete",
 | |
|                 "displayName": "Delete",
 | |
|                 "plugin": "users-permissions",
 | |
|                 "subCategory": "roles",
 | |
|               },
 | |
|               {
 | |
|                 "action": "plugin::users-permissions.roles.read",
 | |
|                 "displayName": "Read",
 | |
|                 "plugin": "users-permissions",
 | |
|                 "subCategory": "roles",
 | |
|               },
 | |
|               {
 | |
|                 "action": "plugin::users-permissions.roles.update",
 | |
|                 "displayName": "Update",
 | |
|                 "plugin": "users-permissions",
 | |
|                 "subCategory": "roles",
 | |
|               },
 | |
|             ],
 | |
|             "settings": [
 | |
|               {
 | |
|                 "action": "admin::api-tokens.access",
 | |
|                 "category": "api tokens",
 | |
|                 "displayName": "Access the API tokens settings page",
 | |
|                 "subCategory": "api Tokens",
 | |
|               },
 | |
|               {
 | |
|                 "action": "admin::api-tokens.create",
 | |
|                 "category": "api tokens",
 | |
|                 "displayName": "Create (generate)",
 | |
|                 "subCategory": "general",
 | |
|               },
 | |
|               {
 | |
|                 "action": "admin::api-tokens.delete",
 | |
|                 "category": "api tokens",
 | |
|                 "displayName": "Delete (revoke)",
 | |
|                 "subCategory": "general",
 | |
|               },
 | |
|               {
 | |
|                 "action": "admin::api-tokens.read",
 | |
|                 "category": "api tokens",
 | |
|                 "displayName": "Read",
 | |
|                 "subCategory": "general",
 | |
|               },
 | |
|               {
 | |
|                 "action": "admin::api-tokens.regenerate",
 | |
|                 "category": "api tokens",
 | |
|                 "displayName": "Regenerate",
 | |
|                 "subCategory": "general",
 | |
|               },
 | |
|               {
 | |
|                 "action": "admin::api-tokens.update",
 | |
|                 "category": "api tokens",
 | |
|                 "displayName": "Update",
 | |
|                 "subCategory": "general",
 | |
|               },
 | |
|               {
 | |
|                 "action": "admin::marketplace.read",
 | |
|                 "category": "plugins and marketplace",
 | |
|                 "displayName": "Access the marketplace",
 | |
|                 "subCategory": "marketplace",
 | |
|               },
 | |
|               {
 | |
|                 "action": "admin::project-settings.read",
 | |
|                 "category": "project",
 | |
|                 "displayName": "Read the project level settings",
 | |
|                 "subCategory": "general",
 | |
|               },
 | |
|               {
 | |
|                 "action": "admin::project-settings.update",
 | |
|                 "category": "project",
 | |
|                 "displayName": "Update the project level settings",
 | |
|                 "subCategory": "general",
 | |
|               },
 | |
|               {
 | |
|                 "action": "admin::roles.create",
 | |
|                 "category": "users and roles",
 | |
|                 "displayName": "Create",
 | |
|                 "subCategory": "roles",
 | |
|               },
 | |
|               {
 | |
|                 "action": "admin::roles.delete",
 | |
|                 "category": "users and roles",
 | |
|                 "displayName": "Delete",
 | |
|                 "subCategory": "roles",
 | |
|               },
 | |
|               {
 | |
|                 "action": "admin::roles.read",
 | |
|                 "category": "users and roles",
 | |
|                 "displayName": "Read",
 | |
|                 "subCategory": "roles",
 | |
|               },
 | |
|               {
 | |
|                 "action": "admin::roles.update",
 | |
|                 "category": "users and roles",
 | |
|                 "displayName": "Update",
 | |
|                 "subCategory": "roles",
 | |
|               },
 | |
|               {
 | |
|                 "action": "admin::transfer.tokens.access",
 | |
|                 "category": "transfer tokens",
 | |
|                 "displayName": "Access the transfer tokens settings page",
 | |
|                 "subCategory": "transfer tokens",
 | |
|               },
 | |
|               {
 | |
|                 "action": "admin::transfer.tokens.create",
 | |
|                 "category": "transfer tokens",
 | |
|                 "displayName": "Create (generate)",
 | |
|                 "subCategory": "general",
 | |
|               },
 | |
|               {
 | |
|                 "action": "admin::transfer.tokens.delete",
 | |
|                 "category": "transfer tokens",
 | |
|                 "displayName": "Delete (revoke)",
 | |
|                 "subCategory": "general",
 | |
|               },
 | |
|               {
 | |
|                 "action": "admin::transfer.tokens.read",
 | |
|                 "category": "transfer tokens",
 | |
|                 "displayName": "Read",
 | |
|                 "subCategory": "general",
 | |
|               },
 | |
|               {
 | |
|                 "action": "admin::transfer.tokens.regenerate",
 | |
|                 "category": "transfer tokens",
 | |
|                 "displayName": "Regenerate",
 | |
|                 "subCategory": "general",
 | |
|               },
 | |
|               {
 | |
|                 "action": "admin::transfer.tokens.update",
 | |
|                 "category": "transfer tokens",
 | |
|                 "displayName": "Update",
 | |
|                 "subCategory": "general",
 | |
|               },
 | |
|               {
 | |
|                 "action": "admin::users.create",
 | |
|                 "category": "users and roles",
 | |
|                 "displayName": "Create (invite)",
 | |
|                 "subCategory": "users",
 | |
|               },
 | |
|               {
 | |
|                 "action": "admin::users.delete",
 | |
|                 "category": "users and roles",
 | |
|                 "displayName": "Delete",
 | |
|                 "subCategory": "users",
 | |
|               },
 | |
|               {
 | |
|                 "action": "admin::users.read",
 | |
|                 "category": "users and roles",
 | |
|                 "displayName": "Read",
 | |
|                 "subCategory": "users",
 | |
|               },
 | |
|               {
 | |
|                 "action": "admin::users.update",
 | |
|                 "category": "users and roles",
 | |
|                 "displayName": "Update",
 | |
|                 "subCategory": "users",
 | |
|               },
 | |
|               {
 | |
|                 "action": "admin::webhooks.create",
 | |
|                 "category": "webhooks",
 | |
|                 "displayName": "Create",
 | |
|                 "subCategory": "general",
 | |
|               },
 | |
|               {
 | |
|                 "action": "admin::webhooks.delete",
 | |
|                 "category": "webhooks",
 | |
|                 "displayName": "Delete",
 | |
|                 "subCategory": "general",
 | |
|               },
 | |
|               {
 | |
|                 "action": "admin::webhooks.read",
 | |
|                 "category": "webhooks",
 | |
|                 "displayName": "Read",
 | |
|                 "subCategory": "general",
 | |
|               },
 | |
|               {
 | |
|                 "action": "admin::webhooks.update",
 | |
|                 "category": "webhooks",
 | |
|                 "displayName": "Update",
 | |
|                 "subCategory": "general",
 | |
|               },
 | |
|               {
 | |
|                 "action": "plugin::documentation.settings.read",
 | |
|                 "category": "documentation",
 | |
|                 "displayName": "Access the documentation settings page",
 | |
|                 "subCategory": "general",
 | |
|               },
 | |
|               {
 | |
|                 "action": "plugin::email.settings.read",
 | |
|                 "category": "email",
 | |
|                 "displayName": "Access the Email Settings page",
 | |
|                 "subCategory": "general",
 | |
|               },
 | |
|               {
 | |
|                 "action": "plugin::i18n.locale.create",
 | |
|                 "category": "Internationalization",
 | |
|                 "displayName": "Create",
 | |
|                 "subCategory": "Locales",
 | |
|               },
 | |
|               {
 | |
|                 "action": "plugin::i18n.locale.delete",
 | |
|                 "category": "Internationalization",
 | |
|                 "displayName": "Delete",
 | |
|                 "subCategory": "Locales",
 | |
|               },
 | |
|               {
 | |
|                 "action": "plugin::i18n.locale.read",
 | |
|                 "category": "Internationalization",
 | |
|                 "displayName": "Read",
 | |
|                 "subCategory": "Locales",
 | |
|               },
 | |
|               {
 | |
|                 "action": "plugin::i18n.locale.update",
 | |
|                 "category": "Internationalization",
 | |
|                 "displayName": "Update",
 | |
|                 "subCategory": "Locales",
 | |
|               },
 | |
|               {
 | |
|                 "action": "plugin::upload.settings.read",
 | |
|                 "category": "media library",
 | |
|                 "displayName": "Access the Media Library settings page",
 | |
|                 "subCategory": "general",
 | |
|               },
 | |
|             ],
 | |
|             "singleTypes": [
 | |
|               [
 | |
|                 {
 | |
|                   "actionId": "plugin::content-manager.explorer.create",
 | |
|                   "applyToProperties": [
 | |
|                     "fields",
 | |
|                     "locales",
 | |
|                   ],
 | |
|                   "label": "Create",
 | |
|                   "subjects": [
 | |
|                     "plugin::users-permissions.user",
 | |
|                   ],
 | |
|                 },
 | |
|                 {
 | |
|                   "actionId": "plugin::content-manager.explorer.read",
 | |
|                   "applyToProperties": [
 | |
|                     "fields",
 | |
|                     "locales",
 | |
|                   ],
 | |
|                   "label": "Read",
 | |
|                   "subjects": [
 | |
|                     "plugin::users-permissions.user",
 | |
|                   ],
 | |
|                 },
 | |
|                 {
 | |
|                   "actionId": "plugin::content-manager.explorer.update",
 | |
|                   "applyToProperties": [
 | |
|                     "fields",
 | |
|                     "locales",
 | |
|                   ],
 | |
|                   "label": "Update",
 | |
|                   "subjects": [
 | |
|                     "plugin::users-permissions.user",
 | |
|                   ],
 | |
|                 },
 | |
|                 {
 | |
|                   "actionId": "plugin::content-manager.explorer.delete",
 | |
|                   "applyToProperties": [
 | |
|                     "locales",
 | |
|                   ],
 | |
|                   "label": "Delete",
 | |
|                   "subjects": [
 | |
|                     "plugin::users-permissions.user",
 | |
|                   ],
 | |
|                 },
 | |
|                 {
 | |
|                   "actionId": "plugin::content-manager.explorer.publish",
 | |
|                   "applyToProperties": [
 | |
|                     "locales",
 | |
|                   ],
 | |
|                   "label": "Publish",
 | |
|                   "subjects": [],
 | |
|                 },
 | |
|               ],
 | |
|               [],
 | |
|             ],
 | |
|           },
 | |
|         }
 | |
|       `);
 | |
|     }
 | |
|   });
 | |
| });
 | 
