@akemona-org/strapi-plugin-users-permissions 3.7.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 (143) hide show
  1. package/LICENSE +22 -0
  2. package/README.md +19 -0
  3. package/admin/src/assets/images/logo.svg +1 -0
  4. package/admin/src/components/BaselineAlignement/index.js +33 -0
  5. package/admin/src/components/Bloc/index.js +10 -0
  6. package/admin/src/components/BoundRoute/Components.js +78 -0
  7. package/admin/src/components/BoundRoute/index.js +56 -0
  8. package/admin/src/components/ContainerFluid/index.js +13 -0
  9. package/admin/src/components/FormBloc/index.js +61 -0
  10. package/admin/src/components/IntlInput/index.js +38 -0
  11. package/admin/src/components/ListBaselineAlignment/index.js +8 -0
  12. package/admin/src/components/ListRow/Components.js +74 -0
  13. package/admin/src/components/ListRow/index.js +35 -0
  14. package/admin/src/components/ModalForm/Wrapper.js +12 -0
  15. package/admin/src/components/ModalForm/index.js +59 -0
  16. package/admin/src/components/Permissions/ListWrapper.js +9 -0
  17. package/admin/src/components/Permissions/PermissionRow/BaselineAlignment.js +7 -0
  18. package/admin/src/components/Permissions/PermissionRow/CheckboxWrapper.js +37 -0
  19. package/admin/src/components/Permissions/PermissionRow/RowStyle.js +28 -0
  20. package/admin/src/components/Permissions/PermissionRow/SubCategory/ConditionsButtonWrapper.js +13 -0
  21. package/admin/src/components/Permissions/PermissionRow/SubCategory/PolicyWrapper.js +8 -0
  22. package/admin/src/components/Permissions/PermissionRow/SubCategory/SubCategoryWrapper.js +26 -0
  23. package/admin/src/components/Permissions/PermissionRow/SubCategory/index.js +116 -0
  24. package/admin/src/components/Permissions/PermissionRow/index.js +92 -0
  25. package/admin/src/components/Permissions/index.js +44 -0
  26. package/admin/src/components/Permissions/init.js +14 -0
  27. package/admin/src/components/Permissions/reducer.js +27 -0
  28. package/admin/src/components/Policies/Components.js +26 -0
  29. package/admin/src/components/Policies/index.js +61 -0
  30. package/admin/src/components/PrefixedIcon/index.js +27 -0
  31. package/admin/src/components/Roles/EmptyRole/BaselineAlignment.js +7 -0
  32. package/admin/src/components/Roles/EmptyRole/index.js +27 -0
  33. package/admin/src/components/Roles/RoleListWrapper/index.js +17 -0
  34. package/admin/src/components/Roles/RoleRow/RoleDescription.js +9 -0
  35. package/admin/src/components/Roles/RoleRow/index.js +45 -0
  36. package/admin/src/components/Roles/index.js +3 -0
  37. package/admin/src/components/SizedInput/index.js +24 -0
  38. package/admin/src/components/UsersPermissions/index.js +91 -0
  39. package/admin/src/components/UsersPermissions/init.js +11 -0
  40. package/admin/src/components/UsersPermissions/reducer.js +60 -0
  41. package/admin/src/containers/AdvancedSettings/index.js +218 -0
  42. package/admin/src/containers/AdvancedSettings/reducer.js +65 -0
  43. package/admin/src/containers/AdvancedSettings/utils/form.js +52 -0
  44. package/admin/src/containers/EmailTemplates/CustomTextInput.js +105 -0
  45. package/admin/src/containers/EmailTemplates/Wrapper.js +36 -0
  46. package/admin/src/containers/EmailTemplates/index.js +222 -0
  47. package/admin/src/containers/EmailTemplates/reducer.js +58 -0
  48. package/admin/src/containers/EmailTemplates/utils/forms.js +81 -0
  49. package/admin/src/containers/EmailTemplates/utils/schema.js +25 -0
  50. package/admin/src/containers/Providers/index.js +283 -0
  51. package/admin/src/containers/Providers/reducer.js +54 -0
  52. package/admin/src/containers/Providers/utils/createProvidersArray.js +21 -0
  53. package/admin/src/containers/Providers/utils/forms.js +205 -0
  54. package/admin/src/containers/Roles/CreatePage/index.js +167 -0
  55. package/admin/src/containers/Roles/CreatePage/utils/schema.js +9 -0
  56. package/admin/src/containers/Roles/EditPage/index.js +161 -0
  57. package/admin/src/containers/Roles/EditPage/utils/schema.js +9 -0
  58. package/admin/src/containers/Roles/ListPage/BaselineAlignment.js +8 -0
  59. package/admin/src/containers/Roles/ListPage/index.js +188 -0
  60. package/admin/src/containers/Roles/ProtectedCreatePage/index.js +12 -0
  61. package/admin/src/containers/Roles/ProtectedEditPage/index.js +12 -0
  62. package/admin/src/containers/Roles/ProtectedListPage/index.js +15 -0
  63. package/admin/src/containers/Roles/index.js +35 -0
  64. package/admin/src/contexts/EditPage/index.js +26 -0
  65. package/admin/src/contexts/HomePage/index.js +27 -0
  66. package/admin/src/contexts/UsersPermissionsContext/index.js +17 -0
  67. package/admin/src/hooks/index.js +5 -0
  68. package/admin/src/hooks/useFetchRole/index.js +55 -0
  69. package/admin/src/hooks/useFetchRole/reducer.js +31 -0
  70. package/admin/src/hooks/useForm/index.js +96 -0
  71. package/admin/src/hooks/useForm/reducer.js +59 -0
  72. package/admin/src/hooks/usePlugins/index.js +73 -0
  73. package/admin/src/hooks/usePlugins/init.js +5 -0
  74. package/admin/src/hooks/usePlugins/reducer.js +37 -0
  75. package/admin/src/hooks/useRolesList/index.js +62 -0
  76. package/admin/src/hooks/useRolesList/init.js +5 -0
  77. package/admin/src/hooks/useRolesList/reducer.js +31 -0
  78. package/admin/src/index.js +109 -0
  79. package/admin/src/permissions.js +33 -0
  80. package/admin/src/pluginId.js +5 -0
  81. package/admin/src/translations/ar.json +49 -0
  82. package/admin/src/translations/cs.json +55 -0
  83. package/admin/src/translations/de.json +68 -0
  84. package/admin/src/translations/dk.json +116 -0
  85. package/admin/src/translations/en.json +104 -0
  86. package/admin/src/translations/es.json +70 -0
  87. package/admin/src/translations/fr.json +55 -0
  88. package/admin/src/translations/id.json +69 -0
  89. package/admin/src/translations/index.js +55 -0
  90. package/admin/src/translations/it.json +68 -0
  91. package/admin/src/translations/ja.json +53 -0
  92. package/admin/src/translations/ko.json +55 -0
  93. package/admin/src/translations/ms.json +54 -0
  94. package/admin/src/translations/nl.json +53 -0
  95. package/admin/src/translations/pl.json +55 -0
  96. package/admin/src/translations/pt-BR.json +49 -0
  97. package/admin/src/translations/pt.json +53 -0
  98. package/admin/src/translations/ru.json +68 -0
  99. package/admin/src/translations/sk.json +57 -0
  100. package/admin/src/translations/sv.json +68 -0
  101. package/admin/src/translations/th.json +66 -0
  102. package/admin/src/translations/tr.json +53 -0
  103. package/admin/src/translations/uk.json +54 -0
  104. package/admin/src/translations/vi.json +55 -0
  105. package/admin/src/translations/zh-Hans.json +104 -0
  106. package/admin/src/translations/zh.json +53 -0
  107. package/admin/src/utils/cleanPermissions.js +25 -0
  108. package/admin/src/utils/formatPolicies.js +8 -0
  109. package/admin/src/utils/getRequestURL.js +5 -0
  110. package/admin/src/utils/getTrad.js +5 -0
  111. package/admin/src/utils/index.js +4 -0
  112. package/config/functions/bootstrap.js +234 -0
  113. package/config/layout.js +10 -0
  114. package/config/policies/isAuthenticated.js +9 -0
  115. package/config/policies/permissions.js +93 -0
  116. package/config/policies/rateLimit.js +33 -0
  117. package/config/request.json +6 -0
  118. package/config/routes.json +397 -0
  119. package/config/schema.graphql.js +280 -0
  120. package/config/security.json +5 -0
  121. package/config/users-permissions-actions.js +80 -0
  122. package/controllers/Auth.js +612 -0
  123. package/controllers/User.js +125 -0
  124. package/controllers/UsersPermissions.js +291 -0
  125. package/controllers/user/admin.js +224 -0
  126. package/controllers/user/api.js +173 -0
  127. package/controllers/validation/email-template.js +40 -0
  128. package/documentation/1.0.0/overrides/users-permissions-Role.json +281 -0
  129. package/documentation/1.0.0/overrides/users-permissions-User.json +325 -0
  130. package/middlewares/users-permissions/defaults.json +5 -0
  131. package/middlewares/users-permissions/index.js +40 -0
  132. package/models/Permission.js +7 -0
  133. package/models/Permission.settings.json +43 -0
  134. package/models/Role.js +7 -0
  135. package/models/Role.settings.json +42 -0
  136. package/models/User.config.js +15 -0
  137. package/models/User.js +7 -0
  138. package/models/User.settings.json +62 -0
  139. package/package.json +70 -0
  140. package/services/Jwt.js +65 -0
  141. package/services/Providers.js +596 -0
  142. package/services/User.js +167 -0
  143. package/services/UsersPermissions.js +416 -0
