@strapi/admin 5.45.1 → 5.46.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.
Files changed (59) hide show
  1. package/dist/admin/admin/src/components/UpsellBanner.js +112 -61
  2. package/dist/admin/admin/src/components/UpsellBanner.js.map +1 -1
  3. package/dist/admin/admin/src/components/UpsellBanner.mjs +115 -64
  4. package/dist/admin/admin/src/components/UpsellBanner.mjs.map +1 -1
  5. package/dist/admin/admin/src/pages/ProfilePage.js +1 -1
  6. package/dist/admin/admin/src/pages/ProfilePage.js.map +1 -1
  7. package/dist/admin/admin/src/pages/ProfilePage.mjs +1 -1
  8. package/dist/admin/admin/src/pages/ProfilePage.mjs.map +1 -1
  9. package/dist/admin/admin/src/translations/de.json.js +2 -0
  10. package/dist/admin/admin/src/translations/de.json.js.map +1 -1
  11. package/dist/admin/admin/src/translations/de.json.mjs +2 -0
  12. package/dist/admin/admin/src/translations/de.json.mjs.map +1 -1
  13. package/dist/admin/admin/src/translations/en.json.js +3 -0
  14. package/dist/admin/admin/src/translations/en.json.js.map +1 -1
  15. package/dist/admin/admin/src/translations/en.json.mjs +3 -0
  16. package/dist/admin/admin/src/translations/en.json.mjs.map +1 -1
  17. package/dist/admin/admin/src/translations/es.json.js +3 -0
  18. package/dist/admin/admin/src/translations/es.json.js.map +1 -1
  19. package/dist/admin/admin/src/translations/es.json.mjs +3 -0
  20. package/dist/admin/admin/src/translations/es.json.mjs.map +1 -1
  21. package/dist/admin/admin/src/translations/fr.json.js +2 -0
  22. package/dist/admin/admin/src/translations/fr.json.js.map +1 -1
  23. package/dist/admin/admin/src/translations/fr.json.mjs +2 -0
  24. package/dist/admin/admin/src/translations/fr.json.mjs.map +1 -1
  25. package/dist/admin/admin/src/translations/tr.json.js +216 -1
  26. package/dist/admin/admin/src/translations/tr.json.js.map +1 -1
  27. package/dist/admin/admin/src/translations/tr.json.mjs +215 -2
  28. package/dist/admin/admin/src/translations/tr.json.mjs.map +1 -1
  29. package/dist/admin/admin/src/utils/getFetchClient.js +15 -7
  30. package/dist/admin/admin/src/utils/getFetchClient.js.map +1 -1
  31. package/dist/admin/admin/src/utils/getFetchClient.mjs +15 -7
  32. package/dist/admin/admin/src/utils/getFetchClient.mjs.map +1 -1
  33. package/dist/admin/admin/tests/server.js +123 -119
  34. package/dist/admin/admin/tests/server.js.map +1 -1
  35. package/dist/admin/admin/tests/server.mjs +124 -120
  36. package/dist/admin/admin/tests/server.mjs.map +1 -1
  37. package/dist/server/server/src/controllers/api-token.js +4 -5
  38. package/dist/server/server/src/controllers/api-token.js.map +1 -1
  39. package/dist/server/server/src/controllers/api-token.mjs +4 -5
  40. package/dist/server/server/src/controllers/api-token.mjs.map +1 -1
  41. package/dist/server/server/src/services/api-token.js +37 -18
  42. package/dist/server/server/src/services/api-token.js.map +1 -1
  43. package/dist/server/server/src/services/api-token.mjs +38 -19
  44. package/dist/server/server/src/services/api-token.mjs.map +1 -1
  45. package/dist/server/server/src/services/index.js +5 -2
  46. package/dist/server/server/src/services/index.js.map +1 -1
  47. package/dist/server/server/src/services/index.mjs +5 -2
  48. package/dist/server/server/src/services/index.mjs.map +1 -1
  49. package/dist/server/server/src/strategies/content-api-token.js +1 -1
  50. package/dist/server/server/src/strategies/content-api-token.js.map +1 -1
  51. package/dist/server/server/src/strategies/content-api-token.mjs +1 -1
  52. package/dist/server/server/src/strategies/content-api-token.mjs.map +1 -1
  53. package/dist/server/src/controllers/api-token.d.ts.map +1 -1
  54. package/dist/server/src/index.d.ts +1 -0
  55. package/dist/server/src/index.d.ts.map +1 -1
  56. package/dist/server/src/services/api-token.d.ts.map +1 -1
  57. package/dist/server/src/services/index.d.ts +2 -0
  58. package/dist/server/src/services/index.d.ts.map +1 -1
  59. package/package.json +8 -8
