@webbio/strapi-plugin-page-builder 0.12.2-platform → 0.12.4-platform

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 (172) hide show
  1. package/README.md +166 -166
  2. package/admin/src/api/collection-type.ts +111 -111
  3. package/admin/src/api/entity-relation.ts +42 -42
  4. package/admin/src/api/has-page-relation.ts +37 -37
  5. package/admin/src/api/has-platform-relation.ts +40 -40
  6. package/admin/src/api/page-type-relation.ts +41 -41
  7. package/admin/src/api/platform-page-types.ts +45 -45
  8. package/admin/src/api/platform-relation.ts +42 -42
  9. package/admin/src/api/platform.ts +35 -35
  10. package/admin/src/api/search-filtered-entity.ts +114 -114
  11. package/admin/src/api/template.ts +39 -39
  12. package/admin/src/components/Combobox/index.tsx +83 -83
  13. package/admin/src/components/Combobox/react-select-custom-styles.tsx +121 -121
  14. package/admin/src/components/Combobox/styles.ts +46 -46
  15. package/admin/src/components/ConfirmModal/index.tsx +90 -90
  16. package/admin/src/components/EditView/CollectionTypeSearch/index.tsx +127 -127
  17. package/admin/src/components/EditView/CollectionTypeSettings/CreatePageButton/index.tsx +149 -149
  18. package/admin/src/components/EditView/CollectionTypeSettings/CreatePageButton/styles.ts +19 -19
  19. package/admin/src/components/EditView/CollectionTypeSettings/index.tsx +82 -82
  20. package/admin/src/components/EditView/Details/index.tsx +48 -48
  21. package/admin/src/components/EditView/Details/styles.ts +51 -51
  22. package/admin/src/components/EditView/PageSettings/index.tsx +124 -124
  23. package/admin/src/components/EditView/Platform/platform-select.tsx +30 -30
  24. package/admin/src/components/EditView/Template/TemplateConfirmModal/index.tsx +36 -36
  25. package/admin/src/components/EditView/Template/TemplateSelect/index.tsx +70 -70
  26. package/admin/src/components/EditView/Template/TemplateSelect/use-template-modules.ts +41 -41
  27. package/admin/src/components/EditView/index.tsx +35 -35
  28. package/admin/src/components/EditView/page-type-select.tsx +32 -32
  29. package/admin/src/components/EditView/wrapper.tsx +41 -41
  30. package/admin/src/components/GlobalPlatformSelect/index.tsx +40 -40
  31. package/admin/src/components/GlobalPlatformSelect/styles.ts +27 -27
  32. package/admin/src/components/Initializer/index.tsx +24 -24
  33. package/admin/src/components/PageFilters/PageTypeFilter/index.tsx +39 -39
  34. package/admin/src/components/PageFilters/PlatformFilter/index.tsx +32 -32
  35. package/admin/src/components/PageFilters/filters.tsx +189 -189
  36. package/admin/src/components/PageFilters/index.tsx +35 -35
  37. package/admin/src/components/PageTypeEditView/TemplatePlatformSelect/index.tsx +76 -76
  38. package/admin/src/components/PageTypeEditView/index.tsx +53 -53
  39. package/admin/src/components/PlatformFilteredSelectField/InputIcon/index.tsx +23 -23
  40. package/admin/src/components/PlatformFilteredSelectField/Multi/index.tsx +210 -210
  41. package/admin/src/components/PlatformFilteredSelectField/Single/index.tsx +197 -197
  42. package/admin/src/components/PlatformFilteredSelectField/hooks/useRelationLoad.tsx +128 -128
  43. package/admin/src/components/PlatformFilteredSelectField/index.tsx +85 -85
  44. package/admin/src/components/PlatformFilteredSelectField/styles.tsx +77 -77
  45. package/admin/src/components/PlatformFilteredSelectField/utils/get-translations.ts +3 -3
  46. package/admin/src/components/PlatformFilteredSelectField/utils/relation-helper.ts +147 -147
  47. package/admin/src/components/PluginIcon/index.tsx +94 -94
  48. package/admin/src/components/StrapiCore/admin/admin/src/content-manager/components/Relations/RelationInput.tsx +689 -689
  49. package/admin/src/components/StrapiCore/admin/admin/src/content-manager/components/Relations/RelationInputDataManager.tsx +6 -6
  50. package/admin/src/components/StrapiCore/admin/admin/src/content-manager/components/Relations/useRelation.ts +170 -170
  51. package/admin/src/components/StrapiCore/admin/admin/src/content-manager/components/Relations/utils/getRelationLink.ts +5 -5
  52. package/admin/src/components/StrapiCore/admin/admin/src/content-manager/components/Relations/utils/normalizeRelations.ts +52 -52
  53. package/admin/src/components/StrapiCore/admin/admin/src/content-manager/constants/attributes.ts +3 -3
  54. package/admin/src/components/StrapiCore/admin/admin/src/content-manager/hooks/useDragAndDrop.ts +253 -253
  55. package/admin/src/components/StrapiCore/admin/admin/src/content-manager/hooks/useKeyboardDragAndDrop.ts +96 -96
  56. package/admin/src/components/StrapiCore/admin/admin/src/content-manager/hooks/usePrev.ts +11 -11
  57. package/admin/src/components/StrapiCore/admin/admin/src/content-manager/utils/dragAndDrop.ts +8 -8
  58. package/admin/src/components/StrapiCore/admin/admin/src/content-manager/utils/paths.ts +29 -29
  59. package/admin/src/components/StrapiCore/admin/admin/src/content-manager/utils/refs.ts +19 -19
  60. package/admin/src/components/StrapiCore/admin/admin/src/content-manager/utils/translations.ts +3 -3
  61. package/admin/src/components/StrapiCore/content-manager/shared/contracts/collection-types.ts +300 -300
  62. package/admin/src/components/StrapiCore/content-manager/shared/contracts/components.ts +72 -72
  63. package/admin/src/components/StrapiCore/content-manager/shared/contracts/content-types.ts +116 -116
  64. package/admin/src/components/StrapiCore/content-manager/shared/contracts/index.ts +8 -8
  65. package/admin/src/components/StrapiCore/content-manager/shared/contracts/init.ts +22 -22
  66. package/admin/src/components/StrapiCore/content-manager/shared/contracts/relations.ts +80 -80
  67. package/admin/src/components/StrapiCore/content-manager/shared/contracts/review-workflows.ts +88 -88
  68. package/admin/src/components/StrapiCore/content-manager/shared/contracts/single-types.ts +112 -112
  69. package/admin/src/components/StrapiCore/content-manager/shared/contracts/uid.ts +48 -48
  70. package/admin/src/components/StrapiCore/content-manager/shared/index.ts +1 -1
  71. package/admin/src/constants.ts +3 -3
  72. package/admin/src/index.tsx +101 -101
  73. package/admin/src/middlewares/index.tsx +37 -37
  74. package/admin/src/pages/app/index.tsx +14 -14
  75. package/admin/src/pluginId.ts +5 -5
  76. package/admin/src/translations/en.json +9 -9
  77. package/admin/src/translations/nl.json +9 -9
  78. package/admin/src/utils/findDomElement.ts +6 -6
  79. package/admin/src/utils/findElementParent.ts +20 -20
  80. package/admin/src/utils/getObjectFromFormName.ts +42 -42
  81. package/admin/src/utils/getRequestUrl.ts +11 -11
  82. package/admin/src/utils/getTrad.ts +5 -5
  83. package/admin/src/utils/hooks/useDebounce.ts +17 -17
  84. package/admin/src/utils/hooks/useDefaultPlatformFromLocalStorage.ts +61 -61
  85. package/admin/src/utils/hooks/useGetLocaleFromUrl.ts +9 -9
  86. package/admin/src/utils/hooks/useHideOverviewFilterTags.ts +34 -34
  87. package/admin/src/utils/hooks/usePlatformFormData.ts +64 -64
  88. package/admin/src/utils/hooks/usePrevious.ts +12 -12
  89. package/admin/src/utils/sanitizeModules.ts +93 -93
  90. package/custom.d.ts +6 -6
  91. package/dist/package.json +1 -1
  92. package/dist/server/bootstrap/collection-type-lifecycles.js +1 -1
  93. package/dist/server/bootstrap.js +1 -1
  94. package/dist/server/graphql/page-by-path.js +20 -17
  95. package/dist/server/graphql/page-by-slug.js +9 -9
  96. package/dist/server/graphql/pages-by-uid.js +5 -5
  97. package/dist/server/services/private-content/graphql/index.js +27 -27
  98. package/dist/server/services/private-content/graphql/types/index.js +74 -74
  99. package/dist/server/utils/graphql.js +18 -18
  100. package/dist/tsconfig.server.tsbuildinfo +1 -1
  101. package/package.json +78 -78
  102. package/server/bootstrap/collection-type-lifecycles.ts +47 -47
  103. package/server/bootstrap/permissions.ts +161 -161
  104. package/server/bootstrap.ts +261 -261
  105. package/server/config/index.ts +4 -4
  106. package/server/content-types/index.ts +7 -7
  107. package/server/content-types/user-category/schema.json +23 -23
  108. package/server/controllers/collection-types.ts +32 -32
  109. package/server/controllers/index.ts +19 -19
  110. package/server/controllers/page-type.ts +18 -18
  111. package/server/controllers/page.ts +9 -9
  112. package/server/controllers/platform.ts +21 -21
  113. package/server/controllers/private-content.ts +17 -17
  114. package/server/controllers/sitemap.ts +32 -32
  115. package/server/controllers/template.ts +16 -16
  116. package/server/controllers/user-category.ts +3 -3
  117. package/server/destroy.ts +5 -5
  118. package/server/graphql/index.ts +9 -9
  119. package/server/graphql/page-by-path.ts +135 -132
  120. package/server/graphql/page-type.ts +67 -67
  121. package/server/graphql/pages-by-uid.ts +89 -89
  122. package/server/index.ts +23 -23
  123. package/server/middlewares/index.ts +1 -1
  124. package/server/policies/index.ts +5 -5
  125. package/server/policies/isAuthorizedPage.ts +11 -11
  126. package/server/register.ts +22 -22
  127. package/server/routes/index.ts +115 -115
  128. package/server/routes/user-category.ts +3 -3
  129. package/server/schema/page-end.json +96 -96
  130. package/server/schema/page-start.json +87 -87
  131. package/server/schema/page-type-end.json +53 -53
  132. package/server/schema/page-type-start.json +38 -38
  133. package/server/schema/platform-start.json +21 -21
  134. package/server/schema/template-end.json +40 -40
  135. package/server/schema/template-start.json +35 -35
  136. package/server/services/builder.ts +232 -232
  137. package/server/services/collection-types.ts +95 -95
  138. package/server/services/email.ts +127 -127
  139. package/server/services/index.ts +23 -23
  140. package/server/services/page-type.ts +30 -30
  141. package/server/services/page.ts +24 -24
  142. package/server/services/platform.ts +30 -30
  143. package/server/services/private-content/components/admin-email.json +22 -22
  144. package/server/services/private-content/components/email.json +22 -22
  145. package/server/services/private-content/components/platform-email.json +30 -30
  146. package/server/services/private-content/constants/index.ts +13 -13
  147. package/server/services/private-content/graphql/index.ts +88 -88
  148. package/server/services/private-content/graphql/resolvers/findOnePage.ts +40 -40
  149. package/server/services/private-content/graphql/resolvers/findPage.ts +45 -45
  150. package/server/services/private-content/graphql/resolvers/forgot-password.ts +34 -34
  151. package/server/services/private-content/graphql/resolvers/login.ts +56 -56
  152. package/server/services/private-content/graphql/resolvers/register.ts +78 -78
  153. package/server/services/private-content/graphql/resolvers/reset-password.ts +44 -44
  154. package/server/services/private-content/graphql/types/index.ts +96 -96
  155. package/server/services/private-content/index.ts +95 -95
  156. package/server/services/private-content/mail-template/txtMail.email.template.text.ts +6 -6
  157. package/server/services/private-content/page.ts +20 -20
  158. package/server/services/private-content/platform.ts +19 -19
  159. package/server/services/private-content/schemas/index.ts +28 -28
  160. package/server/services/private-content/user.ts +197 -197
  161. package/server/services/sitemap.ts +83 -83
  162. package/server/services/template.ts +13 -13
  163. package/server/services/user-category.ts +3 -3
  164. package/server/utils/filter-underscore-arguments.ts +12 -12
  165. package/server/utils/reload-strapi-on-load.ts +13 -13
  166. package/server/utils/strapi.ts +50 -50
  167. package/shared/utils/constants.ts +8 -8
  168. package/shared/utils/sleep.ts +1 -1
  169. package/strapi-admin.js +3 -3
  170. package/strapi-server.js +3 -3
  171. package/tsconfig.json +20 -20
  172. package/tsconfig.server.json +25 -25