@@ -0,0 +1,397 @@
1
+ {
2
+ "routes": [
3
+ {
4
+ "method": "GET",
5
+ "path": "/",
6
+ "handler": "UsersPermissions.index",
7
+ "config": {
8
+ "policies": []
9
+ }
10
+ },
11
+ {
12
+ "method": "GET",
13
+ "path": "/search/:id",
14
+ "handler": "UsersPermissions.searchUsers",
15
+ "config": {
16
+ "policies": [],
17
+ "description": "Search for users",
18
+ "tag": {
19
+ "plugin": "users-permissions",
20
+ "name": "User",
21
+ "actionType": "find"
22
+ }
23
+ }
24
+ },
25
+ {
26
+ "method": "GET",
27
+ "path": "/policies",
28
+ "handler": "UsersPermissions.getPolicies",
29
+ "config": {
30
+ "policies": []
31
+ }
32
+ },
33
+ {
34
+ "method": "GET",
35
+ "path": "/roles/:id",
36
+ "handler": "UsersPermissions.getRole",
37
+ "config": {
38
+ "policies": [
39
+ ["admin::hasPermissions", ["plugins::users-permissions.roles.read"]]
40
+ ],
41
+ "description": "Retrieve a role depending on its id",
42
+ "tag": {
43
+ "plugin": "users-permissions",
44
+ "name": "Role",
45
+ "actionType": "findOne"
46
+ }
47
+ }
48
+ },
49
+ {
50
+ "method": "GET",
51
+ "path": "/roles",
52
+ "handler": "UsersPermissions.getRoles",
53
+ "config": {
54
+ "policies": [
55
+ ["admin::hasPermissions", ["plugins::users-permissions.roles.read"]]
56
+ ],
57
+ "description": "Retrieve all role documents",
58
+ "tag": {
59
+ "plugin": "users-permissions",
60
+ "name": "Role",
61
+ "actionType": "find"
62
+ }
63
+ }
64
+ },
65
+ {
66
+ "method": "GET",
67
+ "path": "/routes",
68
+ "handler": "UsersPermissions.getRoutes",
69
+ "config": {
70
+ "policies": []
71
+ }
72
+ },
73
+ {
74
+ "method": "GET",
75
+ "path": "/email-templates",
76
+ "handler": "UsersPermissions.getEmailTemplate",
77
+ "config": {
78
+ "policies": [
79
+ ["admin::hasPermissions", ["plugins::users-permissions.email-templates.read"]]
80
+ ]
81
+ }
82
+ },
83
+ {
84
+ "method": "PUT",
85
+ "path": "/email-templates",
86
+ "handler": "UsersPermissions.updateEmailTemplate",
87
+ "config": {
88
+ "policies": [
89
+ ["admin::hasPermissions", ["plugins::users-permissions.email-templates.update"]]
90
+ ]
91
+ }
92
+ },
93
+ {
94
+ "method": "GET",
95
+ "path": "/advanced",
96
+ "handler": "UsersPermissions.getAdvancedSettings",
97
+ "config": {
98
+ "policies": [
99
+ ["admin::hasPermissions", ["plugins::users-permissions.advanced-settings.read"]]
100
+ ]
101
+ }
102
+ },
103
+ {
104
+ "method": "PUT",
105
+ "path": "/advanced",
106
+ "handler": "UsersPermissions.updateAdvancedSettings",
107
+ "config": {
108
+ "policies": [
109
+ ["admin::hasPermissions", ["plugins::users-permissions.advanced-settings.update"]]
110
+ ]
111
+ }
112
+ },
113
+ {
114
+ "method": "GET",
115
+ "path": "/permissions",
116
+ "handler": "UsersPermissions.getPermissions",
117
+ "config": {
118
+ "policies": []
119
+ }
120
+ },
121
+ {
122
+ "method": "GET",
123
+ "path": "/providers",
124
+ "handler": "UsersPermissions.getProviders",
125
+ "config": {
126
+ "policies": [
127
+ ["admin::hasPermissions", ["plugins::users-permissions.providers.read"]]
128
+ ]
129
+ }
130
+ },
131
+
132
+ {
133
+ "method": "PUT",
134
+ "path": "/providers",
135
+ "handler": "UsersPermissions.updateProviders",
136
+ "config": {
137
+ "policies": [
138
+ ["admin::hasPermissions", ["plugins::users-permissions.providers.update"]]
139
+ ]
140
+ }
141
+ },
142
+ {
143
+ "method": "POST",
144
+ "path": "/roles",
145
+ "handler": "UsersPermissions.createRole",
146
+ "config": {
147
+ "policies": [
148
+ ["admin::hasPermissions", ["plugins::users-permissions.roles.create"]]
149
+ ],
150
+ "description": "Create a new role",
151
+ "tag": {
152
+ "plugin": "users-permissions",
153
+ "name": "Role",
154
+ "actionType": "create"
155
+ }
156
+ }
157
+ },
158
+ {
159
+ "method": "PUT",
160
+ "path": "/roles/:role",
161
+ "handler": "UsersPermissions.updateRole",
162
+ "config": {
163
+ "policies": [
164
+ ["admin::hasPermissions", ["plugins::users-permissions.roles.update"]]
165
+ ],
166
+ "description": "Update a role",
167
+ "tag": {
168
+ "plugin": "users-permissions",
169
+ "name": "Role",
170
+ "actionType": "update"
171
+ }
172
+ }
173
+ },
174
+ {
175
+ "method": "DELETE",
176
+ "path": "/roles/:role",
177
+ "handler": "UsersPermissions.deleteRole",
178
+ "config": {
179
+ "policies": [
180
+ ["admin::hasPermissions", ["plugins::users-permissions.roles.delete"]]
181
+ ],
182
+ "description": "Delete a role",
183
+ "tag": {
184
+ "plugin": "users-permissions",
185
+ "name": "Role",
186
+ "actionType": "destroy"
187
+ }
188
+ }
189
+ },
190
+ {
191
+ "method": "GET",
192
+ "path": "/connect/*",
193
+ "handler": "Auth.connect",
194
+ "config": {
195
+ "policies": ["plugins::users-permissions.ratelimit"],
196
+ "prefix": "",
197
+ "description": "Connect a provider",
198
+ "tag": {
199
+ "plugin": "users-permissions",
200
+ "name": "User"
201
+ }
202
+ }
203
+ },
204
+ {
205
+ "method": "POST",
206
+ "path": "/auth/local",
207
+ "handler": "Auth.callback",
208
+ "config": {
209
+ "policies": ["plugins::users-permissions.ratelimit"],
210
+ "prefix": "",
211
+ "description": "Login a user using the identifiers email and password",
212
+ "tag": {
213
+ "plugin": "users-permissions",
214
+ "name": "User"
215
+ }
216
+ }
217
+ },
218
+ {
219
+ "method": "POST",
220
+ "path": "/auth/local/register",
221
+ "handler": "Auth.register",
222
+ "config": {
223
+ "policies": ["plugins::users-permissions.ratelimit"],
224
+ "prefix": "",
225
+ "description": "Register a new user with the default role",
226
+ "tag": {
227
+ "plugin": "users-permissions",
228
+ "name": "User",
229
+ "actionType": "create"
230
+ }
231
+ }
232
+ },
233
+ {
234
+ "method": "GET",
235
+ "path": "/auth/:provider/callback",
236
+ "handler": "Auth.callback",
237
+ "config": {
238
+ "policies": [],
239
+ "prefix": "",
240
+ "description": "Successfull redirection after approving a provider",
241
+ "tag": {
242
+ "plugin": "users-permissions",
243
+ "name": "User"
244
+ }
245
+ }
246
+ },
247
+ {
248
+ "method": "POST",
249
+ "path": "/auth/forgot-password",
250
+ "handler": "Auth.forgotPassword",
251
+ "config": {
252
+ "policies": ["plugins::users-permissions.ratelimit"],
253
+ "prefix": "",
254
+ "description": "Send the reset password email link",
255
+ "tag": {
256
+ "plugin": "users-permissions",
257
+ "name": "User"
258
+ }
259
+ }
260
+ },
261
+ {
262
+ "method": "POST",
263
+ "path": "/auth/reset-password",
264
+ "handler": "Auth.resetPassword",
265
+ "config": {
266
+ "policies": ["plugins::users-permissions.ratelimit"],
267
+ "prefix": "",
268
+ "description": "Reset user password with a code (resetToken)",
269
+ "tag": {
270
+ "plugin": "users-permissions",
271
+ "name": "User"
272
+ }
273
+ }
274
+ },
275
+ {
276
+ "method": "GET",
277
+ "path": "/auth/email-confirmation",
278
+ "handler": "Auth.emailConfirmation",
279
+ "config": {
280
+ "policies": [],
281
+ "prefix": "",
282
+ "description": "Validate a user account",
283
+ "tag": {
284
+ "plugin": "users-permissions",
285
+ "name": "User"
286
+ }
287
+ }
288
+ },
289
+ {
290
+ "method": "POST",
291
+ "path": "/auth/send-email-confirmation",
292
+ "handler": "Auth.sendEmailConfirmation",
293
+ "config": {
294
+ "policies": [],
295
+ "prefix": "",
296
+ "description": "Send a confirmation email to user",
297
+ "tag": {
298
+ "plugin": "users-permissions",
299
+ "name": "User"
300
+ }
301
+ }
302
+ },
303
+ {
304
+ "method": "GET",
305
+ "path": "/users/count",
306
+ "handler": "User.count",
307
+ "config": {
308
+ "prefix": "",
309
+ "policies": []
310
+ }
311
+ },
312
+ {
313
+ "method": "GET",
314
+ "path": "/users",
315
+ "handler": "User.find",
316
+ "config": {
317
+ "policies": [],
318
+ "prefix": "",
319
+ "description": "Retrieve all user documents",
320
+ "tag": {
321
+ "plugin": "users-permissions",
322
+ "name": "User",
323
+ "actionType": "find"
324
+ }
325
+ }
326
+ },
327
+ {
328
+ "method": "GET",
329
+ "path": "/users/me",
330
+ "handler": "User.me",
331
+ "config": {
332
+ "policies": [],
333
+ "prefix": "",
334
+ "description": "Retrieve the logged in user information",
335
+ "tag": {
336
+ "plugin": "users-permissions",
337
+ "name": "User",
338
+ "actionType": "findOne"
339
+ }
340
+ }
341
+ },
342
+ {
343
+ "method": "GET",
344
+ "path": "/users/:id",
345
+ "handler": "User.findOne",
346
+ "config": {
347
+ "policies": [],
348
+ "prefix": "",
349
+ "description": "Retrieve a single user depending on his id",
350
+ "tag": {
351
+ "plugin": "users-permissions",
352
+ "name": "User",
353
+ "actionType": "findOne"
354
+ }
355
+ }
356
+ },
357
+ {
358
+ "method": "POST",
359
+ "path": "/users",
360
+ "handler": "User.create",
361
+ "config": {
362
+ "policies": [],
363
+ "prefix": ""
364
+ }
365
+ },
366
+ {
367
+ "method": "PUT",
368
+ "path": "/users/:id",
369
+ "handler": "User.update",
370
+ "config": {
371
+ "policies": [],
372
+ "prefix": "",
373
+ "description": "Update an existing user",
374
+ "tag": {
375
+ "plugin": "users-permissions",
376
+ "name": "User",
377
+ "actionType": "update"
378
+ }
379
+ }
380
+ },
381
+ {
382
+ "method": "DELETE",
383
+ "path": "/users/:id",
384
+ "handler": "User.destroy",
385
+ "config": {
386
+ "policies": [],
387
+ "prefix": "",
388
+ "description": "Delete an existing user",
389
+ "tag": {
390
+ "plugin": "users-permissions",
391
+ "name": "User",
392
+ "actionType": "destroy"
393
+ }
394
+ }
395
+ }
396
+ ]
397
+ }
@@ -0,0 +1,280 @@
1
+ 'use strict';
2
+
3
+ const _ = require('lodash');
4
+
5
+ /**
6
+ * Throws an ApolloError if context body contains a bad request
7
+ * @param contextBody - body of the context object given to the resolver
8
+ * @throws ApolloError if the body is a bad request
9
+ */
10
+ function checkBadRequest(contextBody) {
11
+ if (_.get(contextBody, 'statusCode', 200) !== 200) {
12
+ const message = _.get(contextBody, 'error', 'Bad Request');
13
+ const exception = new Error(message);
14
+ exception.code = _.get(contextBody, 'statusCode', 400);
15
+ exception.data = contextBody;
16
+ throw exception;
17
+ }
18
+ }
19
+
20
+ module.exports = {
21
+ type: {
22
+ UsersPermissionsPermission: false, // Make this type NOT queriable.
23
+ },
24
+ definition: /* GraphQL */ `
25
+ type UsersPermissionsMe {
26
+ id: ID!
27
+ username: String!
28
+ email: String!
29
+ confirmed: Boolean
30
+ blocked: Boolean
31
+ role: UsersPermissionsMeRole
32
+ }
33
+
34
+ type UsersPermissionsMeRole {
35
+ id: ID!
36
+ name: String!
37
+ description: String
38
+ type: String
39
+ }
40
+
41
+ input UsersPermissionsRegisterInput {
42
+ username: String!
43
+ email: String!
44
+ password: String!
45
+ }
46
+
47
+ input UsersPermissionsLoginInput {
48
+ identifier: String!
49
+ password: String!
50
+ provider: String = "local"
51
+ }
52
+
53
+ type UsersPermissionsLoginPayload {
54
+ jwt: String
55
+ user: UsersPermissionsMe!
56
+ }
57
+
58
+ type UserPermissionsPasswordPayload {
59
+ ok: Boolean!
60
+ }
61
+ `,
62
+ query: `
63
+ me: UsersPermissionsMe
64
+ `,
65
+ mutation: `
66
+ login(input: UsersPermissionsLoginInput!): UsersPermissionsLoginPayload!
67
+ register(input: UsersPermissionsRegisterInput!): UsersPermissionsLoginPayload!
68
+ forgotPassword(email: String!): UserPermissionsPasswordPayload
69
+ resetPassword(password: String!, passwordConfirmation: String!, code: String!): UsersPermissionsLoginPayload
70
+ emailConfirmation(confirmation: String!): UsersPermissionsLoginPayload
71
+ `,
72
+ resolver: {
73
+ Query: {
74
+ me: {
75
+ resolver: 'plugins::users-permissions.user.me',
76
+ },
77
+ role: {
78
+ resolverOf: 'plugins::users-permissions.userspermissions.getRole',
79
+ resolver: async (obj, options, { context }) => {
80
+ context.params = { ...context.params, ...options.input };
81
+
82
+ await strapi.plugins['users-permissions'].controllers.userspermissions.getRole(context);
83
+
84
+ return context.body.role;
85
+ },
86
+ },
87
+ roles: {
88
+ description: `Retrieve all the existing roles. You can't apply filters on this query.`,
89
+ resolverOf: 'plugins::users-permissions.userspermissions.getRoles', // Apply the `getRoles` permissions on the resolver.
90
+ resolver: async (obj, options, { context }) => {
91
+ context.params = { ...context.params, ...options.input };
92
+
93
+ await strapi.plugins['users-permissions'].controllers.userspermissions.getRoles(context);
94
+
95
+ return context.body.roles;
96
+ },
97
+ },
98
+ },
99
+ Mutation: {
100
+ createRole: {
101
+ description: 'Create a new role',
102
+ resolverOf: 'plugins::users-permissions.userspermissions.createRole',
103
+ resolver: async (obj, options, { context }) => {
104
+ await strapi.plugins['users-permissions'].controllers.userspermissions.createRole(
105
+ context
106
+ );
107
+
108
+ return { ok: true };
109
+ },
110
+ },
111
+ updateRole: {
112
+ description: 'Update an existing role',
113
+ resolverOf: 'plugins::users-permissions.userspermissions.updateRole',
114
+ resolver: async (obj, options, { context }) => {
115
+ context.params = { ...context.params, ...options.input };
116
+ context.params.role = context.params.id;
117
+
118
+ await strapi.plugins['users-permissions'].controllers.userspermissions.updateRole(
119
+ context
120
+ );
121
+
122
+ return { ok: true };
123
+ },
124
+ },
125
+ deleteRole: {
126
+ description: 'Delete an existing role',
127
+ resolverOf: 'plugins::users-permissions.userspermissions.deleteRole',
128
+ resolver: async (obj, options, { context }) => {
129
+ context.params = { ...context.params, ...options.input };
130
+ context.params.role = context.params.id;
131
+
132
+ await strapi.plugins['users-permissions'].controllers.userspermissions.deleteRole(
133
+ context
134
+ );
135
+
136
+ return { ok: true };
137
+ },
138
+ },
139
+ createUser: {
140
+ description: 'Create a new user',
141
+ resolverOf: 'plugins::users-permissions.user.create',
142
+ resolver: async (obj, options, { context }) => {
143
+ context.params = _.toPlainObject(options.input.where);
144
+ context.request.body = _.toPlainObject(options.input.data);
145
+
146
+ await strapi.plugins['users-permissions'].controllers.user.create(context);
147
+
148
+ return {
149
+ user: context.body.toJSON ? context.body.toJSON() : context.body,
150
+ };
151
+ },
152
+ },
153
+ updateUser: {
154
+ description: 'Update an existing user',
155
+ resolverOf: 'plugins::users-permissions.user.update',
156
+ resolver: async (obj, options, { context }) => {
157
+ context.params = _.toPlainObject(options.input.where);
158
+ context.request.body = _.toPlainObject(options.input.data);
159
+
160
+ await strapi.plugins['users-permissions'].controllers.user.update(context);
161
+
162
+ return {
163
+ user: context.body.toJSON ? context.body.toJSON() : context.body,
164
+ };
165
+ },
166
+ },
167
+ deleteUser: {
168
+ description: 'Delete an existing user',
169
+ resolverOf: 'plugins::users-permissions.user.destroy',
170
+ resolver: async (obj, options, { context }) => {
171
+ // Set parameters to context.
172
+ context.params = _.toPlainObject(options.input.where);
173
+ context.request.body = _.toPlainObject(options.input.data);
174
+
175
+ // Retrieve user to be able to return it because
176
+ // Bookshelf doesn't return the row once deleted.
177
+ await strapi.plugins['users-permissions'].controllers.user.findOne(context);
178
+ // Assign result to user.
179
+ const user = context.body.toJSON ? context.body.toJSON() : context.body;
180
+
181
+ // Run destroy query.
182
+ await strapi.plugins['users-permissions'].controllers.user.destroy(context);
183
+
184
+ return {
185
+ user,
186
+ };
187
+ },
188
+ },
189
+ register: {
190
+ description: 'Register a user',
191
+ resolverOf: 'plugins::users-permissions.auth.register',
192
+ resolver: async (obj, options, { context }) => {
193
+ context.request.body = _.toPlainObject(options.input);
194
+
195
+ await strapi.plugins['users-permissions'].controllers.auth.register(context);
196
+ let output = context.body.toJSON ? context.body.toJSON() : context.body;
197
+
198
+ checkBadRequest(output);
199
+ return {
200
+ user: output.user || output,
201
+ jwt: output.jwt,
202
+ };
203
+ },
204
+ },
205
+ login: {
206
+ resolverOf: 'plugins::users-permissions.auth.callback',
207
+ resolver: async (obj, options, { context }) => {
208
+ context.params = {
209
+ ...context.params,
210
+ provider: options.input.provider,
211
+ };
212
+ context.request.body = _.toPlainObject(options.input);
213
+
214
+ await strapi.plugins['users-permissions'].controllers.auth.callback(context);
215
+ let output = context.body.toJSON ? context.body.toJSON() : context.body;
216
+
217
+ checkBadRequest(output);
218
+ return {
219
+ user: output.user || output,
220
+ jwt: output.jwt,
221
+ };
222
+ },
223
+ },
224
+ forgotPassword: {
225
+ description: 'Request a reset password token',
226
+ resolverOf: 'plugins::users-permissions.auth.forgotPassword',
227
+ resolver: async (obj, options, { context }) => {
228
+ context.request.body = _.toPlainObject(options);
229
+
230
+ await strapi.plugins['users-permissions'].controllers.auth.forgotPassword(context);
231
+ let output = context.body.toJSON ? context.body.toJSON() : context.body;
232
+
233
+ checkBadRequest(output);
234
+
235
+ return {
236
+ ok: output.ok || output,
237
+ };
238
+ },
239
+ },
240
+ resetPassword: {
241
+ description: 'Reset user password. Confirm with a code (resetToken from forgotPassword)',
242
+ resolverOf: 'plugins::users-permissions.auth.resetPassword',
243
+ resolver: async (obj, options, { context }) => {
244
+ context.request.body = _.toPlainObject(options);
245
+
246
+ await strapi.plugins['users-permissions'].controllers.auth.resetPassword(context);
247
+ let output = context.body.toJSON ? context.body.toJSON() : context.body;
248
+
249
+ checkBadRequest(output);
250
+
251
+ return {
252
+ user: output.user || output,
253
+ jwt: output.jwt,
254
+ };
255
+ },
256
+ },
257
+ emailConfirmation: {
258
+ description: 'Confirm an email users email address',
259
+ resolverOf: 'plugins::users-permissions.auth.emailConfirmation',
260
+ resolver: async (obj, options, { context }) => {
261
+ context.query = _.toPlainObject(options);
262
+
263
+ await strapi.plugins['users-permissions'].controllers.auth.emailConfirmation(
264
+ context,
265
+ null,
266
+ true
267
+ );
268
+ let output = context.body.toJSON ? context.body.toJSON() : context.body;
269
+
270
+ checkBadRequest(output);
271
+
272
+ return {
273
+ user: output.user || output,
274
+ jwt: output.jwt,
275
+ };
276
+ },
277
+ },
278
+ },
279
+ },
280
+ };
@@ -0,0 +1,5 @@
1
+ {
2
+ "jwt": {
3
+ "expiresIn": "30d"
4
+ }
5
+ }