@@ -1,18 +1,18 @@
1
- import { rest } from 'msw';
1
+ import { http, HttpResponse } from 'msw';
2
2
  import { setupServer } from 'msw/node';
3
3
  import { mockData } from './mockData.mjs';
4
4
 
5
5
  const server = setupServer(...[
6
6
  /**
7
7
  * TRACKING
8
- */ rest.post('https://analytics.strapi.io/api/v2/track', (req, res, ctx)=>{
9
- return res(ctx.status(200));
8
+ */ http.post('https://analytics.strapi.io/api/v2/track', ()=>{
9
+ return new HttpResponse();
10
10
  }),
11
11
  /**
12
12
  *
13
13
  * ADMIN ROLES
14
14
  *
15
- */ rest.get('/admin/roles', (req, res, ctx)=>res(ctx.json({
15
+ */ http.get('/admin/roles', ()=>HttpResponse.json({
16
16
  data: [
17
17
  {
18
18
  id: 1,
@@ -25,18 +25,18 @@ const server = setupServer(...[
25
25
  name: 'Author'
26
26
  }
27
27
  ]
28
- }))),
29
- rest.get('/admin/roles/1', (req, res, ctx)=>res(ctx.json({
28
+ })),
29
+ http.get('/admin/roles/1', ({ request })=>HttpResponse.json({
30
30
  data: {
31
31
  id: 1,
32
32
  code: 'strapi-editor',
33
33
  params: {
34
- filters: req.url.searchParams.get('filters')
34
+ filters: new URL(request.url).searchParams.get('filters')
35
35
  }
36
36
  }
37
- }))),
38
- rest.get('/admin/roles/:id/permissions', (req, res, ctx)=>{
39
- return res(ctx.json({
37
+ })),
38
+ http.get('/admin/roles/:id/permissions', ({ request })=>{
39
+ return HttpResponse.json({
40
40
  data: [
41
41
  {
42
42
  id: 1,
@@ -50,18 +50,18 @@ const server = setupServer(...[
50
50
  },
51
51
  conditions: [],
52
52
  params: {
53
- filters: req.url.searchParams.get('filters')
53
+ filters: new URL(request.url).searchParams.get('filters')
54
54
  }
55
55
  }
56
56
  ]
57
- }));
57
+ });
58
58
  }),
59
59
  /**
60
60
  *
61
61
  * ADMIN USERS
62
62
  *
63
- */ rest.get('/admin/users', (req, res, ctx)=>{
64
- return res(ctx.json({
63
+ */ http.get('/admin/users', ()=>{
64
+ return HttpResponse.json({
65
65
  data: {
66
66
  results: [
67
67
  {
@@ -81,9 +81,9 @@ const server = setupServer(...[
81
81
  page: 1
82
82
  }
83
83
  }
84
- }));
84
+ });
85
85
  }),
86
- rest.get('/admin/users/1', (req, res, ctx)=>res(ctx.json({
86
+ http.get('/admin/users/1', ({ request })=>HttpResponse.json({
87
87
  data: {
88
88
  id: 1,
89
89
  firstname: 'John',
@@ -102,12 +102,12 @@ const server = setupServer(...[
102
102
  }
103
103
  ],
104
104
  params: {
105
- some: req.url.searchParams.get('some')
105
+ some: new URL(request.url).searchParams.get('some')
106
106
  }
107
107
  }
108
- }))),
109
- rest.get('/admin/users/me', (req, res, ctx)=>{
110
- return res(ctx.json({
108
+ })),
109
+ http.get('/admin/users/me', ()=>{
110
+ return HttpResponse.json({
111
111
  data: {
112
112
  id: 1,
113
113
  email: 'michka@michka.fr',
@@ -121,23 +121,23 @@ const server = setupServer(...[
121
121
  }
122
122
  ]
123
123
  }
124
- }));
124
+ });
125
125
  }),
126
- rest.get('/admin/users/me/permissions', (req, res, ctx)=>res(ctx.json({
126
+ http.get('/admin/users/me/permissions', ()=>HttpResponse.json({
127
127
  data: []
128
- }))),
128
+ })),
129
129
  /**
130
130
  *
131
131
  * ADMIN PROVIDERS
132
132
  *
133
- */ rest.get('/admin/providers/isSSOLocked', (req, res, ctx)=>{
134
- return res(ctx.json({
133
+ */ http.get('/admin/providers/isSSOLocked', ()=>{
134
+ return HttpResponse.json({
135
135
  data: {
136
136
  isSSOLocked: false
137
137
  }
138
- }));
138
+ });
139
139
  }),
140
- rest.put('/admin/providers/options', (req, res, ctx)=>res(ctx.json({
140
+ http.put('/admin/providers/options', ()=>HttpResponse.json({
141
141
  data: {
142
142
  autoRegister: false,
143
143
  defaultRole: '1',
@@ -147,8 +147,8 @@ const server = setupServer(...[
147
147
  '3'
148
148
  ]
149
149
  }
150
- }))),
151
- rest.get('/admin/providers/options', (req, res, ctx)=>res(ctx.json({
150
+ })),
151
+ http.get('/admin/providers/options', ()=>HttpResponse.json({
152
152
  data: {
153
153
  autoRegister: false,
154
154
  defaultRole: '1',
@@ -157,13 +157,13 @@ const server = setupServer(...[
157
157
  '2'
158
158
  ]
159
159
  }
160
- }))),
160
+ })),
161
161
  /**
162
162
  *
163
163
  * ADMIN PERMISSIONS
164
164
  *
165
- */ rest.get('/admin/permissions', (req, res, ctx)=>{
166
- const role = req.url.searchParams.get('role');
165
+ */ http.get('/admin/permissions', ({ request })=>{
166
+ const role = new URL(request.url).searchParams.get('role');
167
167
  const permissionsData = {
168
168
  conditions: [
169
169
  {
@@ -192,32 +192,34 @@ const server = setupServer(...[
192
192
  ]
193
193
  }
194
194
  };
195
- // role === '' is used by AdminPermissions (token permission layout, no role scoping)
195
+ // role === '' used by AdminPermissions (token permission layout, no role scoping)
196
196
  if (role === '1' || role === '') {
197
- return res(ctx.json({
197
+ return HttpResponse.json({
198
198
  data: permissionsData
199
- }));
199
+ });
200
200
  }
201
- return res(ctx.status(404));
201
+ return new HttpResponse(null, {
202
+ status: 404
203
+ });
202
204
  }),
203
205
  /**
204
206
  *
205
207
  * ADMIN MISC
206
208
  *
207
- */ rest.get('/admin/init', (req, res, ctx)=>{
208
- return res(ctx.json({
209
+ */ http.get('/admin/init', ()=>{
210
+ return HttpResponse.json({
209
211
  data: {}
210
- }));
212
+ });
211
213
  }),
212
- rest.get('/admin/information', (req, res, ctx)=>res(ctx.json({
214
+ http.get('/admin/information', ()=>HttpResponse.json({
213
215
  autoReload: true,
214
216
  communityEdition: false,
215
217
  currentEnvironment: 'development',
216
218
  nodeVersion: 'v14.13.1',
217
219
  strapiVersion: '3.6.0'
218
- }))),
219
- rest.get('/admin/license-limit-information', (req, res, ctx)=>{
220
- return res(ctx.json({
220
+ })),
221
+ http.get('/admin/license-limit-information', ()=>{
222
+ return HttpResponse.json({
221
223
  data: {
222
224
  attribute: 1,
223
225
  features: [
@@ -232,10 +234,10 @@ const server = setupServer(...[
232
234
  }
233
235
  ]
234
236
  }
235
- }));
237
+ });
236
238
  }),
237
- rest.get('/admin/project-settings', (req, res, ctx)=>{
238
- return res(ctx.json({
239
+ http.get('/admin/project-settings', ()=>{
240
+ return HttpResponse.json({
239
241
  menuLogo: {
240
242
  ext: '.svg',
241
243
  height: 256,
@@ -244,10 +246,10 @@ const server = setupServer(...[
244
246
  url: '/uploads/michka.svg',
245
247
  width: 256
246
248
  }
247
- }));
249
+ });
248
250
  }),
249
- rest.post('/admin/project-settings', (req, res, ctx)=>{
250
- return res(ctx.json({
251
+ http.post('/admin/project-settings', ()=>{
252
+ return HttpResponse.json({
251
253
  menuLogo: {
252
254
  ext: '.svg',
253
255
  height: 256,
@@ -256,10 +258,10 @@ const server = setupServer(...[
256
258
  url: '/uploads/michka.svg',
257
259
  width: 256
258
260
  }
259
- }));
261
+ });
260
262
  }),
261
- rest.get('/admin/transfer/tokens', (req, res, ctx)=>{
262
- return res(ctx.json({
263
+ http.get('/admin/transfer/tokens', ()=>{
264
+ return HttpResponse.json({
263
265
  data: [
264
266
  {
265
267
  id: 1,
@@ -270,10 +272,10 @@ const server = setupServer(...[
270
272
  permissions: []
271
273
  }
272
274
  ]
273
- }));
275
+ });
274
276
  }),
275
- rest.get('/admin/transfer/tokens/:id', (req, res, ctx)=>{
276
- return res(ctx.json({
277
+ http.get('/admin/transfer/tokens/:id', ()=>{
278
+ return HttpResponse.json({
277
279
  data: {
278
280
  id: 1,
279
281
  name: 'My super token',
@@ -282,64 +284,66 @@ const server = setupServer(...[
282
284
  createdAt: '2021-11-15T00:00:00.000Z',
283
285
  permissions: []
284
286
  }
285
- }));
287
+ });
286
288
  }),
287
- rest.get('/admin/registration-info', async (req, res, ctx)=>{
288
- const token = req.url.searchParams.get('registrationToken');
289
+ http.get('/admin/registration-info', ({ request })=>{
290
+ const token = new URL(request.url).searchParams.get('registrationToken');
289
291
  if (token === 'error') {
290
- return res(ctx.status(500), ctx.json({}));
292
+ return HttpResponse.json({}, {
293
+ status: 500
294
+ });
291
295
  }
292
- return res(ctx.json({
296
+ return HttpResponse.json({
293
297
  data: {
294
298
  firstname: 'Token firstname',
295
299
  lastname: 'Token lastname',
296
300
  email: 'test+register-token@strapi.io'
297
301
  }
298
- }));
302
+ });
299
303
  }),
300
- rest.post('/admin/renew-token', (req, res, ctx)=>{
301
- return res(ctx.json({
304
+ http.post('/admin/renew-token', ()=>{
305
+ return HttpResponse.json({
302
306
  data: {
303
307
  token: 'renewed-test-token'
304
308
  }
305
- }));
309
+ });
306
310
  }),
307
- rest.get('/admin/guided-tour-meta', (req, res, ctx)=>{
308
- return res(ctx.json({
311
+ http.get('/admin/guided-tour-meta', ()=>{
312
+ return HttpResponse.json({
309
313
  data: {
310
314
  isFirstSuperAdminUser: false,
311
315
  completedActions: []
312
316
  }
313
- }));
317
+ });
314
318
  }),
315
319
  /**
316
320
  * WEBHOOKS
317
- */ rest.get('/admin/webhooks', (req, res, ctx)=>{
318
- return res(ctx.json({
321
+ */ http.get('/admin/webhooks', ()=>{
322
+ return HttpResponse.json({
319
323
  data: mockData.webhooks
320
- }));
324
+ });
321
325
  }),
322
- rest.post('/admin/webhooks/batch-delete', async (req, res, ctx)=>{
323
- const { ids } = await req.json();
324
- return res(ctx.json({
326
+ http.post('/admin/webhooks/batch-delete', async ({ request })=>{
327
+ const { ids } = await request.json();
328
+ return HttpResponse.json({
325
329
  data: mockData.webhooks.filter((webhook)=>!ids.includes(webhook.id))
326
- }));
330
+ });
327
331
  }),
328
- rest.put('/admin/webhooks/:id', async (req, res, ctx)=>{
329
- const { id } = req.params;
330
- const { isEnabled } = await req.json();
331
- return res(ctx.json({
332
+ http.put('/admin/webhooks/:id', async ({ request, params })=>{
333
+ const { id } = params;
334
+ const { isEnabled } = await request.json();
335
+ return HttpResponse.json({
332
336
  data: mockData.webhooks.map((webhook)=>webhook.id === Number(id) ? {
333
337
  ...webhook,
334
338
  isEnabled
335
339
  } : webhook)
336
- }));
340
+ });
337
341
  }),
338
342
  /**
339
343
  *
340
344
  * CONTENT_MANAGER
341
345
  *
342
- */ rest.get('/content-manager/content-types', (req, res, ctx)=>res(ctx.json({
346
+ */ http.get('/content-manager/content-types', ()=>HttpResponse.json({
343
347
  data: [
344
348
  {
345
349
  uid: 'admin::collectionType',
@@ -364,8 +368,8 @@ const server = setupServer(...[
364
368
  kind: 'singleType'
365
369
  }
366
370
  ]
367
- }))),
368
- rest.get('/content-manager/components', (req, res, ctx)=>res(ctx.json({
371
+ })),
372
+ http.get('/content-manager/components', ()=>HttpResponse.json({
369
373
  data: [
370
374
  {
371
375
  uid: 'basic.relation',
@@ -390,18 +394,18 @@ const server = setupServer(...[
390
394
  }
391
395
  }
392
396
  ]
393
- }))),
397
+ })),
394
398
  /**
395
399
  *
396
400
  * NPS SURVEY
397
401
  *
398
- */ rest.post('https://analytics.strapi.io/submit-nps', (req, res, ctx)=>{
399
- return res(ctx.status(200));
402
+ */ http.post('https://analytics.strapi.io/submit-nps', ()=>{
403
+ return new HttpResponse();
400
404
  }),
401
405
  /**
402
406
  * CONTENT-API (API TOKENS)
403
- */ rest.get('/admin/content-api/permissions', (req, res, ctx)=>{
404
- return res(ctx.json({
407
+ */ http.get('/admin/content-api/permissions', ()=>{
408
+ return HttpResponse.json({
405
409
  data: {
406
410
  'api::address': {
407
411
  controllers: {
@@ -420,10 +424,10 @@ const server = setupServer(...[
420
424
  }
421
425
  }
422
426
  }
423
- }));
427
+ });
424
428
  }),
425
- rest.get('/admin/content-api/routes', (req, res, ctx)=>{
426
- return res(ctx.json({
429
+ http.get('/admin/content-api/routes', ()=>{
430
+ return HttpResponse.json({
427
431
  data: {
428
432
  'api::address': [
429
433
  {
@@ -494,12 +498,12 @@ const server = setupServer(...[
494
498
  }
495
499
  ]
496
500
  }
497
- }));
501
+ });
498
502
  }),
499
503
  /**
500
504
  * API TOKENS
501
- */ rest.get('/admin/api-tokens', (req, res, ctx)=>{
502
- return res(ctx.json({
505
+ */ http.get('/admin/api-tokens', ()=>{
506
+ return HttpResponse.json({
503
507
  data: [
504
508
  {
505
509
  id: '1',
@@ -511,12 +515,12 @@ const server = setupServer(...[
511
515
  permissions: []
512
516
  }
513
517
  ]
514
- }));
518
+ });
515
519
  }),
516
- rest.get('/admin/api-tokens/:id', (req, res, ctx)=>{
517
- const { id } = req.params;
520
+ http.get('/admin/api-tokens/:id', ({ params })=>{
521
+ const { id } = params;
518
522
  if (id === '2') {
519
- return res(ctx.json({
523
+ return HttpResponse.json({
520
524
  data: {
521
525
  id: '2',
522
526
  name: 'My admin token',
@@ -531,9 +535,9 @@ const server = setupServer(...[
531
535
  },
532
536
  createdAt: '2021-11-15T00:00:00.000Z'
533
537
  }
534
- }));
538
+ });
535
539
  }
536
- return res(ctx.json({
540
+ return HttpResponse.json({
537
541
  data: {
538
542
  id: '1',
539
543
  name: 'My super token',
@@ -543,12 +547,12 @@ const server = setupServer(...[
543
547
  createdAt: '2021-11-15T00:00:00.000Z',
544
548
  permissions: []
545
549
  }
546
- }));
550
+ });
547
551
  }),
548
552
  /**
549
553
  * ADMIN TOKENS
550
- */ rest.get('/admin/admin-tokens', (req, res, ctx)=>{
551
- return res(ctx.json({
554
+ */ http.get('/admin/admin-tokens', ()=>{
555
+ return HttpResponse.json({
552
556
  data: [
553
557
  {
554
558
  id: '1',
@@ -565,10 +569,10 @@ const server = setupServer(...[
565
569
  createdAt: '2021-11-15T00:00:00.000Z'
566
570
  }
567
571
  ]
568
- }));
572
+ });
569
573
  }),
570
- rest.get('/admin/admin-tokens/:id', (req, res, ctx)=>{
571
- return res(ctx.json({
574
+ http.get('/admin/admin-tokens/:id', ()=>{
575
+ return HttpResponse.json({
572
576
  data: {
573
577
  id: '1',
574
578
  name: 'My admin token',
@@ -583,17 +587,17 @@ const server = setupServer(...[
583
587
  },
584
588
  createdAt: '2021-11-15T00:00:00.000Z'
585
589
  }
586
- }));
590
+ });
587
591
  }),
588
- rest.get('/admin/admin-tokens/:id/owner-permissions', (req, res, ctx)=>{
589
- return res(ctx.json({
592
+ http.get('/admin/admin-tokens/:id/owner-permissions', ()=>{
593
+ return HttpResponse.json({
590
594
  data: []
591
- }));
595
+ });
592
596
  }),
593
597
  /**
594
598
  * Audit Logs
595
- */ rest.get('/admin/audit-logs', (req, res, ctx)=>{
596
- return res(ctx.json({
599
+ */ http.get('/admin/audit-logs', ()=>{
600
+ return HttpResponse.json({
597
601
  results: [
598
602
  {
599
603
  id: 1,
@@ -666,10 +670,10 @@ const server = setupServer(...[
666
670
  pageCount: 1,
667
671
  total: 2
668
672
  }
669
- }));
673
+ });
670
674
  }),
671
- rest.get('/admin/audit-logs/:id', (req, res, ctx)=>{
672
- return res(ctx.json({
675
+ http.get('/admin/audit-logs/:id', ()=>{
676
+ return HttpResponse.json({
673
677
  id: 1,
674
678
  action: 'admin.logout',
675
679
  date: '2023-10-31T15:56:54.873Z',
@@ -700,14 +704,14 @@ const server = setupServer(...[
700
704
  email: 'test@testing.com',
701
705
  displayName: 'test testing'
702
706
  }
703
- }));
707
+ });
704
708
  }),
705
709
  /**
706
710
  *
707
711
  * fetchClient, useFetchClient and getFetchClient
708
712
  *
709
- */ rest.get('/use-fetch-client-test', (req, res, ctx)=>{
710
- return res(ctx.json({
713
+ */ http.get('/use-fetch-client-test', ()=>{
714
+ return HttpResponse.json({
711
715
  data: {
712
716
  results: [
713
717
  {
@@ -726,10 +730,10 @@ const server = setupServer(...[
726
730
  pageCount: 10
727
731
  }
728
732
  }
729
- }));
733
+ });
730
734
  }),
731
- rest.get('/test-fetch-client', (req, res, ctx)=>{
732
- return res(ctx.status(200));
735
+ http.get('/test-fetch-client', ()=>{
736
+ return new HttpResponse();
733
737
  })
734
738
  ]);
735
739