@@ -1,22 +1,22 @@
1
- {
2
- "collectionName": "components_internal_admin_emails",
3
- "info": {
4
- "displayName": "AdminEmail",
5
- "description": ""
6
- },
7
- "options": {},
8
- "attributes": {
9
- "toEmail": {
10
- "type": "string"
11
- },
12
- "fromEmail": {
13
- "type": "string"
14
- },
15
- "subject": {
16
- "type": "string"
17
- },
18
- "message": {
19
- "type": "text"
20
- }
21
- }
22
- }
1
+ {
2
+ "collectionName": "components_internal_admin_emails",
3
+ "info": {
4
+ "displayName": "AdminEmail",
5
+ "description": ""
6
+ },
7
+ "options": {},
8
+ "attributes": {
9
+ "toEmail": {
10
+ "type": "string"
11
+ },
12
+ "fromEmail": {
13
+ "type": "string"
14
+ },
15
+ "subject": {
16
+ "type": "string"
17
+ },
18
+ "message": {
19
+ "type": "text"
20
+ }
21
+ }
22
+ }
@@ -1,22 +1,22 @@
1
- {
2
- "collectionName": "components_internal_emails",
3
- "info": {
4
- "displayName": "email",
5
- "description": ""
6
- },
7
- "options": {},
8
- "attributes": {
9
- "nameSender": {
10
- "type": "string"
11
- },
12
- "fromEmail": {
13
- "type": "string"
14
- },
15
- "subject": {
16
- "type": "string"
17
- },
18
- "message": {
19
- "type": "text"
20
- }
21
- }
22
- }
1
+ {
2
+ "collectionName": "components_internal_emails",
3
+ "info": {
4
+ "displayName": "email",
5
+ "description": ""
6
+ },
7
+ "options": {},
8
+ "attributes": {
9
+ "nameSender": {
10
+ "type": "string"
11
+ },
12
+ "fromEmail": {
13
+ "type": "string"
14
+ },
15
+ "subject": {
16
+ "type": "string"
17
+ },
18
+ "message": {
19
+ "type": "text"
20
+ }
21
+ }
22
+ }
@@ -1,30 +1,30 @@
1
- {
2
- "collectionName": "components_internal_platform_emails",
3
- "info": {
4
- "displayName": "PlatformEmail"
5
- },
6
- "options": {},
7
- "attributes": {
8
- "resetPasswordMail": {
9
- "type": "component",
10
- "repeatable": false,
11
- "component": "internal.email"
12
- },
13
- "accountCreatedMail": {
14
- "type": "component",
15
- "repeatable": false,
16
- "component": "internal.email"
17
- },
18
- "accountAcceptedMail": {
19
- "type": "component",
20
- "repeatable": false,
21
- "component": "internal.email"
22
- },
23
- "adminEmail": {
24
- "displayName": "AdminEmail",
25
- "type": "component",
26
- "repeatable": false,
27
- "component": "internal.admin-email"
28
- }
29
- }
30
- }
1
+ {
2
+ "collectionName": "components_internal_platform_emails",
3
+ "info": {
4
+ "displayName": "PlatformEmail"
5
+ },
6
+ "options": {},
7
+ "attributes": {
8
+ "resetPasswordMail": {
9
+ "type": "component",
10
+ "repeatable": false,
11
+ "component": "internal.email"
12
+ },
13
+ "accountCreatedMail": {
14
+ "type": "component",
15
+ "repeatable": false,
16
+ "component": "internal.email"
17
+ },
18
+ "accountAcceptedMail": {
19
+ "type": "component",
20
+ "repeatable": false,
21
+ "component": "internal.email"
22
+ },
23
+ "adminEmail": {
24
+ "displayName": "AdminEmail",
25
+ "type": "component",
26
+ "repeatable": false,
27
+ "component": "internal.admin-email"
28
+ }
29
+ }
30
+ }
@@ -1,13 +1,13 @@
1
- import { contentTypes as contentTypesUtils } from '@strapi/utils';
2
- export const { UPDATED_BY_ATTRIBUTE, CREATED_BY_ATTRIBUTE } = contentTypesUtils.constants;
3
-
4
- export const USER_MODEL = 'plugin::users-permissions.user';
5
- export const USER_CONTENT_MANAGER = 'plugin::users-permissions.contentmanageruser';
6
- export const USER_ROLE = 'plugin::users-permissions.role';
7
- export const CONTENT_ENTITY_MANAGER = 'plugin::content-manager.entity-manager';
8
- export const ACTIONS = {
9
- read: 'plugin::content-manager.explorer.read',
10
- create: 'plugin::content-manager.explorer.create',
11
- edit: 'plugin::content-manager.explorer.update',
12
- delete: 'plugin::content-manager.explorer.delete'
13
- };
1
+ import { contentTypes as contentTypesUtils } from '@strapi/utils';
2
+ export const { UPDATED_BY_ATTRIBUTE, CREATED_BY_ATTRIBUTE } = contentTypesUtils.constants;
3
+
4
+ export const USER_MODEL = 'plugin::users-permissions.user';
5
+ export const USER_CONTENT_MANAGER = 'plugin::users-permissions.contentmanageruser';
6
+ export const USER_ROLE = 'plugin::users-permissions.role';
7
+ export const CONTENT_ENTITY_MANAGER = 'plugin::content-manager.entity-manager';
8
+ export const ACTIONS = {
9
+ read: 'plugin::content-manager.explorer.read',
10
+ create: 'plugin::content-manager.explorer.create',
11
+ edit: 'plugin::content-manager.explorer.update',
12
+ delete: 'plugin::content-manager.explorer.delete'
13
+ };
@@ -1,88 +1,88 @@
1
- import {
2
- ForgotPasswordInput,
3
- ForgotPasswordResponse,
4
- LoginInput,
5
- LoginResponse,
6
- Mutations,
7
- Queries,
8
- RegisterInput,
9
- RegisterResponse,
10
- ResetPasswordInput,
11
- ResetPasswordResponse,
12
- User
13
- } from './types';
14
- import { platformRegister } from './resolvers/register';
15
- import { platformLogin } from './resolvers/login';
16
- import { platformForgotPassword } from './resolvers/forgot-password';
17
- import { platformResetPassword } from './resolvers/reset-password';
18
- import { page } from './resolvers/findOnePage';
19
- import { pages } from './resolvers/findPage';
20
-
21
- export const extendGraphQL = () => {
22
- const extensionService = strapi.plugin('graphql').service('extension');
23
-
24
- const extension = () => ({
25
- typeDefs: `
26
- ${RegisterInput}
27
-
28
- ${LoginInput}
29
-
30
- ${RegisterResponse}
31
-
32
- ${LoginResponse}
33
-
34
- ${User}
35
-
36
- ${Mutations}
37
-
38
- ${ForgotPasswordInput}
39
-
40
- ${ForgotPasswordResponse}
41
-
42
- ${ResetPasswordInput}
43
-
44
- ${ResetPasswordResponse}
45
-
46
- ${ResetPasswordInput}
47
-
48
- ${ResetPasswordResponse}
49
-
50
- ${Queries}
51
-
52
- `,
53
- resolvers: {
54
- Query: {
55
- page,
56
- pages
57
- },
58
- Mutation: {
59
- platformLogin,
60
- platformRegister,
61
- platformForgotPassword,
62
- platformResetPassword
63
- }
64
- },
65
- resolversConfig: {
66
- 'Mutation.platformLogin': {
67
- auth: false
68
- },
69
- 'Mutation.platformRegister': {
70
- auth: false
71
- },
72
- 'Mutation.platformForgotPassword': {
73
- auth: false
74
- },
75
- 'Mutation.platformResetPassword': {
76
- auth: false
77
- },
78
- 'Query.page': {
79
- auth: false
80
- },
81
- 'Query.pages': {
82
- auth: false
83
- }
84
- }
85
- });
86
-
87
- extensionService.use(extension);
88
- };
1
+ import {
2
+ ForgotPasswordInput,
3
+ ForgotPasswordResponse,
4
+ LoginInput,
5
+ LoginResponse,
6
+ Mutations,
7
+ Queries,
8
+ RegisterInput,
9
+ RegisterResponse,
10
+ ResetPasswordInput,
11
+ ResetPasswordResponse,
12
+ User
13
+ } from './types';
14
+ import { platformRegister } from './resolvers/register';
15
+ import { platformLogin } from './resolvers/login';
16
+ import { platformForgotPassword } from './resolvers/forgot-password';
17
+ import { platformResetPassword } from './resolvers/reset-password';
18
+ import { page } from './resolvers/findOnePage';
19
+ import { pages } from './resolvers/findPage';
20
+
21
+ export const extendGraphQL = () => {
22
+ const extensionService = strapi.plugin('graphql').service('extension');
23
+
24
+ const extension = () => ({
25
+ typeDefs: `
26
+ ${RegisterInput}
27
+
28
+ ${LoginInput}
29
+
30
+ ${RegisterResponse}
31
+
32
+ ${LoginResponse}
33
+
34
+ ${User}
35
+
36
+ ${Mutations}
37
+
38
+ ${ForgotPasswordInput}
39
+
40
+ ${ForgotPasswordResponse}
41
+
42
+ ${ResetPasswordInput}
43
+
44
+ ${ResetPasswordResponse}
45
+
46
+ ${ResetPasswordInput}
47
+
48
+ ${ResetPasswordResponse}
49
+
50
+ ${Queries}
51
+
52
+ `,
53
+ resolvers: {
54
+ Query: {
55
+ page,
56
+ pages
57
+ },
58
+ Mutation: {
59
+ platformLogin,
60
+ platformRegister,
61
+ platformForgotPassword,
62
+ platformResetPassword
63
+ }
64
+ },
65
+ resolversConfig: {
66
+ 'Mutation.platformLogin': {
67
+ auth: false
68
+ },
69
+ 'Mutation.platformRegister': {
70
+ auth: false
71
+ },
72
+ 'Mutation.platformForgotPassword': {
73
+ auth: false
74
+ },
75
+ 'Mutation.platformResetPassword': {
76
+ auth: false
77
+ },
78
+ 'Query.page': {
79
+ auth: false
80
+ },
81
+ 'Query.pages': {
82
+ auth: false
83
+ }
84
+ }
85
+ });
86
+
87
+ extensionService.use(extension);
88
+ };
@@ -1,40 +1,40 @@
1
- import { omit } from 'lodash/fp';
2
- import { sanitize } from '@strapi/utils';
3
- import { PAGE_UID } from '../../../../../shared/utils/constants';
4
- import { ForbiddenError as ApolloForbiddenError } from 'apollo-server-koa';
5
-
6
- export const page = {
7
- async resolve(parent, args, ctx) {
8
- const uid = PAGE_UID;
9
- const { toEntityResponse } = strapi.plugin('graphql').service('format').returnTypes;
10
- const { transformArgs } = strapi.plugin('graphql').service('builders').utils;
11
- const populatedArgs = { ...args, populate: { platform: true } };
12
- const transformedArgs = transformArgs(populatedArgs, strapi.contentType(PAGE_UID));
13
- const sanitizedQuery = await sanitize.contentAPI.query(populatedArgs, strapi.contentType(PAGE_UID));
14
- const value = await strapi.entityService!.findOne(uid, args.id, omit('id', sanitizedQuery));
15
- // @ts-ignore Strapi types are the best
16
- if (!value?.platform?.isPrivate && !value?.isPrivate) {
17
- return toEntityResponse(value, { args: transformedArgs, resourceUID: uid });
18
- }
19
-
20
- if (
21
- // @ts-ignore Strapi types are the best
22
- (value?.platform?.isPrivate === true && ctx.koaContext.req.headers.authorization) ||
23
- (value?.isPrivate === true && ctx.koaContext.req.headers.authorization)
24
- ) {
25
- const auth = ctx.koaContext.req.headers.authorization;
26
- const token = auth.split(' ');
27
-
28
- const jwtService = strapi.plugin('users-permissions').service('jwt');
29
- const decodedToken = await jwtService.verify(token[1]);
30
- if (decodedToken) {
31
- const user = ctx.state.user;
32
- // @ts-ignore Strapi types are the best
33
- if (user?.platform?.id === value?.platform?.id) {
34
- return toEntityResponse(value, { args: transformedArgs, resourceUID: uid });
35
- }
36
- }
37
- }
38
- return new ApolloForbiddenError('Forbidden access');
39
- }
40
- };
1
+ import { omit } from 'lodash/fp';
2
+ import { sanitize } from '@strapi/utils';
3
+ import { PAGE_UID } from '../../../../../shared/utils/constants';
4
+ import { ForbiddenError as ApolloForbiddenError } from 'apollo-server-koa';
5
+
6
+ export const page = {
7
+ async resolve(parent, args, ctx) {
8
+ const uid = PAGE_UID;
9
+ const { toEntityResponse } = strapi.plugin('graphql').service('format').returnTypes;
10
+ const { transformArgs } = strapi.plugin('graphql').service('builders').utils;
11
+ const populatedArgs = { ...args, populate: { platform: true } };
12
+ const transformedArgs = transformArgs(populatedArgs, strapi.contentType(PAGE_UID));
13
+ const sanitizedQuery = await sanitize.contentAPI.query(populatedArgs, strapi.contentType(PAGE_UID));
14
+ const value = await strapi.entityService!.findOne(uid, args.id, omit('id', sanitizedQuery));
15
+ // @ts-ignore Strapi types are the best
16
+ if (!value?.platform?.isPrivate && !value?.isPrivate) {
17
+ return toEntityResponse(value, { args: transformedArgs, resourceUID: uid });
18
+ }
19
+
20
+ if (
21
+ // @ts-ignore Strapi types are the best
22
+ (value?.platform?.isPrivate === true && ctx.koaContext.req.headers.authorization) ||
23
+ (value?.isPrivate === true && ctx.koaContext.req.headers.authorization)
24
+ ) {
25
+ const auth = ctx.koaContext.req.headers.authorization;
26
+ const token = auth.split(' ');
27
+
28
+ const jwtService = strapi.plugin('users-permissions').service('jwt');
29
+ const decodedToken = await jwtService.verify(token[1]);
30
+ if (decodedToken) {
31
+ const user = ctx.state.user;
32
+ // @ts-ignore Strapi types are the best
33
+ if (user?.platform?.id === value?.platform?.id) {
34
+ return toEntityResponse(value, { args: transformedArgs, resourceUID: uid });
35
+ }
36
+ }
37
+ }
38
+ return new ApolloForbiddenError('Forbidden access');
39
+ }
40
+ };
@@ -1,45 +1,45 @@
1
- import { sanitize } from '@strapi/utils';
2
- import { PAGE_UID } from '../../../../../shared/utils/constants';
3
-
4
- export const pages = {
5
- async resolve(parent, args, ctx) {
6
- const uid = PAGE_UID;
7
- const { toEntityResponseCollection } = strapi.plugin('graphql').service('format').returnTypes;
8
- const { transformArgs } = strapi.plugin('graphql').service('builders').utils;
9
- const populatedArgs = { ...args, populate: { platform: true } };
10
- const transformedArgs = transformArgs(populatedArgs, strapi.contentType(PAGE_UID));
11
- const sanitizedQuery = await sanitize.contentAPI.query(populatedArgs, strapi.contentType(PAGE_UID));
12
- const value = await strapi.entityService!.findMany(uid, sanitizedQuery);
13
-
14
- const user = ctx.state.user;
15
-
16
- if (user && ctx.koaContext.req.headers.authorization) {
17
- const auth = ctx.koaContext.req.headers.authorization;
18
- const token = auth.split(' ');
19
- const jwtService = strapi.plugin('users-permissions').service('jwt');
20
- const decodedToken = await jwtService.verify(token[1]);
21
- if (decodedToken) {
22
- // @ts-ignore
23
- const filteredItems = value.filter((item) => {
24
- // @ts-ignore
25
- if (item.platform?.isPrivate === true && user.platform.id === item.platform.id) {
26
- return item;
27
- }
28
- if (item?.isPrivate === true && user.platform.id === item.platform.id) {
29
- return item;
30
- }
31
- // @ts-ignore
32
- if (item.platform?.isPrivate !== true && item?.isPrivate !== true) {
33
- return item;
34
- }
35
- });
36
- return toEntityResponseCollection(filteredItems, { args: transformedArgs, resourceUID: uid });
37
- }
38
- }
39
-
40
- // @ts-ignore
41
- const filteredItems = value.filter((item) => item.platform?.isPrivate !== true && item?.isPrivate !== true);
42
-
43
- return toEntityResponseCollection(filteredItems, { args: transformedArgs, resourceUID: uid });
44
- }
45
- };
1
+ import { sanitize } from '@strapi/utils';
2
+ import { PAGE_UID } from '../../../../../shared/utils/constants';
3
+
4
+ export const pages = {
5
+ async resolve(parent, args, ctx) {
6
+ const uid = PAGE_UID;
7
+ const { toEntityResponseCollection } = strapi.plugin('graphql').service('format').returnTypes;
8
+ const { transformArgs } = strapi.plugin('graphql').service('builders').utils;
9
+ const populatedArgs = { ...args, populate: { platform: true } };
10
+ const transformedArgs = transformArgs(populatedArgs, strapi.contentType(PAGE_UID));
11
+ const sanitizedQuery = await sanitize.contentAPI.query(populatedArgs, strapi.contentType(PAGE_UID));
12
+ const value = await strapi.entityService!.findMany(uid, sanitizedQuery);
13
+
14
+ const user = ctx.state.user;
15
+
16
+ if (user && ctx.koaContext.req.headers.authorization) {
17
+ const auth = ctx.koaContext.req.headers.authorization;
18
+ const token = auth.split(' ');
19
+ const jwtService = strapi.plugin('users-permissions').service('jwt');
20
+ const decodedToken = await jwtService.verify(token[1]);
21
+ if (decodedToken) {
22
+ // @ts-ignore
23
+ const filteredItems = value.filter((item) => {
24
+ // @ts-ignore
25
+ if (item.platform?.isPrivate === true && user.platform.id === item.platform.id) {
26
+ return item;
27
+ }
28
+ if (item?.isPrivate === true && user.platform.id === item.platform.id) {
29
+ return item;
30
+ }
31
+ // @ts-ignore
32
+ if (item.platform?.isPrivate !== true && item?.isPrivate !== true) {
33
+ return item;
34
+ }
35
+ });
36
+ return toEntityResponseCollection(filteredItems, { args: transformedArgs, resourceUID: uid });
37
+ }
38
+ }
39
+
40
+ // @ts-ignore
41
+ const filteredItems = value.filter((item) => item.platform?.isPrivate !== true && item?.isPrivate !== true);
42
+
43
+ return toEntityResponseCollection(filteredItems, { args: transformedArgs, resourceUID: uid });
44
+ }
45
+ };
@@ -1,34 +1,34 @@
1
- import { errors } from '@strapi/utils';
2
- import { USER_MODEL } from '../../constants';
3
- import { validateForgotPasswordSchema } from '../../schemas';
4
- const { UnauthorizedError } = errors;
5
-
6
- export const platformForgotPassword = {
7
- async resolve(parent, args, context) {
8
- await validateForgotPasswordSchema(args.input);
9
-
10
- const { email, domain } = args.input;
11
-
12
- const user = await strapi.query(USER_MODEL).findOne({
13
- populate: { platform: { populate: { platformEmails: { populate: true } } } },
14
- where: {
15
- email: email.toLowerCase(),
16
- platform: {
17
- domain: domain.toLowerCase()
18
- }
19
- }
20
- });
21
-
22
- if (!user) {
23
- {
24
- message: 'Email has been sent';
25
- }
26
- }
27
-
28
- await strapi.service('plugin::page-builder.email').sendForgotPasswordMail(user);
29
-
30
- return {
31
- message: 'Email has been sent'
32
- };
33
- }
34
- };
1
+ import { errors } from '@strapi/utils';
2
+ import { USER_MODEL } from '../../constants';
3
+ import { validateForgotPasswordSchema } from '../../schemas';
4
+ const { UnauthorizedError } = errors;
5
+
6
+ export const platformForgotPassword = {
7
+ async resolve(parent, args, context) {
8
+ await validateForgotPasswordSchema(args.input);
9
+
10
+ const { email, domain } = args.input;
11
+
12
+ const user = await strapi.query(USER_MODEL).findOne({
13
+ populate: { platform: { populate: { platformEmails: { populate: true } } } },
14
+ where: {
15
+ email: email.toLowerCase(),
16
+ platform: {
17
+ domain: domain.toLowerCase()
18
+ }
19
+ }
20
+ });
21
+
22
+ if (!user) {
23
+ {
24
+ message: 'Email has been sent';
25
+ }
26
+ }
27
+
28
+ await strapi.service('plugin::page-builder.email').sendForgotPasswordMail(user);
29
+
30
+ return {
31
+ message: 'Email has been sent'
32
+ };
33
+ }
34
+ };