@strapi/admin 5.46.0 → 5.47.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/admin/admin/src/StrapiApp.js +2 -1
- package/dist/admin/admin/src/StrapiApp.js.map +1 -1
- package/dist/admin/admin/src/StrapiApp.mjs +2 -1
- package/dist/admin/admin/src/StrapiApp.mjs.map +1 -1
- package/dist/admin/admin/src/components/FormInputs/Date.js +2 -0
- package/dist/admin/admin/src/components/FormInputs/Date.js.map +1 -1
- package/dist/admin/admin/src/components/FormInputs/Date.mjs +2 -0
- package/dist/admin/admin/src/components/FormInputs/Date.mjs.map +1 -1
- package/dist/admin/admin/src/components/FormInputs/DateTime.js +2 -0
- package/dist/admin/admin/src/components/FormInputs/DateTime.js.map +1 -1
- package/dist/admin/admin/src/components/FormInputs/DateTime.mjs +2 -0
- package/dist/admin/admin/src/components/FormInputs/DateTime.mjs.map +1 -1
- package/dist/admin/admin/src/components/Layouts/HeaderLayout.js +51 -8
- package/dist/admin/admin/src/components/Layouts/HeaderLayout.js.map +1 -1
- package/dist/admin/admin/src/components/Layouts/HeaderLayout.mjs +52 -9
- package/dist/admin/admin/src/components/Layouts/HeaderLayout.mjs.map +1 -1
- package/dist/admin/admin/src/components/Layouts/utils/getMatchingDocLink.js +167 -0
- package/dist/admin/admin/src/components/Layouts/utils/getMatchingDocLink.js.map +1 -0
- package/dist/admin/admin/src/components/Layouts/utils/getMatchingDocLink.mjs +165 -0
- package/dist/admin/admin/src/components/Layouts/utils/getMatchingDocLink.mjs.map +1 -0
- package/dist/admin/admin/src/constants.js +13 -11
- package/dist/admin/admin/src/constants.js.map +1 -1
- package/dist/admin/admin/src/constants.mjs +13 -11
- package/dist/admin/admin/src/constants.mjs.map +1 -1
- package/dist/admin/admin/src/features/Auth.js +25 -0
- package/dist/admin/admin/src/features/Auth.js.map +1 -1
- package/dist/admin/admin/src/features/Auth.mjs +26 -1
- package/dist/admin/admin/src/features/Auth.mjs.map +1 -1
- package/dist/admin/admin/src/features/Tracking.js.map +1 -1
- package/dist/admin/admin/src/features/Tracking.mjs.map +1 -1
- package/dist/admin/admin/src/hooks/useIdleSessionLogout.js +62 -0
- package/dist/admin/admin/src/hooks/useIdleSessionLogout.js.map +1 -0
- package/dist/admin/admin/src/hooks/useIdleSessionLogout.mjs +40 -0
- package/dist/admin/admin/src/hooks/useIdleSessionLogout.mjs.map +1 -0
- package/dist/admin/admin/src/pages/Settings/constants.js +1 -2
- package/dist/admin/admin/src/pages/Settings/constants.js.map +1 -1
- package/dist/admin/admin/src/pages/Settings/constants.mjs +1 -2
- package/dist/admin/admin/src/pages/Settings/constants.mjs.map +1 -1
- package/dist/admin/admin/src/render.js +2 -1
- package/dist/admin/admin/src/render.js.map +1 -1
- package/dist/admin/admin/src/render.mjs +2 -1
- package/dist/admin/admin/src/render.mjs.map +1 -1
- package/dist/admin/admin/src/translations/en.json.js +1 -0
- package/dist/admin/admin/src/translations/en.json.js.map +1 -1
- package/dist/admin/admin/src/translations/en.json.mjs +1 -0
- package/dist/admin/admin/src/translations/en.json.mjs.map +1 -1
- package/dist/admin/admin/src/translations/sk.json.js +446 -42
- package/dist/admin/admin/src/translations/sk.json.js.map +1 -1
- package/dist/admin/admin/src/translations/sk.json.mjs +445 -43
- package/dist/admin/admin/src/translations/sk.json.mjs.map +1 -1
- package/dist/admin/admin/src/utils/baseQuery.js +5 -0
- package/dist/admin/admin/src/utils/baseQuery.js.map +1 -1
- package/dist/admin/admin/src/utils/baseQuery.mjs +6 -1
- package/dist/admin/admin/src/utils/baseQuery.mjs.map +1 -1
- package/dist/admin/admin/src/utils/getFetchClient.js +24 -0
- package/dist/admin/admin/src/utils/getFetchClient.js.map +1 -1
- package/dist/admin/admin/src/utils/getFetchClient.mjs +23 -1
- package/dist/admin/admin/src/utils/getFetchClient.mjs.map +1 -1
- package/dist/admin/admin/src/utils/jwt.js +37 -0
- package/dist/admin/admin/src/utils/jwt.js.map +1 -0
- package/dist/admin/admin/src/utils/jwt.mjs +35 -0
- package/dist/admin/admin/src/utils/jwt.mjs.map +1 -0
- package/dist/admin/index.js +2 -0
- package/dist/admin/index.js.map +1 -1
- package/dist/admin/index.mjs +1 -1
- package/dist/admin/src/components/Layouts/HeaderLayout.d.ts +2 -0
- package/dist/admin/src/components/Layouts/utils/getMatchingDocLink.d.ts +6 -0
- package/dist/admin/src/components/SubNav.d.ts +12 -4
- package/dist/admin/src/constants.d.ts +6 -0
- package/dist/admin/src/features/Tracking.d.ts +8 -1
- package/dist/admin/src/hooks/useAdminRoles.d.ts +1 -1
- package/dist/admin/src/hooks/useIdleSessionLogout.d.ts +33 -0
- package/dist/admin/src/layouts/UnauthenticatedLayout.d.ts +4 -2
- package/dist/admin/src/pages/Settings/pages/Roles/components/CollapseLabel.d.ts +7 -3
- package/dist/admin/src/pages/Settings/pages/Roles/components/ConditionsButton.d.ts +4 -2
- package/dist/admin/src/pages/Settings/pages/Roles/components/HiddenAction.d.ts +1 -1
- package/dist/admin/src/services/admin.d.ts +6 -6
- package/dist/admin/src/services/contentApi.d.ts +1 -1
- package/dist/admin/src/services/users.d.ts +8 -8
- package/dist/admin/src/utils/getFetchClient.d.ts +15 -1
- package/dist/admin/src/utils/jwt.d.ts +15 -0
- package/dist/server/server/src/bootstrap.js +3 -2
- package/dist/server/server/src/bootstrap.js.map +1 -1
- package/dist/server/server/src/bootstrap.mjs +4 -3
- package/dist/server/server/src/bootstrap.mjs.map +1 -1
- package/dist/server/server/src/policies/index.js +0 -2
- package/dist/server/server/src/policies/index.js.map +1 -1
- package/dist/server/server/src/policies/index.mjs +0 -2
- package/dist/server/server/src/policies/index.mjs.map +1 -1
- package/dist/server/server/src/register.js +1 -1
- package/dist/server/server/src/register.js.map +1 -1
- package/dist/server/server/src/routes/admin-tokens.js +0 -7
- package/dist/server/server/src/routes/admin-tokens.js.map +1 -1
- package/dist/server/server/src/routes/admin-tokens.mjs +0 -7
- package/dist/server/server/src/routes/admin-tokens.mjs.map +1 -1
- package/dist/server/server/src/routes/serve-admin-panel.js +8 -1
- package/dist/server/server/src/routes/serve-admin-panel.js.map +1 -1
- package/dist/server/server/src/routes/serve-admin-panel.mjs +6 -2
- package/dist/server/server/src/routes/serve-admin-panel.mjs.map +1 -1
- package/dist/server/server/src/services/api-token.js +71 -1
- package/dist/server/server/src/services/api-token.js.map +1 -1
- package/dist/server/server/src/services/api-token.mjs +71 -2
- package/dist/server/server/src/services/api-token.mjs.map +1 -1
- package/dist/server/server/src/services/token.js +11 -0
- package/dist/server/server/src/services/token.js.map +1 -1
- package/dist/server/server/src/services/token.mjs +11 -1
- package/dist/server/server/src/services/token.mjs.map +1 -1
- package/dist/server/server/src/strategies/admin-token.js +5 -63
- package/dist/server/server/src/strategies/admin-token.js.map +1 -1
- package/dist/server/server/src/strategies/admin-token.mjs +6 -64
- package/dist/server/server/src/strategies/admin-token.mjs.map +1 -1
- package/dist/server/src/bootstrap.d.ts.map +1 -1
- package/dist/server/src/index.d.ts +0 -5
- package/dist/server/src/index.d.ts.map +1 -1
- package/dist/server/src/policies/index.d.ts +0 -5
- package/dist/server/src/policies/index.d.ts.map +1 -1
- package/dist/server/src/routes/admin-tokens.d.ts.map +1 -1
- package/dist/server/src/routes/serve-admin-panel.d.ts +2 -0
- package/dist/server/src/routes/serve-admin-panel.d.ts.map +1 -1
- package/dist/server/src/services/api-token.d.ts +15 -1
- package/dist/server/src/services/api-token.d.ts.map +1 -1
- package/dist/server/src/services/token.d.ts +7 -1
- package/dist/server/src/services/token.d.ts.map +1 -1
- package/dist/server/src/strategies/admin-token.d.ts +12 -22
- package/dist/server/src/strategies/admin-token.d.ts.map +1 -1
- package/package.json +10 -10
- package/dist/server/server/src/policies/isAdminTokensEnabled.js +0 -16
- package/dist/server/server/src/policies/isAdminTokensEnabled.js.map +0 -1
- package/dist/server/server/src/policies/isAdminTokensEnabled.mjs +0 -14
- package/dist/server/server/src/policies/isAdminTokensEnabled.mjs.map +0 -1
- package/dist/server/src/policies/isAdminTokensEnabled.d.ts +0 -7
- package/dist/server/src/policies/isAdminTokensEnabled.d.ts.map +0 -1
|
@@ -0,0 +1,165 @@
|
|
|
1
|
+
import { matchRoutes } from 'react-router-dom';
|
|
2
|
+
|
|
3
|
+
const matchingLinks = [
|
|
4
|
+
{
|
|
5
|
+
path: '/content-manager/*',
|
|
6
|
+
link: 'https://docs.strapi.io/cms/features/content-manager',
|
|
7
|
+
title: 'Content Manager'
|
|
8
|
+
},
|
|
9
|
+
{
|
|
10
|
+
path: '/plugins/content-type-builder/*',
|
|
11
|
+
link: 'https://docs.strapi.io/cms/features/content-type-builder',
|
|
12
|
+
title: 'Content-Type Builder'
|
|
13
|
+
},
|
|
14
|
+
{
|
|
15
|
+
path: '/plugins/upload/*',
|
|
16
|
+
link: 'https://docs.strapi.io/cms/features/media-library',
|
|
17
|
+
title: 'Media Library'
|
|
18
|
+
},
|
|
19
|
+
{
|
|
20
|
+
path: '/plugins/content-releases/*',
|
|
21
|
+
link: 'https://docs.strapi.io/cms/features/releases',
|
|
22
|
+
title: 'Releases'
|
|
23
|
+
},
|
|
24
|
+
{
|
|
25
|
+
path: '/settings/purchase-content-releases/*',
|
|
26
|
+
link: 'https://docs.strapi.io/cms/features/releases',
|
|
27
|
+
title: 'Releases'
|
|
28
|
+
},
|
|
29
|
+
{
|
|
30
|
+
path: '/plugins/documentation/*',
|
|
31
|
+
link: 'https://docs.strapi.io/cms/plugins/documentation',
|
|
32
|
+
title: 'Documentation plugin'
|
|
33
|
+
},
|
|
34
|
+
{
|
|
35
|
+
path: '/settings/list-plugins/*',
|
|
36
|
+
link: 'https://docs.strapi.io/cms/plugins-development/developing-plugins',
|
|
37
|
+
title: 'Plugins'
|
|
38
|
+
},
|
|
39
|
+
{
|
|
40
|
+
path: '/settings/application-infos/*',
|
|
41
|
+
link: 'https://docs.strapi.io/cms/features/admin-panel',
|
|
42
|
+
title: 'General settings'
|
|
43
|
+
},
|
|
44
|
+
{
|
|
45
|
+
path: '/settings/api-tokens/*',
|
|
46
|
+
link: 'https://docs.strapi.io/cms/features/api-tokens',
|
|
47
|
+
title: 'API Tokens settings'
|
|
48
|
+
},
|
|
49
|
+
{
|
|
50
|
+
path: '/settings/documentation/*',
|
|
51
|
+
link: 'https://docs.strapi.io/cms/plugins/documentation',
|
|
52
|
+
title: 'Documentation plugin settings'
|
|
53
|
+
},
|
|
54
|
+
{
|
|
55
|
+
path: '/settings/internationalization/*',
|
|
56
|
+
link: 'https://docs.strapi.io/cms/features/internationalization#settings',
|
|
57
|
+
title: 'Internationalization settings (i18n)'
|
|
58
|
+
},
|
|
59
|
+
{
|
|
60
|
+
path: '/settings/media-library/*',
|
|
61
|
+
link: 'https://docs.strapi.io/cms/features/media-library#configuration',
|
|
62
|
+
title: 'Media Library settings'
|
|
63
|
+
},
|
|
64
|
+
{
|
|
65
|
+
path: '/settings/review-workflows/*',
|
|
66
|
+
link: 'https://docs.strapi.io/cms/features/review-workflows',
|
|
67
|
+
title: 'Review Workflows settings'
|
|
68
|
+
},
|
|
69
|
+
{
|
|
70
|
+
path: '/settings/purchase-review-workflows/*',
|
|
71
|
+
link: 'https://docs.strapi.io/cms/features/review-workflows',
|
|
72
|
+
title: 'Review Workflows settings'
|
|
73
|
+
},
|
|
74
|
+
{
|
|
75
|
+
path: '/settings/single-sign-on/*',
|
|
76
|
+
link: 'https://docs.strapi.io/cms/features/sso',
|
|
77
|
+
title: 'SSO settings'
|
|
78
|
+
},
|
|
79
|
+
{
|
|
80
|
+
path: '/settings/purchase-single-sign-on/*',
|
|
81
|
+
link: 'https://docs.strapi.io/cms/features/sso',
|
|
82
|
+
title: 'SSO settings'
|
|
83
|
+
},
|
|
84
|
+
{
|
|
85
|
+
path: '/settings/purchase-content-history/*',
|
|
86
|
+
link: 'https://docs.strapi.io/cms/features/content-history',
|
|
87
|
+
title: 'Content History'
|
|
88
|
+
},
|
|
89
|
+
{
|
|
90
|
+
path: '/settings/transfer-tokens/*',
|
|
91
|
+
link: 'https://docs.strapi.io/cms/features/data-management',
|
|
92
|
+
title: 'Transfer Tokens'
|
|
93
|
+
},
|
|
94
|
+
{
|
|
95
|
+
path: '/settings/webhooks/*',
|
|
96
|
+
link: 'https://docs.strapi.io/cms/backend-customization/webhooks',
|
|
97
|
+
title: 'Webhooks'
|
|
98
|
+
},
|
|
99
|
+
{
|
|
100
|
+
path: '/settings/roles/*',
|
|
101
|
+
link: 'https://docs.strapi.io/cms/features/rbac#configuration',
|
|
102
|
+
title: 'Users & Permissions'
|
|
103
|
+
},
|
|
104
|
+
{
|
|
105
|
+
path: '/settings/users/*',
|
|
106
|
+
link: 'https://docs.strapi.io/cms/features/rbac#usage',
|
|
107
|
+
title: 'Users & Permissions'
|
|
108
|
+
},
|
|
109
|
+
{
|
|
110
|
+
path: '/settings/audit-logs/*',
|
|
111
|
+
link: 'https://docs.strapi.io/cms/features/audit-logs',
|
|
112
|
+
title: 'Audit Logs'
|
|
113
|
+
},
|
|
114
|
+
{
|
|
115
|
+
path: '/settings/purchase-audit-logs/*',
|
|
116
|
+
link: 'https://docs.strapi.io/cms/features/audit-logs',
|
|
117
|
+
title: 'Audit Logs'
|
|
118
|
+
},
|
|
119
|
+
{
|
|
120
|
+
path: '/settings/email/*',
|
|
121
|
+
link: 'https://docs.strapi.io/cms/features/email',
|
|
122
|
+
title: 'Email plugin'
|
|
123
|
+
},
|
|
124
|
+
{
|
|
125
|
+
path: '/settings/users-permissions/roles/*',
|
|
126
|
+
link: 'https://docs.strapi.io/cms/features/users-permissions',
|
|
127
|
+
title: 'End-users roles'
|
|
128
|
+
},
|
|
129
|
+
{
|
|
130
|
+
path: '/settings/users-permissions/providers/*',
|
|
131
|
+
link: 'https://docs.strapi.io/cms/features/users-permissions#providers',
|
|
132
|
+
title: 'Providers'
|
|
133
|
+
},
|
|
134
|
+
{
|
|
135
|
+
path: '/settings/users-permissions/email-templates/*',
|
|
136
|
+
link: 'https://docs.strapi.io/cms/features/users-permissions#email-templates',
|
|
137
|
+
title: 'Email Templates'
|
|
138
|
+
},
|
|
139
|
+
{
|
|
140
|
+
path: '/settings/users-permissions/advanced-settings/*',
|
|
141
|
+
link: 'https://docs.strapi.io/cms/features/users-permissions#advanced-settings',
|
|
142
|
+
title: 'U&P Advanced settings'
|
|
143
|
+
},
|
|
144
|
+
{
|
|
145
|
+
path: '/me/*',
|
|
146
|
+
link: 'https://docs.strapi.io/cms/features/admin-panel#modifying-profile-information-name-email-username',
|
|
147
|
+
title: 'Administrator profile'
|
|
148
|
+
}
|
|
149
|
+
];
|
|
150
|
+
function getMatchingDocLink(pathname) {
|
|
151
|
+
const matches = matchRoutes(matchingLinks, pathname);
|
|
152
|
+
const match = matches?.[0];
|
|
153
|
+
if (!match) {
|
|
154
|
+
return null;
|
|
155
|
+
}
|
|
156
|
+
const { link, title } = match.route;
|
|
157
|
+
return {
|
|
158
|
+
path: match.pathnameBase,
|
|
159
|
+
link,
|
|
160
|
+
title
|
|
161
|
+
};
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
export { getMatchingDocLink };
|
|
165
|
+
//# sourceMappingURL=getMatchingDocLink.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getMatchingDocLink.mjs","sources":["../../../../../../../admin/src/components/Layouts/utils/getMatchingDocLink.ts"],"sourcesContent":["import { matchRoutes, RouteObject } from 'react-router-dom';\n\nexport interface DocLink {\n link: string;\n title: string;\n path: string;\n}\n\ntype DocRoute = RouteObject & { link: string; title: string };\n\nconst matchingLinks: DocRoute[] = [\n {\n path: '/content-manager/*',\n link: 'https://docs.strapi.io/cms/features/content-manager',\n title: 'Content Manager',\n },\n {\n path: '/plugins/content-type-builder/*',\n link: 'https://docs.strapi.io/cms/features/content-type-builder',\n title: 'Content-Type Builder',\n },\n {\n path: '/plugins/upload/*',\n link: 'https://docs.strapi.io/cms/features/media-library',\n title: 'Media Library',\n },\n {\n path: '/plugins/content-releases/*',\n link: 'https://docs.strapi.io/cms/features/releases',\n title: 'Releases',\n },\n {\n path: '/settings/purchase-content-releases/*',\n link: 'https://docs.strapi.io/cms/features/releases',\n title: 'Releases',\n },\n {\n path: '/plugins/documentation/*',\n link: 'https://docs.strapi.io/cms/plugins/documentation',\n title: 'Documentation plugin',\n },\n {\n path: '/settings/list-plugins/*',\n link: 'https://docs.strapi.io/cms/plugins-development/developing-plugins',\n title: 'Plugins',\n },\n {\n path: '/settings/application-infos/*',\n link: 'https://docs.strapi.io/cms/features/admin-panel',\n title: 'General settings',\n },\n {\n path: '/settings/api-tokens/*',\n link: 'https://docs.strapi.io/cms/features/api-tokens',\n title: 'API Tokens settings',\n },\n {\n path: '/settings/documentation/*',\n link: 'https://docs.strapi.io/cms/plugins/documentation',\n title: 'Documentation plugin settings',\n },\n {\n path: '/settings/internationalization/*',\n link: 'https://docs.strapi.io/cms/features/internationalization#settings',\n title: 'Internationalization settings (i18n)',\n },\n {\n path: '/settings/media-library/*',\n link: 'https://docs.strapi.io/cms/features/media-library#configuration',\n title: 'Media Library settings',\n },\n {\n path: '/settings/review-workflows/*',\n link: 'https://docs.strapi.io/cms/features/review-workflows',\n title: 'Review Workflows settings',\n },\n {\n path: '/settings/purchase-review-workflows/*',\n link: 'https://docs.strapi.io/cms/features/review-workflows',\n title: 'Review Workflows settings',\n },\n {\n path: '/settings/single-sign-on/*',\n link: 'https://docs.strapi.io/cms/features/sso',\n title: 'SSO settings',\n },\n {\n path: '/settings/purchase-single-sign-on/*',\n link: 'https://docs.strapi.io/cms/features/sso',\n title: 'SSO settings',\n },\n {\n path: '/settings/purchase-content-history/*',\n link: 'https://docs.strapi.io/cms/features/content-history',\n title: 'Content History',\n },\n {\n path: '/settings/transfer-tokens/*',\n link: 'https://docs.strapi.io/cms/features/data-management',\n title: 'Transfer Tokens',\n },\n {\n path: '/settings/webhooks/*',\n link: 'https://docs.strapi.io/cms/backend-customization/webhooks',\n title: 'Webhooks',\n },\n {\n path: '/settings/roles/*',\n link: 'https://docs.strapi.io/cms/features/rbac#configuration',\n title: 'Users & Permissions',\n },\n {\n path: '/settings/users/*',\n link: 'https://docs.strapi.io/cms/features/rbac#usage',\n title: 'Users & Permissions',\n },\n {\n path: '/settings/audit-logs/*',\n link: 'https://docs.strapi.io/cms/features/audit-logs',\n title: 'Audit Logs',\n },\n {\n path: '/settings/purchase-audit-logs/*',\n link: 'https://docs.strapi.io/cms/features/audit-logs',\n title: 'Audit Logs',\n },\n {\n path: '/settings/email/*',\n link: 'https://docs.strapi.io/cms/features/email',\n title: 'Email plugin',\n },\n {\n path: '/settings/users-permissions/roles/*',\n link: 'https://docs.strapi.io/cms/features/users-permissions',\n title: 'End-users roles',\n },\n {\n path: '/settings/users-permissions/providers/*',\n link: 'https://docs.strapi.io/cms/features/users-permissions#providers',\n title: 'Providers',\n },\n {\n path: '/settings/users-permissions/email-templates/*',\n link: 'https://docs.strapi.io/cms/features/users-permissions#email-templates',\n title: 'Email Templates',\n },\n {\n path: '/settings/users-permissions/advanced-settings/*',\n link: 'https://docs.strapi.io/cms/features/users-permissions#advanced-settings',\n title: 'U&P Advanced settings',\n },\n {\n path: '/me/*',\n link: 'https://docs.strapi.io/cms/features/admin-panel#modifying-profile-information-name-email-username',\n title: 'Administrator profile',\n },\n];\n\nexport function getMatchingDocLink(pathname: string): DocLink | null {\n const matches = matchRoutes(matchingLinks, pathname);\n const match = matches?.[0];\n\n if (!match) {\n return null;\n }\n\n const { link, title } = match.route;\n return { path: match.pathnameBase, link, title };\n}\n"],"names":["matchingLinks","path","link","title","getMatchingDocLink","pathname","matches","matchRoutes","match","route","pathnameBase"],"mappings":"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"}
|
|
@@ -329,6 +329,11 @@ const HOOKS = {
|
|
|
329
329
|
* @type {string}
|
|
330
330
|
*/ INJECT_COLUMN_IN_TABLE: 'Admin/CM/pages/ListView/inject-column-in-table',
|
|
331
331
|
/**
|
|
332
|
+
* Hook that allows to mutate the displayed filters of the list view
|
|
333
|
+
* @constant
|
|
334
|
+
* @type {string}
|
|
335
|
+
*/ INJECT_LIST_VIEW_FILTERS: 'Admin/CM/pages/ListView/inject-in-filters',
|
|
336
|
+
/**
|
|
332
337
|
* Hook that allows to mutate the CM's collection types links pre-set filters
|
|
333
338
|
* @constant
|
|
334
339
|
* @type {string}
|
|
@@ -344,7 +349,6 @@ const HOOKS = {
|
|
|
344
349
|
* @type {string}
|
|
345
350
|
*/ MUTATE_SINGLE_TYPES_LINKS: 'Admin/CM/pages/App/mutate-single-types-links'
|
|
346
351
|
};
|
|
347
|
-
const isAdminTokensFutureEnabled = ()=>window.strapi.future.isEnabled('adminTokens') === true;
|
|
348
352
|
const SETTINGS_LINKS_CE = ()=>({
|
|
349
353
|
global: [
|
|
350
354
|
{
|
|
@@ -430,16 +434,14 @@ const SETTINGS_LINKS_CE = ()=>({
|
|
|
430
434
|
to: '/settings/users?pageSize=10&page=1&sort=firstname',
|
|
431
435
|
id: 'users'
|
|
432
436
|
},
|
|
433
|
-
|
|
434
|
-
{
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
|
|
440
|
-
|
|
441
|
-
}
|
|
442
|
-
] : [],
|
|
437
|
+
{
|
|
438
|
+
intlLabel: {
|
|
439
|
+
id: 'Settings.adminTokens.title',
|
|
440
|
+
defaultMessage: 'Admin Tokens'
|
|
441
|
+
},
|
|
442
|
+
to: '/settings/admin-tokens',
|
|
443
|
+
id: 'admin-tokens'
|
|
444
|
+
},
|
|
443
445
|
...!window.strapi.features.isEnabled(window.strapi.features.AUDIT_LOGS) && window.strapi?.flags?.promoteEE ? [
|
|
444
446
|
{
|
|
445
447
|
intlLabel: {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"constants.js","sources":["../../../../admin/src/constants.ts"],"sourcesContent":["import { PermissionMap } from './types/permissions';\n\nimport type { StrapiAppSettingLink } from './core/apis/router';\n\nexport const ADMIN_PERMISSIONS_CE = {\n contentManager: {\n main: [],\n collectionTypesConfigurations: [\n {\n action: 'plugin::content-manager.collection-types.configure-view',\n subject: null,\n },\n ],\n componentsConfigurations: [\n {\n action: 'plugin::content-manager.components.configure-layout',\n subject: null,\n },\n ],\n singleTypesConfigurations: [\n {\n action: 'plugin::content-manager.single-types.configure-view',\n subject: null,\n },\n ],\n },\n marketplace: {\n main: [{ action: 'admin::marketplace.read', subject: null }],\n read: [{ action: 'admin::marketplace.read', subject: null }],\n },\n settings: {\n roles: {\n main: [\n { action: 'admin::roles.create', subject: null },\n { action: 'admin::roles.update', subject: null },\n { action: 'admin::roles.read', subject: null },\n { action: 'admin::roles.delete', subject: null },\n ],\n create: [{ action: 'admin::roles.create', subject: null }],\n delete: [{ action: 'admin::roles.delete', subject: null }],\n read: [{ action: 'admin::roles.read', subject: null }],\n update: [{ action: 'admin::roles.update', subject: null }],\n },\n users: {\n main: [\n { action: 'admin::users.create', subject: null },\n { action: 'admin::users.read', subject: null },\n { action: 'admin::users.update', subject: null },\n { action: 'admin::users.delete', subject: null },\n ],\n create: [{ action: 'admin::users.create', subject: null }],\n delete: [{ action: 'admin::users.delete', subject: null }],\n read: [{ action: 'admin::users.read', subject: null }],\n update: [{ action: 'admin::users.update', subject: null }],\n },\n webhooks: {\n main: [\n { action: 'admin::webhooks.create', subject: null },\n { action: 'admin::webhooks.read', subject: null },\n { action: 'admin::webhooks.update', subject: null },\n { action: 'admin::webhooks.delete', subject: null },\n ],\n create: [{ action: 'admin::webhooks.create', subject: null }],\n delete: [{ action: 'admin::webhooks.delete', subject: null }],\n read: [\n { action: 'admin::webhooks.read', subject: null },\n // NOTE: We need to check with the API\n { action: 'admin::webhooks.update', subject: null },\n { action: 'admin::webhooks.delete', subject: null },\n ],\n update: [{ action: 'admin::webhooks.update', subject: null }],\n },\n 'admin-tokens': {\n main: [{ action: 'admin::admin-tokens.access', subject: null }],\n create: [{ action: 'admin::admin-tokens.create', subject: null }],\n delete: [{ action: 'admin::admin-tokens.delete', subject: null }],\n read: [{ action: 'admin::admin-tokens.read', subject: null }],\n update: [{ action: 'admin::admin-tokens.update', subject: null }],\n regenerate: [{ action: 'admin::admin-tokens.regenerate', subject: null }],\n },\n 'api-tokens': {\n main: [{ action: 'admin::api-tokens.access', subject: null }],\n create: [{ action: 'admin::api-tokens.create', subject: null }],\n delete: [{ action: 'admin::api-tokens.delete', subject: null }],\n read: [{ action: 'admin::api-tokens.read', subject: null }],\n update: [{ action: 'admin::api-tokens.update', subject: null }],\n regenerate: [{ action: 'admin::api-tokens.regenerate', subject: null }],\n },\n 'transfer-tokens': {\n main: [{ action: 'admin::transfer.tokens.access', subject: null }],\n create: [{ action: 'admin::transfer.tokens.create', subject: null }],\n delete: [{ action: 'admin::transfer.tokens.delete', subject: null }],\n read: [{ action: 'admin::transfer.tokens.read', subject: null }],\n update: [{ action: 'admin::transfer.tokens.update', subject: null }],\n regenerate: [{ action: 'admin::transfer.tokens.regenerate', subject: null }],\n },\n 'project-settings': {\n read: [{ action: 'admin::project-settings.read', subject: null }],\n update: [{ action: 'admin::project-settings.update', subject: null }],\n },\n plugins: {\n main: [{ action: 'admin::marketplace.read', subject: null }],\n read: [{ action: 'admin::marketplace.read', subject: null }],\n },\n },\n} satisfies Partial<PermissionMap>;\n\nexport const HOOKS = {\n /**\n * Hook that allows to mutate the displayed headers of the list view table\n * @constant\n * @type {string}\n */\n INJECT_COLUMN_IN_TABLE: 'Admin/CM/pages/ListView/inject-column-in-table',\n\n /**\n * Hook that allows to mutate the CM's collection types links pre-set filters\n * @constant\n * @type {string}\n */\n MUTATE_COLLECTION_TYPES_LINKS: 'Admin/CM/pages/App/mutate-collection-types-links',\n\n /**\n * Hook that allows to mutate the CM's edit view layout\n * @constant\n * @type {string}\n */\n MUTATE_EDIT_VIEW_LAYOUT: 'Admin/CM/pages/EditView/mutate-edit-view-layout',\n\n /**\n * Hook that allows to mutate the CM's single types links pre-set filters\n * @constant\n * @type {string}\n */\n MUTATE_SINGLE_TYPES_LINKS: 'Admin/CM/pages/App/mutate-single-types-links',\n};\n\nexport interface SettingsMenuLink\n extends Omit<StrapiAppSettingLink, 'Component' | 'permissions' | 'licenseOnly'> {\n licenseOnly?: boolean;\n}\n\nexport type SettingsMenu = {\n admin: SettingsMenuLink[];\n global: SettingsMenuLink[];\n};\n\nconst isAdminTokensFutureEnabled = () => window.strapi.future.isEnabled('adminTokens') === true;\n\nexport const SETTINGS_LINKS_CE = (): SettingsMenu => ({\n global: [\n {\n intlLabel: { id: 'Settings.application.title', defaultMessage: 'Overview' },\n to: '/settings/application-infos',\n id: '000-application-infos',\n },\n {\n intlLabel: { id: 'Settings.webhooks.title', defaultMessage: 'Webhooks' },\n to: '/settings/webhooks',\n id: 'webhooks',\n },\n {\n intlLabel: { id: 'Settings.apiTokens.title', defaultMessage: 'API Tokens' },\n to: '/settings/api-tokens?sort=name:ASC',\n id: 'api-tokens',\n },\n {\n intlLabel: { id: 'Settings.transferTokens.title', defaultMessage: 'Transfer Tokens' },\n to: '/settings/transfer-tokens?sort=name:ASC',\n id: 'transfer-tokens',\n },\n {\n intlLabel: {\n id: 'global.plugins',\n defaultMessage: 'Plugins',\n },\n to: '/settings/list-plugins',\n id: 'plugins',\n },\n // If the Enterprise/Cloud feature is not enabled and if the config doesn't disable it, we promote the Enterprise/Cloud feature by displaying them in the settings menu.\n // Disable this by adding \"promoteEE: false\" to your `./config/admin.js` file\n ...(!window.strapi.features.isEnabled(window.strapi.features.SSO) &&\n window.strapi?.flags?.promoteEE\n ? [\n {\n intlLabel: { id: 'Settings.sso.title', defaultMessage: 'Single Sign-On' },\n to: '/settings/purchase-single-sign-on',\n id: 'sso-purchase-page',\n licenseOnly: true,\n },\n ]\n : []),\n ...(!window.strapi.features.isEnabled('cms-content-history') && window.strapi?.flags?.promoteEE\n ? [\n {\n intlLabel: { id: 'Settings.content-history.title', defaultMessage: 'Content History' },\n to: '/settings/purchase-content-history',\n id: 'content-history-purchase-page',\n licenseOnly: true,\n },\n ]\n : []),\n ],\n\n admin: [\n {\n intlLabel: { id: 'global.roles', defaultMessage: 'Roles' },\n to: '/settings/roles',\n id: 'roles',\n },\n {\n intlLabel: { id: 'global.users', defaultMessage: 'Users' },\n // Init the search params directly\n to: '/settings/users?pageSize=10&page=1&sort=firstname',\n id: 'users',\n },\n ...(isAdminTokensFutureEnabled() === true\n ? [\n {\n intlLabel: { id: 'Settings.adminTokens.title', defaultMessage: 'Admin Tokens' },\n to: '/settings/admin-tokens',\n id: 'admin-tokens',\n },\n ]\n : []),\n ...(!window.strapi.features.isEnabled(window.strapi.features.AUDIT_LOGS) &&\n window.strapi?.flags?.promoteEE\n ? [\n {\n intlLabel: { id: 'global.auditLogs', defaultMessage: 'Audit Logs' },\n to: '/settings/purchase-audit-logs',\n id: 'auditLogs-purchase-page',\n licenseOnly: true,\n },\n ]\n : []),\n ],\n});\n"],"names":["ADMIN_PERMISSIONS_CE","contentManager","main","collectionTypesConfigurations","action","subject","componentsConfigurations","singleTypesConfigurations","marketplace","read","settings","roles","create","delete","update","users","webhooks","regenerate","plugins","HOOKS","INJECT_COLUMN_IN_TABLE","MUTATE_COLLECTION_TYPES_LINKS","MUTATE_EDIT_VIEW_LAYOUT","MUTATE_SINGLE_TYPES_LINKS","isAdminTokensFutureEnabled","window","strapi","future","isEnabled","SETTINGS_LINKS_CE","global","intlLabel","id","defaultMessage","to","features","SSO","flags","promoteEE","licenseOnly","admin","AUDIT_LOGS"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"constants.js","sources":["../../../../admin/src/constants.ts"],"sourcesContent":["import { PermissionMap } from './types/permissions';\n\nimport type { StrapiAppSettingLink } from './core/apis/router';\n\nexport const ADMIN_PERMISSIONS_CE = {\n contentManager: {\n main: [],\n collectionTypesConfigurations: [\n {\n action: 'plugin::content-manager.collection-types.configure-view',\n subject: null,\n },\n ],\n componentsConfigurations: [\n {\n action: 'plugin::content-manager.components.configure-layout',\n subject: null,\n },\n ],\n singleTypesConfigurations: [\n {\n action: 'plugin::content-manager.single-types.configure-view',\n subject: null,\n },\n ],\n },\n marketplace: {\n main: [{ action: 'admin::marketplace.read', subject: null }],\n read: [{ action: 'admin::marketplace.read', subject: null }],\n },\n settings: {\n roles: {\n main: [\n { action: 'admin::roles.create', subject: null },\n { action: 'admin::roles.update', subject: null },\n { action: 'admin::roles.read', subject: null },\n { action: 'admin::roles.delete', subject: null },\n ],\n create: [{ action: 'admin::roles.create', subject: null }],\n delete: [{ action: 'admin::roles.delete', subject: null }],\n read: [{ action: 'admin::roles.read', subject: null }],\n update: [{ action: 'admin::roles.update', subject: null }],\n },\n users: {\n main: [\n { action: 'admin::users.create', subject: null },\n { action: 'admin::users.read', subject: null },\n { action: 'admin::users.update', subject: null },\n { action: 'admin::users.delete', subject: null },\n ],\n create: [{ action: 'admin::users.create', subject: null }],\n delete: [{ action: 'admin::users.delete', subject: null }],\n read: [{ action: 'admin::users.read', subject: null }],\n update: [{ action: 'admin::users.update', subject: null }],\n },\n webhooks: {\n main: [\n { action: 'admin::webhooks.create', subject: null },\n { action: 'admin::webhooks.read', subject: null },\n { action: 'admin::webhooks.update', subject: null },\n { action: 'admin::webhooks.delete', subject: null },\n ],\n create: [{ action: 'admin::webhooks.create', subject: null }],\n delete: [{ action: 'admin::webhooks.delete', subject: null }],\n read: [\n { action: 'admin::webhooks.read', subject: null },\n // NOTE: We need to check with the API\n { action: 'admin::webhooks.update', subject: null },\n { action: 'admin::webhooks.delete', subject: null },\n ],\n update: [{ action: 'admin::webhooks.update', subject: null }],\n },\n 'admin-tokens': {\n main: [{ action: 'admin::admin-tokens.access', subject: null }],\n create: [{ action: 'admin::admin-tokens.create', subject: null }],\n delete: [{ action: 'admin::admin-tokens.delete', subject: null }],\n read: [{ action: 'admin::admin-tokens.read', subject: null }],\n update: [{ action: 'admin::admin-tokens.update', subject: null }],\n regenerate: [{ action: 'admin::admin-tokens.regenerate', subject: null }],\n },\n 'api-tokens': {\n main: [{ action: 'admin::api-tokens.access', subject: null }],\n create: [{ action: 'admin::api-tokens.create', subject: null }],\n delete: [{ action: 'admin::api-tokens.delete', subject: null }],\n read: [{ action: 'admin::api-tokens.read', subject: null }],\n update: [{ action: 'admin::api-tokens.update', subject: null }],\n regenerate: [{ action: 'admin::api-tokens.regenerate', subject: null }],\n },\n 'transfer-tokens': {\n main: [{ action: 'admin::transfer.tokens.access', subject: null }],\n create: [{ action: 'admin::transfer.tokens.create', subject: null }],\n delete: [{ action: 'admin::transfer.tokens.delete', subject: null }],\n read: [{ action: 'admin::transfer.tokens.read', subject: null }],\n update: [{ action: 'admin::transfer.tokens.update', subject: null }],\n regenerate: [{ action: 'admin::transfer.tokens.regenerate', subject: null }],\n },\n 'project-settings': {\n read: [{ action: 'admin::project-settings.read', subject: null }],\n update: [{ action: 'admin::project-settings.update', subject: null }],\n },\n plugins: {\n main: [{ action: 'admin::marketplace.read', subject: null }],\n read: [{ action: 'admin::marketplace.read', subject: null }],\n },\n },\n} satisfies Partial<PermissionMap>;\n\nexport const HOOKS = {\n /**\n * Hook that allows to mutate the displayed headers of the list view table\n * @constant\n * @type {string}\n */\n INJECT_COLUMN_IN_TABLE: 'Admin/CM/pages/ListView/inject-column-in-table',\n\n /**\n * Hook that allows to mutate the displayed filters of the list view\n * @constant\n * @type {string}\n */\n INJECT_LIST_VIEW_FILTERS: 'Admin/CM/pages/ListView/inject-in-filters',\n\n /**\n * Hook that allows to mutate the CM's collection types links pre-set filters\n * @constant\n * @type {string}\n */\n MUTATE_COLLECTION_TYPES_LINKS: 'Admin/CM/pages/App/mutate-collection-types-links',\n\n /**\n * Hook that allows to mutate the CM's edit view layout\n * @constant\n * @type {string}\n */\n MUTATE_EDIT_VIEW_LAYOUT: 'Admin/CM/pages/EditView/mutate-edit-view-layout',\n\n /**\n * Hook that allows to mutate the CM's single types links pre-set filters\n * @constant\n * @type {string}\n */\n MUTATE_SINGLE_TYPES_LINKS: 'Admin/CM/pages/App/mutate-single-types-links',\n};\n\nexport interface SettingsMenuLink\n extends Omit<StrapiAppSettingLink, 'Component' | 'permissions' | 'licenseOnly'> {\n licenseOnly?: boolean;\n}\n\nexport type SettingsMenu = {\n admin: SettingsMenuLink[];\n global: SettingsMenuLink[];\n};\n\nexport const SETTINGS_LINKS_CE = (): SettingsMenu => ({\n global: [\n {\n intlLabel: { id: 'Settings.application.title', defaultMessage: 'Overview' },\n to: '/settings/application-infos',\n id: '000-application-infos',\n },\n {\n intlLabel: { id: 'Settings.webhooks.title', defaultMessage: 'Webhooks' },\n to: '/settings/webhooks',\n id: 'webhooks',\n },\n {\n intlLabel: { id: 'Settings.apiTokens.title', defaultMessage: 'API Tokens' },\n to: '/settings/api-tokens?sort=name:ASC',\n id: 'api-tokens',\n },\n {\n intlLabel: { id: 'Settings.transferTokens.title', defaultMessage: 'Transfer Tokens' },\n to: '/settings/transfer-tokens?sort=name:ASC',\n id: 'transfer-tokens',\n },\n {\n intlLabel: {\n id: 'global.plugins',\n defaultMessage: 'Plugins',\n },\n to: '/settings/list-plugins',\n id: 'plugins',\n },\n // If the Enterprise/Cloud feature is not enabled and if the config doesn't disable it, we promote the Enterprise/Cloud feature by displaying them in the settings menu.\n // Disable this by adding \"promoteEE: false\" to your `./config/admin.js` file\n ...(!window.strapi.features.isEnabled(window.strapi.features.SSO) &&\n window.strapi?.flags?.promoteEE\n ? [\n {\n intlLabel: { id: 'Settings.sso.title', defaultMessage: 'Single Sign-On' },\n to: '/settings/purchase-single-sign-on',\n id: 'sso-purchase-page',\n licenseOnly: true,\n },\n ]\n : []),\n ...(!window.strapi.features.isEnabled('cms-content-history') && window.strapi?.flags?.promoteEE\n ? [\n {\n intlLabel: { id: 'Settings.content-history.title', defaultMessage: 'Content History' },\n to: '/settings/purchase-content-history',\n id: 'content-history-purchase-page',\n licenseOnly: true,\n },\n ]\n : []),\n ],\n\n admin: [\n {\n intlLabel: { id: 'global.roles', defaultMessage: 'Roles' },\n to: '/settings/roles',\n id: 'roles',\n },\n {\n intlLabel: { id: 'global.users', defaultMessage: 'Users' },\n // Init the search params directly\n to: '/settings/users?pageSize=10&page=1&sort=firstname',\n id: 'users',\n },\n {\n intlLabel: { id: 'Settings.adminTokens.title', defaultMessage: 'Admin Tokens' },\n to: '/settings/admin-tokens',\n id: 'admin-tokens',\n },\n ...(!window.strapi.features.isEnabled(window.strapi.features.AUDIT_LOGS) &&\n window.strapi?.flags?.promoteEE\n ? [\n {\n intlLabel: { id: 'global.auditLogs', defaultMessage: 'Audit Logs' },\n to: '/settings/purchase-audit-logs',\n id: 'auditLogs-purchase-page',\n licenseOnly: true,\n },\n ]\n : []),\n ],\n});\n"],"names":["ADMIN_PERMISSIONS_CE","contentManager","main","collectionTypesConfigurations","action","subject","componentsConfigurations","singleTypesConfigurations","marketplace","read","settings","roles","create","delete","update","users","webhooks","regenerate","plugins","HOOKS","INJECT_COLUMN_IN_TABLE","INJECT_LIST_VIEW_FILTERS","MUTATE_COLLECTION_TYPES_LINKS","MUTATE_EDIT_VIEW_LAYOUT","MUTATE_SINGLE_TYPES_LINKS","SETTINGS_LINKS_CE","global","intlLabel","id","defaultMessage","to","window","strapi","features","isEnabled","SSO","flags","promoteEE","licenseOnly","admin","AUDIT_LOGS"],"mappings":"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"}
|
|
@@ -327,6 +327,11 @@ const HOOKS = {
|
|
|
327
327
|
* @type {string}
|
|
328
328
|
*/ INJECT_COLUMN_IN_TABLE: 'Admin/CM/pages/ListView/inject-column-in-table',
|
|
329
329
|
/**
|
|
330
|
+
* Hook that allows to mutate the displayed filters of the list view
|
|
331
|
+
* @constant
|
|
332
|
+
* @type {string}
|
|
333
|
+
*/ INJECT_LIST_VIEW_FILTERS: 'Admin/CM/pages/ListView/inject-in-filters',
|
|
334
|
+
/**
|
|
330
335
|
* Hook that allows to mutate the CM's collection types links pre-set filters
|
|
331
336
|
* @constant
|
|
332
337
|
* @type {string}
|
|
@@ -342,7 +347,6 @@ const HOOKS = {
|
|
|
342
347
|
* @type {string}
|
|
343
348
|
*/ MUTATE_SINGLE_TYPES_LINKS: 'Admin/CM/pages/App/mutate-single-types-links'
|
|
344
349
|
};
|
|
345
|
-
const isAdminTokensFutureEnabled = ()=>window.strapi.future.isEnabled('adminTokens') === true;
|
|
346
350
|
const SETTINGS_LINKS_CE = ()=>({
|
|
347
351
|
global: [
|
|
348
352
|
{
|
|
@@ -428,16 +432,14 @@ const SETTINGS_LINKS_CE = ()=>({
|
|
|
428
432
|
to: '/settings/users?pageSize=10&page=1&sort=firstname',
|
|
429
433
|
id: 'users'
|
|
430
434
|
},
|
|
431
|
-
|
|
432
|
-
{
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
}
|
|
440
|
-
] : [],
|
|
435
|
+
{
|
|
436
|
+
intlLabel: {
|
|
437
|
+
id: 'Settings.adminTokens.title',
|
|
438
|
+
defaultMessage: 'Admin Tokens'
|
|
439
|
+
},
|
|
440
|
+
to: '/settings/admin-tokens',
|
|
441
|
+
id: 'admin-tokens'
|
|
442
|
+
},
|
|
441
443
|
...!window.strapi.features.isEnabled(window.strapi.features.AUDIT_LOGS) && window.strapi?.flags?.promoteEE ? [
|
|
442
444
|
{
|
|
443
445
|
intlLabel: {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"constants.mjs","sources":["../../../../admin/src/constants.ts"],"sourcesContent":["import { PermissionMap } from './types/permissions';\n\nimport type { StrapiAppSettingLink } from './core/apis/router';\n\nexport const ADMIN_PERMISSIONS_CE = {\n contentManager: {\n main: [],\n collectionTypesConfigurations: [\n {\n action: 'plugin::content-manager.collection-types.configure-view',\n subject: null,\n },\n ],\n componentsConfigurations: [\n {\n action: 'plugin::content-manager.components.configure-layout',\n subject: null,\n },\n ],\n singleTypesConfigurations: [\n {\n action: 'plugin::content-manager.single-types.configure-view',\n subject: null,\n },\n ],\n },\n marketplace: {\n main: [{ action: 'admin::marketplace.read', subject: null }],\n read: [{ action: 'admin::marketplace.read', subject: null }],\n },\n settings: {\n roles: {\n main: [\n { action: 'admin::roles.create', subject: null },\n { action: 'admin::roles.update', subject: null },\n { action: 'admin::roles.read', subject: null },\n { action: 'admin::roles.delete', subject: null },\n ],\n create: [{ action: 'admin::roles.create', subject: null }],\n delete: [{ action: 'admin::roles.delete', subject: null }],\n read: [{ action: 'admin::roles.read', subject: null }],\n update: [{ action: 'admin::roles.update', subject: null }],\n },\n users: {\n main: [\n { action: 'admin::users.create', subject: null },\n { action: 'admin::users.read', subject: null },\n { action: 'admin::users.update', subject: null },\n { action: 'admin::users.delete', subject: null },\n ],\n create: [{ action: 'admin::users.create', subject: null }],\n delete: [{ action: 'admin::users.delete', subject: null }],\n read: [{ action: 'admin::users.read', subject: null }],\n update: [{ action: 'admin::users.update', subject: null }],\n },\n webhooks: {\n main: [\n { action: 'admin::webhooks.create', subject: null },\n { action: 'admin::webhooks.read', subject: null },\n { action: 'admin::webhooks.update', subject: null },\n { action: 'admin::webhooks.delete', subject: null },\n ],\n create: [{ action: 'admin::webhooks.create', subject: null }],\n delete: [{ action: 'admin::webhooks.delete', subject: null }],\n read: [\n { action: 'admin::webhooks.read', subject: null },\n // NOTE: We need to check with the API\n { action: 'admin::webhooks.update', subject: null },\n { action: 'admin::webhooks.delete', subject: null },\n ],\n update: [{ action: 'admin::webhooks.update', subject: null }],\n },\n 'admin-tokens': {\n main: [{ action: 'admin::admin-tokens.access', subject: null }],\n create: [{ action: 'admin::admin-tokens.create', subject: null }],\n delete: [{ action: 'admin::admin-tokens.delete', subject: null }],\n read: [{ action: 'admin::admin-tokens.read', subject: null }],\n update: [{ action: 'admin::admin-tokens.update', subject: null }],\n regenerate: [{ action: 'admin::admin-tokens.regenerate', subject: null }],\n },\n 'api-tokens': {\n main: [{ action: 'admin::api-tokens.access', subject: null }],\n create: [{ action: 'admin::api-tokens.create', subject: null }],\n delete: [{ action: 'admin::api-tokens.delete', subject: null }],\n read: [{ action: 'admin::api-tokens.read', subject: null }],\n update: [{ action: 'admin::api-tokens.update', subject: null }],\n regenerate: [{ action: 'admin::api-tokens.regenerate', subject: null }],\n },\n 'transfer-tokens': {\n main: [{ action: 'admin::transfer.tokens.access', subject: null }],\n create: [{ action: 'admin::transfer.tokens.create', subject: null }],\n delete: [{ action: 'admin::transfer.tokens.delete', subject: null }],\n read: [{ action: 'admin::transfer.tokens.read', subject: null }],\n update: [{ action: 'admin::transfer.tokens.update', subject: null }],\n regenerate: [{ action: 'admin::transfer.tokens.regenerate', subject: null }],\n },\n 'project-settings': {\n read: [{ action: 'admin::project-settings.read', subject: null }],\n update: [{ action: 'admin::project-settings.update', subject: null }],\n },\n plugins: {\n main: [{ action: 'admin::marketplace.read', subject: null }],\n read: [{ action: 'admin::marketplace.read', subject: null }],\n },\n },\n} satisfies Partial<PermissionMap>;\n\nexport const HOOKS = {\n /**\n * Hook that allows to mutate the displayed headers of the list view table\n * @constant\n * @type {string}\n */\n INJECT_COLUMN_IN_TABLE: 'Admin/CM/pages/ListView/inject-column-in-table',\n\n /**\n * Hook that allows to mutate the CM's collection types links pre-set filters\n * @constant\n * @type {string}\n */\n MUTATE_COLLECTION_TYPES_LINKS: 'Admin/CM/pages/App/mutate-collection-types-links',\n\n /**\n * Hook that allows to mutate the CM's edit view layout\n * @constant\n * @type {string}\n */\n MUTATE_EDIT_VIEW_LAYOUT: 'Admin/CM/pages/EditView/mutate-edit-view-layout',\n\n /**\n * Hook that allows to mutate the CM's single types links pre-set filters\n * @constant\n * @type {string}\n */\n MUTATE_SINGLE_TYPES_LINKS: 'Admin/CM/pages/App/mutate-single-types-links',\n};\n\nexport interface SettingsMenuLink\n extends Omit<StrapiAppSettingLink, 'Component' | 'permissions' | 'licenseOnly'> {\n licenseOnly?: boolean;\n}\n\nexport type SettingsMenu = {\n admin: SettingsMenuLink[];\n global: SettingsMenuLink[];\n};\n\nconst isAdminTokensFutureEnabled = () => window.strapi.future.isEnabled('adminTokens') === true;\n\nexport const SETTINGS_LINKS_CE = (): SettingsMenu => ({\n global: [\n {\n intlLabel: { id: 'Settings.application.title', defaultMessage: 'Overview' },\n to: '/settings/application-infos',\n id: '000-application-infos',\n },\n {\n intlLabel: { id: 'Settings.webhooks.title', defaultMessage: 'Webhooks' },\n to: '/settings/webhooks',\n id: 'webhooks',\n },\n {\n intlLabel: { id: 'Settings.apiTokens.title', defaultMessage: 'API Tokens' },\n to: '/settings/api-tokens?sort=name:ASC',\n id: 'api-tokens',\n },\n {\n intlLabel: { id: 'Settings.transferTokens.title', defaultMessage: 'Transfer Tokens' },\n to: '/settings/transfer-tokens?sort=name:ASC',\n id: 'transfer-tokens',\n },\n {\n intlLabel: {\n id: 'global.plugins',\n defaultMessage: 'Plugins',\n },\n to: '/settings/list-plugins',\n id: 'plugins',\n },\n // If the Enterprise/Cloud feature is not enabled and if the config doesn't disable it, we promote the Enterprise/Cloud feature by displaying them in the settings menu.\n // Disable this by adding \"promoteEE: false\" to your `./config/admin.js` file\n ...(!window.strapi.features.isEnabled(window.strapi.features.SSO) &&\n window.strapi?.flags?.promoteEE\n ? [\n {\n intlLabel: { id: 'Settings.sso.title', defaultMessage: 'Single Sign-On' },\n to: '/settings/purchase-single-sign-on',\n id: 'sso-purchase-page',\n licenseOnly: true,\n },\n ]\n : []),\n ...(!window.strapi.features.isEnabled('cms-content-history') && window.strapi?.flags?.promoteEE\n ? [\n {\n intlLabel: { id: 'Settings.content-history.title', defaultMessage: 'Content History' },\n to: '/settings/purchase-content-history',\n id: 'content-history-purchase-page',\n licenseOnly: true,\n },\n ]\n : []),\n ],\n\n admin: [\n {\n intlLabel: { id: 'global.roles', defaultMessage: 'Roles' },\n to: '/settings/roles',\n id: 'roles',\n },\n {\n intlLabel: { id: 'global.users', defaultMessage: 'Users' },\n // Init the search params directly\n to: '/settings/users?pageSize=10&page=1&sort=firstname',\n id: 'users',\n },\n ...(isAdminTokensFutureEnabled() === true\n ? [\n {\n intlLabel: { id: 'Settings.adminTokens.title', defaultMessage: 'Admin Tokens' },\n to: '/settings/admin-tokens',\n id: 'admin-tokens',\n },\n ]\n : []),\n ...(!window.strapi.features.isEnabled(window.strapi.features.AUDIT_LOGS) &&\n window.strapi?.flags?.promoteEE\n ? [\n {\n intlLabel: { id: 'global.auditLogs', defaultMessage: 'Audit Logs' },\n to: '/settings/purchase-audit-logs',\n id: 'auditLogs-purchase-page',\n licenseOnly: true,\n },\n ]\n : []),\n ],\n});\n"],"names":["ADMIN_PERMISSIONS_CE","contentManager","main","collectionTypesConfigurations","action","subject","componentsConfigurations","singleTypesConfigurations","marketplace","read","settings","roles","create","delete","update","users","webhooks","regenerate","plugins","HOOKS","INJECT_COLUMN_IN_TABLE","MUTATE_COLLECTION_TYPES_LINKS","MUTATE_EDIT_VIEW_LAYOUT","MUTATE_SINGLE_TYPES_LINKS","isAdminTokensFutureEnabled","window","strapi","future","isEnabled","SETTINGS_LINKS_CE","global","intlLabel","id","defaultMessage","to","features","SSO","flags","promoteEE","licenseOnly","admin","AUDIT_LOGS"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"constants.mjs","sources":["../../../../admin/src/constants.ts"],"sourcesContent":["import { PermissionMap } from './types/permissions';\n\nimport type { StrapiAppSettingLink } from './core/apis/router';\n\nexport const ADMIN_PERMISSIONS_CE = {\n contentManager: {\n main: [],\n collectionTypesConfigurations: [\n {\n action: 'plugin::content-manager.collection-types.configure-view',\n subject: null,\n },\n ],\n componentsConfigurations: [\n {\n action: 'plugin::content-manager.components.configure-layout',\n subject: null,\n },\n ],\n singleTypesConfigurations: [\n {\n action: 'plugin::content-manager.single-types.configure-view',\n subject: null,\n },\n ],\n },\n marketplace: {\n main: [{ action: 'admin::marketplace.read', subject: null }],\n read: [{ action: 'admin::marketplace.read', subject: null }],\n },\n settings: {\n roles: {\n main: [\n { action: 'admin::roles.create', subject: null },\n { action: 'admin::roles.update', subject: null },\n { action: 'admin::roles.read', subject: null },\n { action: 'admin::roles.delete', subject: null },\n ],\n create: [{ action: 'admin::roles.create', subject: null }],\n delete: [{ action: 'admin::roles.delete', subject: null }],\n read: [{ action: 'admin::roles.read', subject: null }],\n update: [{ action: 'admin::roles.update', subject: null }],\n },\n users: {\n main: [\n { action: 'admin::users.create', subject: null },\n { action: 'admin::users.read', subject: null },\n { action: 'admin::users.update', subject: null },\n { action: 'admin::users.delete', subject: null },\n ],\n create: [{ action: 'admin::users.create', subject: null }],\n delete: [{ action: 'admin::users.delete', subject: null }],\n read: [{ action: 'admin::users.read', subject: null }],\n update: [{ action: 'admin::users.update', subject: null }],\n },\n webhooks: {\n main: [\n { action: 'admin::webhooks.create', subject: null },\n { action: 'admin::webhooks.read', subject: null },\n { action: 'admin::webhooks.update', subject: null },\n { action: 'admin::webhooks.delete', subject: null },\n ],\n create: [{ action: 'admin::webhooks.create', subject: null }],\n delete: [{ action: 'admin::webhooks.delete', subject: null }],\n read: [\n { action: 'admin::webhooks.read', subject: null },\n // NOTE: We need to check with the API\n { action: 'admin::webhooks.update', subject: null },\n { action: 'admin::webhooks.delete', subject: null },\n ],\n update: [{ action: 'admin::webhooks.update', subject: null }],\n },\n 'admin-tokens': {\n main: [{ action: 'admin::admin-tokens.access', subject: null }],\n create: [{ action: 'admin::admin-tokens.create', subject: null }],\n delete: [{ action: 'admin::admin-tokens.delete', subject: null }],\n read: [{ action: 'admin::admin-tokens.read', subject: null }],\n update: [{ action: 'admin::admin-tokens.update', subject: null }],\n regenerate: [{ action: 'admin::admin-tokens.regenerate', subject: null }],\n },\n 'api-tokens': {\n main: [{ action: 'admin::api-tokens.access', subject: null }],\n create: [{ action: 'admin::api-tokens.create', subject: null }],\n delete: [{ action: 'admin::api-tokens.delete', subject: null }],\n read: [{ action: 'admin::api-tokens.read', subject: null }],\n update: [{ action: 'admin::api-tokens.update', subject: null }],\n regenerate: [{ action: 'admin::api-tokens.regenerate', subject: null }],\n },\n 'transfer-tokens': {\n main: [{ action: 'admin::transfer.tokens.access', subject: null }],\n create: [{ action: 'admin::transfer.tokens.create', subject: null }],\n delete: [{ action: 'admin::transfer.tokens.delete', subject: null }],\n read: [{ action: 'admin::transfer.tokens.read', subject: null }],\n update: [{ action: 'admin::transfer.tokens.update', subject: null }],\n regenerate: [{ action: 'admin::transfer.tokens.regenerate', subject: null }],\n },\n 'project-settings': {\n read: [{ action: 'admin::project-settings.read', subject: null }],\n update: [{ action: 'admin::project-settings.update', subject: null }],\n },\n plugins: {\n main: [{ action: 'admin::marketplace.read', subject: null }],\n read: [{ action: 'admin::marketplace.read', subject: null }],\n },\n },\n} satisfies Partial<PermissionMap>;\n\nexport const HOOKS = {\n /**\n * Hook that allows to mutate the displayed headers of the list view table\n * @constant\n * @type {string}\n */\n INJECT_COLUMN_IN_TABLE: 'Admin/CM/pages/ListView/inject-column-in-table',\n\n /**\n * Hook that allows to mutate the displayed filters of the list view\n * @constant\n * @type {string}\n */\n INJECT_LIST_VIEW_FILTERS: 'Admin/CM/pages/ListView/inject-in-filters',\n\n /**\n * Hook that allows to mutate the CM's collection types links pre-set filters\n * @constant\n * @type {string}\n */\n MUTATE_COLLECTION_TYPES_LINKS: 'Admin/CM/pages/App/mutate-collection-types-links',\n\n /**\n * Hook that allows to mutate the CM's edit view layout\n * @constant\n * @type {string}\n */\n MUTATE_EDIT_VIEW_LAYOUT: 'Admin/CM/pages/EditView/mutate-edit-view-layout',\n\n /**\n * Hook that allows to mutate the CM's single types links pre-set filters\n * @constant\n * @type {string}\n */\n MUTATE_SINGLE_TYPES_LINKS: 'Admin/CM/pages/App/mutate-single-types-links',\n};\n\nexport interface SettingsMenuLink\n extends Omit<StrapiAppSettingLink, 'Component' | 'permissions' | 'licenseOnly'> {\n licenseOnly?: boolean;\n}\n\nexport type SettingsMenu = {\n admin: SettingsMenuLink[];\n global: SettingsMenuLink[];\n};\n\nexport const SETTINGS_LINKS_CE = (): SettingsMenu => ({\n global: [\n {\n intlLabel: { id: 'Settings.application.title', defaultMessage: 'Overview' },\n to: '/settings/application-infos',\n id: '000-application-infos',\n },\n {\n intlLabel: { id: 'Settings.webhooks.title', defaultMessage: 'Webhooks' },\n to: '/settings/webhooks',\n id: 'webhooks',\n },\n {\n intlLabel: { id: 'Settings.apiTokens.title', defaultMessage: 'API Tokens' },\n to: '/settings/api-tokens?sort=name:ASC',\n id: 'api-tokens',\n },\n {\n intlLabel: { id: 'Settings.transferTokens.title', defaultMessage: 'Transfer Tokens' },\n to: '/settings/transfer-tokens?sort=name:ASC',\n id: 'transfer-tokens',\n },\n {\n intlLabel: {\n id: 'global.plugins',\n defaultMessage: 'Plugins',\n },\n to: '/settings/list-plugins',\n id: 'plugins',\n },\n // If the Enterprise/Cloud feature is not enabled and if the config doesn't disable it, we promote the Enterprise/Cloud feature by displaying them in the settings menu.\n // Disable this by adding \"promoteEE: false\" to your `./config/admin.js` file\n ...(!window.strapi.features.isEnabled(window.strapi.features.SSO) &&\n window.strapi?.flags?.promoteEE\n ? [\n {\n intlLabel: { id: 'Settings.sso.title', defaultMessage: 'Single Sign-On' },\n to: '/settings/purchase-single-sign-on',\n id: 'sso-purchase-page',\n licenseOnly: true,\n },\n ]\n : []),\n ...(!window.strapi.features.isEnabled('cms-content-history') && window.strapi?.flags?.promoteEE\n ? [\n {\n intlLabel: { id: 'Settings.content-history.title', defaultMessage: 'Content History' },\n to: '/settings/purchase-content-history',\n id: 'content-history-purchase-page',\n licenseOnly: true,\n },\n ]\n : []),\n ],\n\n admin: [\n {\n intlLabel: { id: 'global.roles', defaultMessage: 'Roles' },\n to: '/settings/roles',\n id: 'roles',\n },\n {\n intlLabel: { id: 'global.users', defaultMessage: 'Users' },\n // Init the search params directly\n to: '/settings/users?pageSize=10&page=1&sort=firstname',\n id: 'users',\n },\n {\n intlLabel: { id: 'Settings.adminTokens.title', defaultMessage: 'Admin Tokens' },\n to: '/settings/admin-tokens',\n id: 'admin-tokens',\n },\n ...(!window.strapi.features.isEnabled(window.strapi.features.AUDIT_LOGS) &&\n window.strapi?.flags?.promoteEE\n ? [\n {\n intlLabel: { id: 'global.auditLogs', defaultMessage: 'Audit Logs' },\n to: '/settings/purchase-audit-logs',\n id: 'auditLogs-purchase-page',\n licenseOnly: true,\n },\n ]\n : []),\n ],\n});\n"],"names":["ADMIN_PERMISSIONS_CE","contentManager","main","collectionTypesConfigurations","action","subject","componentsConfigurations","singleTypesConfigurations","marketplace","read","settings","roles","create","delete","update","users","webhooks","regenerate","plugins","HOOKS","INJECT_COLUMN_IN_TABLE","INJECT_LIST_VIEW_FILTERS","MUTATE_COLLECTION_TYPES_LINKS","MUTATE_EDIT_VIEW_LAYOUT","MUTATE_SINGLE_TYPES_LINKS","SETTINGS_LINKS_CE","global","intlLabel","id","defaultMessage","to","window","strapi","features","isEnabled","SSO","flags","promoteEE","licenseOnly","admin","AUDIT_LOGS"],"mappings":"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"}
|
|
@@ -6,6 +6,7 @@ var reactRouterDom = require('react-router-dom');
|
|
|
6
6
|
var Context = require('../components/Context.js');
|
|
7
7
|
var hooks = require('../core/store/hooks.js');
|
|
8
8
|
var StrapiApp = require('./StrapiApp.js');
|
|
9
|
+
var useIdleSessionLogout = require('../hooks/useIdleSessionLogout.js');
|
|
9
10
|
var useQueryParams = require('../hooks/useQueryParams.js');
|
|
10
11
|
var reducer = require('../reducer.js');
|
|
11
12
|
var api = require('../services/api.js');
|
|
@@ -107,6 +108,30 @@ const AuthProvider = ({ children, _defaultPermissions = [], _disableRenewToken =
|
|
|
107
108
|
}, [
|
|
108
109
|
dispatch
|
|
109
110
|
]);
|
|
111
|
+
/**
|
|
112
|
+
* Register the session-expired handler that the fetch layer / RTK baseQuery
|
|
113
|
+
* call when the server rejects the refresh token. This is what redirects
|
|
114
|
+
* the active tab to /auth/login on a 401, instead of leaving the user on
|
|
115
|
+
* a stale page until they click something.
|
|
116
|
+
*/ React__namespace.useEffect(()=>{
|
|
117
|
+
getFetchClient.setOnSessionExpired(()=>{
|
|
118
|
+
clearStateAndLogout();
|
|
119
|
+
});
|
|
120
|
+
return ()=>{
|
|
121
|
+
getFetchClient.setOnSessionExpired(null);
|
|
122
|
+
};
|
|
123
|
+
}, [
|
|
124
|
+
clearStateAndLogout
|
|
125
|
+
]);
|
|
126
|
+
/**
|
|
127
|
+
* Proactive idle-session detection. See `useIdleSessionLogout` for the full
|
|
128
|
+
* rationale and the UX trade-off (a user actively typing in a form with no
|
|
129
|
+
* outgoing API calls will still be logged out at `exp`).
|
|
130
|
+
*/ useIdleSessionLogout.useIdleSessionLogout({
|
|
131
|
+
token,
|
|
132
|
+
onExpired: clearStateAndLogout,
|
|
133
|
+
disabled: _disableRenewToken
|
|
134
|
+
});
|
|
110
135
|
React__namespace.useEffect(()=>{
|
|
111
136
|
/**
|
|
112
137
|
* This will log a user out of all tabs if they log out in one tab.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Auth.js","sources":["../../../../../admin/src/features/Auth.tsx"],"sourcesContent":["import * as React from 'react';\n\nimport { useLocation, useNavigate } from 'react-router-dom';\n\nimport { Login } from '../../../shared/contracts/authentication';\nimport { createContext } from '../components/Context';\nimport { useTypedDispatch, useTypedSelector } from '../core/store/hooks';\nimport { useStrapiApp } from '../features/StrapiApp';\nimport { useQueryParams } from '../hooks/useQueryParams';\nimport { login as loginAction, logout as logoutAction, setLocale, setToken } from '../reducer';\nimport { adminApi } from '../services/api';\nimport {\n useGetMeQuery,\n useGetMyPermissionsQuery,\n useLazyCheckPermissionsQuery,\n useLoginMutation,\n useLogoutMutation,\n} from '../services/auth';\nimport { getOrCreateDeviceId } from '../utils/deviceId';\nimport { setOnTokenUpdate } from '../utils/getFetchClient';\n\nimport type {\n Permission as PermissionContract,\n SanitizedAdminUser,\n} from '../../../shared/contracts/shared';\n\ninterface Permission\n extends Pick<PermissionContract, 'action' | 'subject'>,\n Partial<Omit<PermissionContract, 'action' | 'subject'>> {}\n\ninterface User\n extends Pick<SanitizedAdminUser, 'email' | 'firstname' | 'lastname' | 'username' | 'roles'>,\n Partial<Omit<SanitizedAdminUser, 'email' | 'firstname' | 'lastname' | 'username' | 'roles'>> {}\n\ninterface AuthContextValue {\n login: (\n body: Login.Request['body'] & { rememberMe: boolean }\n ) => Promise<Awaited<ReturnType<ReturnType<typeof useLoginMutation>[0]>>>;\n logout: () => Promise<void>;\n /**\n * @alpha\n * @description given a list of permissions, this function checks\n * those against the current user's permissions or those passed as\n * the second argument, if the user has those permissions the complete\n * permission object form the API is returned. Therefore, if the list is\n * empty, the user does not have any of those permissions.\n */\n checkUserHasPermissions: (\n permissions?: Array<Pick<Permission, 'action'> & Partial<Omit<Permission, 'action'>>>,\n passedPermissions?: Permission[],\n rawQueryContext?: string\n ) => Promise<Permission[]>;\n isLoading: boolean;\n permissions: Permission[];\n refetchPermissions: () => Promise<void>;\n token: string | null;\n user?: User;\n}\n\n/**\n * ensure the Auth context never exposes a non-function for checkUserHasPermissions.\n * When this is undefined (e.g. context timing in production builds), consumers would throw\n * \"p is not a function\" / \"checkUserHasPermissions is not a function\". By always passing\n * a function here, all current and future consumers are protected without per-call-site guards.\n *\n * When would the fallback run? Only if the real checkUserHasPermissions were ever undefined\n * when we pass to the Provider (e.g. a rare timing/build edge case). In normal runs it is\n * always defined (useCallback), so the real function is passed and behavior is unchanged.\n *\n * If the fallback ever did run: it returns [] so consumers (which use .length > 0) treat it\n * as \"no permission\" for that render—under-permissive. On the next AuthProvider re-render we\n * pass the real function again, so the context updates and the view corrects quickly.\n * @see https://github.com/strapi/strapi/issues/24384\n */\nconst NOOP_CHECK_USER_HAS_PERMISSIONS: AuthContextValue['checkUserHasPermissions'] = async () => [];\n\nconst [Provider, useAuth] = createContext<AuthContextValue>('Auth');\n\ninterface AuthProviderProps {\n children: React.ReactNode;\n /**\n * @internal could be removed at any time.\n */\n _defaultPermissions?: Permission[];\n\n // NOTE: this is used for testing purposed only\n _disableRenewToken?: boolean;\n}\n\nconst STORAGE_KEYS = {\n TOKEN: 'jwtToken',\n STATUS: 'isLoggedIn',\n};\n\nconst AuthProvider = ({\n children,\n _defaultPermissions = [],\n _disableRenewToken = false,\n}: AuthProviderProps) => {\n const dispatch = useTypedDispatch();\n const runRbacMiddleware = useStrapiApp('AuthProvider', (state) => state.rbac.run);\n const location = useLocation();\n const [{ rawQuery }] = useQueryParams();\n\n const locationRef = React.useRef(location);\n\n // Update ref without causing re-render\n React.useEffect(() => {\n locationRef.current = location;\n }, [location]);\n\n const token = useTypedSelector((state) => state.admin_app.token ?? null);\n\n const { data: user, isLoading: isLoadingUser } = useGetMeQuery(undefined, {\n /**\n * If there's no token, we don't try to fetch\n * the user data because it will fail.\n */\n skip: !token,\n });\n\n const {\n data: userPermissions = _defaultPermissions,\n refetch,\n isUninitialized,\n isLoading: isLoadingPermissions,\n } = useGetMyPermissionsQuery(undefined, {\n skip: !token,\n });\n\n const navigate = useNavigate();\n\n const [loginMutation] = useLoginMutation();\n const [logoutMutation] = useLogoutMutation();\n\n const clearStateAndLogout = React.useCallback(() => {\n dispatch(adminApi.util.resetApiState());\n dispatch(logoutAction());\n navigate('/auth/login');\n }, [dispatch, navigate]);\n\n React.useEffect(() => {\n if (user) {\n if (user.preferedLanguage) {\n dispatch(setLocale(user.preferedLanguage));\n }\n }\n }, [dispatch, user]);\n\n /**\n * Register a callback to update Redux state when the token is refreshed.\n * This ensures the app state stays in sync with the token stored in localStorage/cookies.\n */\n React.useEffect(() => {\n setOnTokenUpdate((newToken) => {\n dispatch(setToken(newToken));\n });\n\n return () => {\n setOnTokenUpdate(null);\n };\n }, [dispatch]);\n\n React.useEffect(() => {\n /**\n * This will log a user out of all tabs if they log out in one tab.\n */\n const handleUserStorageChange = (event: StorageEvent) => {\n if (event.key === STORAGE_KEYS.STATUS && event.newValue === null) {\n clearStateAndLogout();\n }\n };\n\n window.addEventListener('storage', handleUserStorageChange);\n\n return () => {\n window.removeEventListener('storage', handleUserStorageChange);\n };\n });\n\n const login = React.useCallback<AuthContextValue['login']>(\n async ({ rememberMe, ...body }) => {\n const res = await loginMutation({ ...body, deviceId: getOrCreateDeviceId(), rememberMe });\n\n /**\n * There will always be a `data` key in the response\n * because if something fails, it will throw an error.\n */\n if ('data' in res) {\n const { token } = res.data;\n\n dispatch(\n loginAction({\n token,\n persist: rememberMe,\n })\n );\n }\n\n return res;\n },\n [dispatch, loginMutation]\n );\n\n const logout = React.useCallback(async () => {\n await logoutMutation({ deviceId: getOrCreateDeviceId() });\n clearStateAndLogout();\n }, [clearStateAndLogout, logoutMutation]);\n\n const refetchPermissions = React.useCallback(async () => {\n if (!isUninitialized) {\n await refetch();\n }\n }, [isUninitialized, refetch]);\n\n const [checkPermissions] = useLazyCheckPermissionsQuery();\n const checkUserHasPermissions: AuthContextValue['checkUserHasPermissions'] = React.useCallback(\n async (\n permissions,\n passedPermissions,\n // TODO:\n // Here we have parameterised checkUserHasPermissions in order to pass\n // query context from elsewhere in the application.\n // See packages/core/content-manager/admin/src/features/DocumentRBAC.tsx\n\n // This is in order to calculate permissions on accurate query params.\n // We should be able to rely on the query params in this provider\n // If we need to pass additional context to the RBAC middleware\n // we should define a better context type.\n rawQueryContext\n ) => {\n /**\n * If there's no permissions to check, then we allow it to\n * pass to preserve existing behaviours.\n *\n * TODO: should we review this? it feels more dangerous than useful.\n */\n if (!permissions || permissions.length === 0) {\n return [{ action: '', subject: '' }];\n }\n\n /**\n * Given the provided permissions, return the permissions from either passedPermissions\n * or userPermissions as this is expected to be the full permission entity.\n */\n const actualUserPermissions = passedPermissions ?? userPermissions;\n\n const matchingPermissions = actualUserPermissions.filter(\n (permission) =>\n permissions.findIndex(\n (perm) =>\n perm.action === permission.action &&\n // Only check the subject if it's provided\n (perm.subject == undefined || perm.subject === permission.subject)\n ) >= 0\n );\n\n const middlewaredPermissions = await runRbacMiddleware(\n {\n user,\n permissions: userPermissions,\n pathname: locationRef.current.pathname,\n search: (rawQueryContext || rawQuery).split('?')[1] ?? '',\n },\n matchingPermissions\n );\n\n const shouldCheckConditions = middlewaredPermissions.some(\n (perm) => Array.isArray(perm.conditions) && perm.conditions.length > 0\n );\n\n if (!shouldCheckConditions) {\n return middlewaredPermissions;\n }\n\n const { data, error } = await checkPermissions({\n permissions: middlewaredPermissions.map((perm) => ({\n action: perm.action,\n subject: perm.subject,\n })),\n });\n\n if (error) {\n throw error;\n } else {\n return middlewaredPermissions.filter((_, index) => data?.data[index] === true);\n }\n },\n [checkPermissions, rawQuery, runRbacMiddleware, user, userPermissions]\n );\n\n const isLoading = isLoadingUser || isLoadingPermissions;\n\n return (\n <Provider\n token={token}\n user={user}\n login={login}\n logout={logout}\n permissions={userPermissions}\n checkUserHasPermissions={checkUserHasPermissions ?? NOOP_CHECK_USER_HAS_PERMISSIONS}\n refetchPermissions={refetchPermissions}\n isLoading={isLoading}\n >\n {children}\n </Provider>\n );\n};\n\nexport { AuthProvider, useAuth, STORAGE_KEYS };\nexport type { AuthContextValue, Permission, User };\n"],"names":["NOOP_CHECK_USER_HAS_PERMISSIONS","Provider","useAuth","createContext","STORAGE_KEYS","STATUS","AuthProvider","children","_defaultPermissions","_disableRenewToken","dispatch","useTypedDispatch","runRbacMiddleware","useStrapiApp","state","rbac","run","location","useLocation","rawQuery","useQueryParams","locationRef","React","useRef","useEffect","current","token","useTypedSelector","admin_app","data","user","isLoading","isLoadingUser","useGetMeQuery","undefined","skip","userPermissions","refetch","isUninitialized","isLoadingPermissions","useGetMyPermissionsQuery","navigate","useNavigate","loginMutation","useLoginMutation","logoutMutation","useLogoutMutation","clearStateAndLogout","useCallback","adminApi","util","resetApiState","logoutAction","preferedLanguage","setLocale","setOnTokenUpdate","newToken","setToken","handleUserStorageChange","event","key","newValue","window","addEventListener","removeEventListener","login","rememberMe","body","res","deviceId","getOrCreateDeviceId","loginAction","persist","logout","refetchPermissions","checkPermissions","useLazyCheckPermissionsQuery","checkUserHasPermissions","permissions","passedPermissions","rawQueryContext","length","action","subject","actualUserPermissions","matchingPermissions","filter","permission","findIndex","perm","middlewaredPermissions","pathname","search","split","shouldCheckConditions","some","Array","isArray","conditions","error","map","_","index","_jsx"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"Auth.js","sources":["../../../../../admin/src/features/Auth.tsx"],"sourcesContent":["import * as React from 'react';\n\nimport { useLocation, useNavigate } from 'react-router-dom';\n\nimport { Login } from '../../../shared/contracts/authentication';\nimport { createContext } from '../components/Context';\nimport { useTypedDispatch, useTypedSelector } from '../core/store/hooks';\nimport { useStrapiApp } from '../features/StrapiApp';\nimport { useIdleSessionLogout } from '../hooks/useIdleSessionLogout';\nimport { useQueryParams } from '../hooks/useQueryParams';\nimport { login as loginAction, logout as logoutAction, setLocale, setToken } from '../reducer';\nimport { adminApi } from '../services/api';\nimport {\n useGetMeQuery,\n useGetMyPermissionsQuery,\n useLazyCheckPermissionsQuery,\n useLoginMutation,\n useLogoutMutation,\n} from '../services/auth';\nimport { getOrCreateDeviceId } from '../utils/deviceId';\nimport { setOnSessionExpired, setOnTokenUpdate } from '../utils/getFetchClient';\n\nimport type {\n Permission as PermissionContract,\n SanitizedAdminUser,\n} from '../../../shared/contracts/shared';\n\ninterface Permission\n extends Pick<PermissionContract, 'action' | 'subject'>,\n Partial<Omit<PermissionContract, 'action' | 'subject'>> {}\n\ninterface User\n extends Pick<SanitizedAdminUser, 'email' | 'firstname' | 'lastname' | 'username' | 'roles'>,\n Partial<Omit<SanitizedAdminUser, 'email' | 'firstname' | 'lastname' | 'username' | 'roles'>> {}\n\ninterface AuthContextValue {\n login: (\n body: Login.Request['body'] & { rememberMe: boolean }\n ) => Promise<Awaited<ReturnType<ReturnType<typeof useLoginMutation>[0]>>>;\n logout: () => Promise<void>;\n /**\n * @alpha\n * @description given a list of permissions, this function checks\n * those against the current user's permissions or those passed as\n * the second argument, if the user has those permissions the complete\n * permission object form the API is returned. Therefore, if the list is\n * empty, the user does not have any of those permissions.\n */\n checkUserHasPermissions: (\n permissions?: Array<Pick<Permission, 'action'> & Partial<Omit<Permission, 'action'>>>,\n passedPermissions?: Permission[],\n rawQueryContext?: string\n ) => Promise<Permission[]>;\n isLoading: boolean;\n permissions: Permission[];\n refetchPermissions: () => Promise<void>;\n token: string | null;\n user?: User;\n}\n\n/**\n * ensure the Auth context never exposes a non-function for checkUserHasPermissions.\n * When this is undefined (e.g. context timing in production builds), consumers would throw\n * \"p is not a function\" / \"checkUserHasPermissions is not a function\". By always passing\n * a function here, all current and future consumers are protected without per-call-site guards.\n *\n * When would the fallback run? Only if the real checkUserHasPermissions were ever undefined\n * when we pass to the Provider (e.g. a rare timing/build edge case). In normal runs it is\n * always defined (useCallback), so the real function is passed and behavior is unchanged.\n *\n * If the fallback ever did run: it returns [] so consumers (which use .length > 0) treat it\n * as \"no permission\" for that render—under-permissive. On the next AuthProvider re-render we\n * pass the real function again, so the context updates and the view corrects quickly.\n * @see https://github.com/strapi/strapi/issues/24384\n */\nconst NOOP_CHECK_USER_HAS_PERMISSIONS: AuthContextValue['checkUserHasPermissions'] = async () => [];\n\nconst [Provider, useAuth] = createContext<AuthContextValue>('Auth');\n\ninterface AuthProviderProps {\n children: React.ReactNode;\n /**\n * @internal could be removed at any time.\n */\n _defaultPermissions?: Permission[];\n\n // NOTE: this is used for testing purposed only\n _disableRenewToken?: boolean;\n}\n\nconst STORAGE_KEYS = {\n TOKEN: 'jwtToken',\n STATUS: 'isLoggedIn',\n};\n\nconst AuthProvider = ({\n children,\n _defaultPermissions = [],\n _disableRenewToken = false,\n}: AuthProviderProps) => {\n const dispatch = useTypedDispatch();\n const runRbacMiddleware = useStrapiApp('AuthProvider', (state) => state.rbac.run);\n const location = useLocation();\n const [{ rawQuery }] = useQueryParams();\n\n const locationRef = React.useRef(location);\n\n // Update ref without causing re-render\n React.useEffect(() => {\n locationRef.current = location;\n }, [location]);\n\n const token = useTypedSelector((state) => state.admin_app.token ?? null);\n\n const { data: user, isLoading: isLoadingUser } = useGetMeQuery(undefined, {\n /**\n * If there's no token, we don't try to fetch\n * the user data because it will fail.\n */\n skip: !token,\n });\n\n const {\n data: userPermissions = _defaultPermissions,\n refetch,\n isUninitialized,\n isLoading: isLoadingPermissions,\n } = useGetMyPermissionsQuery(undefined, {\n skip: !token,\n });\n\n const navigate = useNavigate();\n\n const [loginMutation] = useLoginMutation();\n const [logoutMutation] = useLogoutMutation();\n\n const clearStateAndLogout = React.useCallback(() => {\n dispatch(adminApi.util.resetApiState());\n dispatch(logoutAction());\n navigate('/auth/login');\n }, [dispatch, navigate]);\n\n React.useEffect(() => {\n if (user) {\n if (user.preferedLanguage) {\n dispatch(setLocale(user.preferedLanguage));\n }\n }\n }, [dispatch, user]);\n\n /**\n * Register a callback to update Redux state when the token is refreshed.\n * This ensures the app state stays in sync with the token stored in localStorage/cookies.\n */\n React.useEffect(() => {\n setOnTokenUpdate((newToken) => {\n dispatch(setToken(newToken));\n });\n\n return () => {\n setOnTokenUpdate(null);\n };\n }, [dispatch]);\n\n /**\n * Register the session-expired handler that the fetch layer / RTK baseQuery\n * call when the server rejects the refresh token. This is what redirects\n * the active tab to /auth/login on a 401, instead of leaving the user on\n * a stale page until they click something.\n */\n React.useEffect(() => {\n setOnSessionExpired(() => {\n clearStateAndLogout();\n });\n\n return () => {\n setOnSessionExpired(null);\n };\n }, [clearStateAndLogout]);\n\n /**\n * Proactive idle-session detection. See `useIdleSessionLogout` for the full\n * rationale and the UX trade-off (a user actively typing in a form with no\n * outgoing API calls will still be logged out at `exp`).\n */\n useIdleSessionLogout({\n token,\n onExpired: clearStateAndLogout,\n disabled: _disableRenewToken,\n });\n\n React.useEffect(() => {\n /**\n * This will log a user out of all tabs if they log out in one tab.\n */\n const handleUserStorageChange = (event: StorageEvent) => {\n if (event.key === STORAGE_KEYS.STATUS && event.newValue === null) {\n clearStateAndLogout();\n }\n };\n\n window.addEventListener('storage', handleUserStorageChange);\n\n return () => {\n window.removeEventListener('storage', handleUserStorageChange);\n };\n });\n\n const login = React.useCallback<AuthContextValue['login']>(\n async ({ rememberMe, ...body }) => {\n const res = await loginMutation({ ...body, deviceId: getOrCreateDeviceId(), rememberMe });\n\n /**\n * There will always be a `data` key in the response\n * because if something fails, it will throw an error.\n */\n if ('data' in res) {\n const { token } = res.data;\n\n dispatch(\n loginAction({\n token,\n persist: rememberMe,\n })\n );\n }\n\n return res;\n },\n [dispatch, loginMutation]\n );\n\n const logout = React.useCallback(async () => {\n await logoutMutation({ deviceId: getOrCreateDeviceId() });\n clearStateAndLogout();\n }, [clearStateAndLogout, logoutMutation]);\n\n const refetchPermissions = React.useCallback(async () => {\n if (!isUninitialized) {\n await refetch();\n }\n }, [isUninitialized, refetch]);\n\n const [checkPermissions] = useLazyCheckPermissionsQuery();\n const checkUserHasPermissions: AuthContextValue['checkUserHasPermissions'] = React.useCallback(\n async (\n permissions,\n passedPermissions,\n // TODO:\n // Here we have parameterised checkUserHasPermissions in order to pass\n // query context from elsewhere in the application.\n // See packages/core/content-manager/admin/src/features/DocumentRBAC.tsx\n\n // This is in order to calculate permissions on accurate query params.\n // We should be able to rely on the query params in this provider\n // If we need to pass additional context to the RBAC middleware\n // we should define a better context type.\n rawQueryContext\n ) => {\n /**\n * If there's no permissions to check, then we allow it to\n * pass to preserve existing behaviours.\n *\n * TODO: should we review this? it feels more dangerous than useful.\n */\n if (!permissions || permissions.length === 0) {\n return [{ action: '', subject: '' }];\n }\n\n /**\n * Given the provided permissions, return the permissions from either passedPermissions\n * or userPermissions as this is expected to be the full permission entity.\n */\n const actualUserPermissions = passedPermissions ?? userPermissions;\n\n const matchingPermissions = actualUserPermissions.filter(\n (permission) =>\n permissions.findIndex(\n (perm) =>\n perm.action === permission.action &&\n // Only check the subject if it's provided\n (perm.subject == undefined || perm.subject === permission.subject)\n ) >= 0\n );\n\n const middlewaredPermissions = await runRbacMiddleware(\n {\n user,\n permissions: userPermissions,\n pathname: locationRef.current.pathname,\n search: (rawQueryContext || rawQuery).split('?')[1] ?? '',\n },\n matchingPermissions\n );\n\n const shouldCheckConditions = middlewaredPermissions.some(\n (perm) => Array.isArray(perm.conditions) && perm.conditions.length > 0\n );\n\n if (!shouldCheckConditions) {\n return middlewaredPermissions;\n }\n\n const { data, error } = await checkPermissions({\n permissions: middlewaredPermissions.map((perm) => ({\n action: perm.action,\n subject: perm.subject,\n })),\n });\n\n if (error) {\n throw error;\n } else {\n return middlewaredPermissions.filter((_, index) => data?.data[index] === true);\n }\n },\n [checkPermissions, rawQuery, runRbacMiddleware, user, userPermissions]\n );\n\n const isLoading = isLoadingUser || isLoadingPermissions;\n\n return (\n <Provider\n token={token}\n user={user}\n login={login}\n logout={logout}\n permissions={userPermissions}\n checkUserHasPermissions={checkUserHasPermissions ?? NOOP_CHECK_USER_HAS_PERMISSIONS}\n refetchPermissions={refetchPermissions}\n isLoading={isLoading}\n >\n {children}\n </Provider>\n );\n};\n\nexport { AuthProvider, useAuth, STORAGE_KEYS };\nexport type { AuthContextValue, Permission, User };\n"],"names":["NOOP_CHECK_USER_HAS_PERMISSIONS","Provider","useAuth","createContext","STORAGE_KEYS","STATUS","AuthProvider","children","_defaultPermissions","_disableRenewToken","dispatch","useTypedDispatch","runRbacMiddleware","useStrapiApp","state","rbac","run","location","useLocation","rawQuery","useQueryParams","locationRef","React","useRef","useEffect","current","token","useTypedSelector","admin_app","data","user","isLoading","isLoadingUser","useGetMeQuery","undefined","skip","userPermissions","refetch","isUninitialized","isLoadingPermissions","useGetMyPermissionsQuery","navigate","useNavigate","loginMutation","useLoginMutation","logoutMutation","useLogoutMutation","clearStateAndLogout","useCallback","adminApi","util","resetApiState","logoutAction","preferedLanguage","setLocale","setOnTokenUpdate","newToken","setToken","setOnSessionExpired","useIdleSessionLogout","onExpired","disabled","handleUserStorageChange","event","key","newValue","window","addEventListener","removeEventListener","login","rememberMe","body","res","deviceId","getOrCreateDeviceId","loginAction","persist","logout","refetchPermissions","checkPermissions","useLazyCheckPermissionsQuery","checkUserHasPermissions","permissions","passedPermissions","rawQueryContext","length","action","subject","actualUserPermissions","matchingPermissions","filter","permission","findIndex","perm","middlewaredPermissions","pathname","search","split","shouldCheckConditions","some","Array","isArray","conditions","error","map","_","index","_jsx"],"mappings":"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"}
|