@webbio/strapi-plugin-page-builder 0.12.2-platform → 0.12.3-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.js +1 -1
  93. package/dist/server/graphql/page-by-path.js +20 -17
  94. package/dist/server/graphql/pages-by-uid.js +5 -5
  95. package/dist/server/services/private-content/graphql/index.js +27 -27
  96. package/dist/server/services/private-content/graphql/types/index.js +74 -74
  97. package/dist/tsconfig.server.tsbuildinfo +1 -1
  98. package/package.json +78 -78
  99. package/server/bootstrap/collection-type-lifecycles.ts +47 -47
  100. package/server/bootstrap/permissions.ts +161 -161
  101. package/server/bootstrap.ts +261 -261
  102. package/server/config/index.ts +4 -4
  103. package/server/content-types/index.ts +7 -7
  104. package/server/content-types/user-category/schema.json +23 -23
  105. package/server/controllers/collection-types.ts +32 -32
  106. package/server/controllers/index.ts +19 -19
  107. package/server/controllers/page-type.ts +18 -18
  108. package/server/controllers/page.ts +9 -9
  109. package/server/controllers/platform.ts +21 -21
  110. package/server/controllers/private-content.ts +17 -17
  111. package/server/controllers/sitemap.ts +32 -32
  112. package/server/controllers/template.ts +16 -16
  113. package/server/controllers/user-category.ts +3 -3
  114. package/server/destroy.ts +5 -5
  115. package/server/graphql/index.ts +9 -9
  116. package/server/graphql/page-by-path.ts +135 -132
  117. package/server/graphql/page-type.ts +67 -67
  118. package/server/graphql/pages-by-uid.ts +89 -89
  119. package/server/index.ts +23 -23
  120. package/server/middlewares/index.ts +1 -1
  121. package/server/policies/index.ts +5 -5
  122. package/server/policies/isAuthorizedPage.ts +11 -11
  123. package/server/register.ts +22 -22
  124. package/server/routes/index.ts +115 -115
  125. package/server/routes/user-category.ts +3 -3
  126. package/server/schema/page-end.json +96 -96
  127. package/server/schema/page-start.json +87 -87
  128. package/server/schema/page-type-end.json +53 -53
  129. package/server/schema/page-type-start.json +38 -38
  130. package/server/schema/platform-start.json +21 -21
  131. package/server/schema/template-end.json +40 -40
  132. package/server/schema/template-start.json +35 -35
  133. package/server/services/builder.ts +232 -232
  134. package/server/services/collection-types.ts +95 -95
  135. package/server/services/email.ts +127 -127
  136. package/server/services/index.ts +23 -23
  137. package/server/services/page-type.ts +30 -30
  138. package/server/services/page.ts +24 -24
  139. package/server/services/platform.ts +30 -30
  140. package/server/services/private-content/components/admin-email.json +22 -22
  141. package/server/services/private-content/components/email.json +22 -22
  142. package/server/services/private-content/components/platform-email.json +30 -30
  143. package/server/services/private-content/constants/index.ts +13 -13
  144. package/server/services/private-content/graphql/index.ts +88 -88
  145. package/server/services/private-content/graphql/resolvers/findOnePage.ts +40 -40
  146. package/server/services/private-content/graphql/resolvers/findPage.ts +45 -45
  147. package/server/services/private-content/graphql/resolvers/forgot-password.ts +34 -34
  148. package/server/services/private-content/graphql/resolvers/login.ts +56 -56
  149. package/server/services/private-content/graphql/resolvers/register.ts +78 -78
  150. package/server/services/private-content/graphql/resolvers/reset-password.ts +44 -44
  151. package/server/services/private-content/graphql/types/index.ts +96 -96
  152. package/server/services/private-content/index.ts +95 -95
  153. package/server/services/private-content/mail-template/txtMail.email.template.text.ts +6 -6
  154. package/server/services/private-content/page.ts +20 -20
  155. package/server/services/private-content/platform.ts +19 -19
  156. package/server/services/private-content/schemas/index.ts +28 -28
  157. package/server/services/private-content/user.ts +197 -197
  158. package/server/services/sitemap.ts +83 -83
  159. package/server/services/template.ts +13 -13
  160. package/server/services/user-category.ts +3 -3
  161. package/server/utils/filter-underscore-arguments.ts +12 -12
  162. package/server/utils/reload-strapi-on-load.ts +13 -13
  163. package/server/utils/strapi.ts +50 -50
  164. package/shared/utils/constants.ts +8 -8
  165. package/shared/utils/sleep.ts +1 -1
  166. package/strapi-admin.js +3 -3
  167. package/strapi-server.js +3 -3
  168. package/tsconfig.json +20 -20
  169. package/tsconfig.server.json +25 -25
  170. package/dist/server/graphql/page-by-slug.js +0 -89
  171. package/dist/server/utils/graphql.js +0 -100
  172. package/dist/server/utils/paginationValidation.js +0 -31
@@ -1,67 +1,67 @@
1
- import { Common } from '@strapi/strapi';
2
- import { ICollectionTypeGL } from '../services/collection-types';
3
-
4
- const pageType = ({ nexus }) => {
5
- // @ts-ignore service does exist
6
- const collectionTypes: ICollectionTypeGL[] = strapi.service('plugin::page-builder.collection-types').withPageMorph();
7
-
8
- // Extends collectiontype types to include extra fields.
9
- const collectionTypesNexus = collectionTypes.map((collectionType) =>
10
- nexus.extendType({
11
- type: collectionType.type,
12
- definition(t: any) {
13
- t.string('id', { resolve: (root) => root?.id || null });
14
- t.string('uid', { resolve: () => collectionType?.uid || null });
15
- t.field('page', {
16
- type: 'Page',
17
- resolve: async (root) => {
18
- try {
19
- const results = await strapi.entityService.findOne(
20
- collectionType.uid as Common.UID.ContentType,
21
- root?.id,
22
- {
23
- populate: '*'
24
- }
25
- );
26
-
27
- if (!results) {
28
- return null;
29
- }
30
-
31
- return results.page?.[0];
32
- } catch {
33
- return null;
34
- }
35
- }
36
- });
37
- }
38
- })
39
- );
40
-
41
- // Extends the page type to include its id.
42
- const pageTypeExtendNexus = nexus.extendType({
43
- type: 'Page',
44
- definition(t: any) {
45
- t.string('id', { resolve: (root) => root?.id || null });
46
- }
47
- });
48
-
49
- // Extends the inputTypes for collectiontypes so filtering on Page is possible.
50
- // This however gives a problem when querying, for now we cannot use this.
51
- // const collectionInputTypesNexus = collectionTypes.map((collectionType) =>
52
- // nexus.extendInputType({
53
- // type: collectionType.inputType,
54
- // definition(t) {
55
- // t.field('page', {
56
- // type: 'PageFiltersInput',
57
- // });
58
- // }
59
- // })
60
- // );
61
-
62
- return {
63
- types: [pageTypeExtendNexus, ...collectionTypesNexus]
64
- };
65
- };
66
-
67
- export default pageType;
1
+ import { Common } from '@strapi/strapi';
2
+ import { ICollectionTypeGL } from '../services/collection-types';
3
+
4
+ const pageType = ({ nexus }) => {
5
+ // @ts-ignore service does exist
6
+ const collectionTypes: ICollectionTypeGL[] = strapi.service('plugin::page-builder.collection-types').withPageMorph();
7
+
8
+ // Extends collectiontype types to include extra fields.
9
+ const collectionTypesNexus = collectionTypes.map((collectionType) =>
10
+ nexus.extendType({
11
+ type: collectionType.type,
12
+ definition(t: any) {
13
+ t.string('id', { resolve: (root) => root?.id || null });
14
+ t.string('uid', { resolve: () => collectionType?.uid || null });
15
+ t.field('page', {
16
+ type: 'Page',
17
+ resolve: async (root) => {
18
+ try {
19
+ const results = await strapi.entityService.findOne(
20
+ collectionType.uid as Common.UID.ContentType,
21
+ root?.id,
22
+ {
23
+ populate: '*'
24
+ }
25
+ );
26
+
27
+ if (!results) {
28
+ return null;
29
+ }
30
+
31
+ return results.page?.[0];
32
+ } catch {
33
+ return null;
34
+ }
35
+ }
36
+ });
37
+ }
38
+ })
39
+ );
40
+
41
+ // Extends the page type to include its id.
42
+ const pageTypeExtendNexus = nexus.extendType({
43
+ type: 'Page',
44
+ definition(t: any) {
45
+ t.string('id', { resolve: (root) => root?.id || null });
46
+ }
47
+ });
48
+
49
+ // Extends the inputTypes for collectiontypes so filtering on Page is possible.
50
+ // This however gives a problem when querying, for now we cannot use this.
51
+ // const collectionInputTypesNexus = collectionTypes.map((collectionType) =>
52
+ // nexus.extendInputType({
53
+ // type: collectionType.inputType,
54
+ // definition(t) {
55
+ // t.field('page', {
56
+ // type: 'PageFiltersInput',
57
+ // });
58
+ // }
59
+ // })
60
+ // );
61
+
62
+ return {
63
+ types: [pageTypeExtendNexus, ...collectionTypesNexus]
64
+ };
65
+ };
66
+
67
+ export default pageType;
@@ -1,89 +1,89 @@
1
- import { Strapi } from '@strapi/strapi';
2
-
3
- const getPageInfoFromUID = (strapi: Strapi) => {
4
- // @ts-ignore service does exist
5
- const collectionTypes: ICollectionTypeGL[] = strapi.service('plugin::page-builder.collection-types').withPageMorph();
6
-
7
- const typeDefs = () => {
8
- const entityInfo = collectionTypes.map((collectionType) => {
9
- return `
10
- type Query {
11
- get${collectionType.type}Pages(filters: ${collectionType.type}FiltersInput, pagination: PaginationArg, publicationState: PublicationState, sort: [String]): ${collectionType.type}EntityResponseCollection
12
- }
13
-
14
- `;
15
- });
16
-
17
- return `${entityInfo}`;
18
- };
19
- const resolvers = (strapi: Strapi) => {
20
- const { transformArgs } = strapi.plugin('graphql').service('builders').utils;
21
- const pageQuery = collectionTypes.map((collectionType) => {
22
- return {
23
- [`get${collectionType.type}Pages`]: {
24
- resolve: async (_parent: any, args: Record<string, any>, ctx: any) => {
25
- const filteredArgs: Record<string, any> = {
26
- filters: { ...args.filters, hasPage: { $eq: true }, page: { ...args.pageFilters } },
27
- publicationState: args.publicationState,
28
- locale: args.locale,
29
- pagination: args.pagination,
30
- sort: args.sort
31
- };
32
-
33
- const { toEntityResponseCollection } = strapi.plugin('graphql').service('format').returnTypes;
34
-
35
- const getPage = async () => {
36
- const transformedArgs = transformArgs(filteredArgs, {
37
- contentType: strapi.contentTypes[collectionType.uid],
38
- usePagination: true
39
- });
40
-
41
- const results = await (strapi as Strapi)?.entityService?.findMany(collectionType.uid, {
42
- populate: '*',
43
- ...transformedArgs
44
- });
45
-
46
- const entityResponse = toEntityResponseCollection(results || [], {
47
- args: transformedArgs,
48
- resourceUID: collectionType.uid
49
- });
50
-
51
- return entityResponse;
52
- };
53
-
54
- const results: Record<string, any> = await getPage();
55
-
56
- if (Object.values(results)?.filter(Boolean).length > 0) {
57
- return results;
58
- } else {
59
- throw new Error(ctx.koaContext.response.message);
60
- }
61
- }
62
- }
63
- };
64
- });
65
-
66
- return {
67
- Query: Object.assign({}, ...pageQuery)
68
- };
69
- };
70
-
71
- const resolversConfig = () => {
72
- const configQuery = collectionTypes.map((collectionType) => {
73
- return {
74
- [`Query.get${collectionType.type}Pages`]: {
75
- auth: false
76
- }
77
- };
78
- });
79
- return Object.assign({}, ...configQuery);
80
- };
81
-
82
- return {
83
- typeDefs: typeDefs(),
84
- resolvers: resolvers(strapi),
85
- resolversConfig: resolversConfig()
86
- };
87
- };
88
-
89
- export default getPageInfoFromUID;
1
+ import { Strapi } from '@strapi/strapi';
2
+
3
+ const getPageInfoFromUID = (strapi: Strapi) => {
4
+ // @ts-ignore service does exist
5
+ const collectionTypes: ICollectionTypeGL[] = strapi.service('plugin::page-builder.collection-types').withPageMorph();
6
+
7
+ const typeDefs = () => {
8
+ const entityInfo = collectionTypes.map((collectionType) => {
9
+ return `
10
+ type Query {
11
+ get${collectionType.type}Pages(filters: ${collectionType.type}FiltersInput, pagination: PaginationArg, publicationState: PublicationState, sort: [String]): ${collectionType.type}EntityResponseCollection
12
+ }
13
+
14
+ `;
15
+ });
16
+
17
+ return `${entityInfo}`;
18
+ };
19
+ const resolvers = (strapi: Strapi) => {
20
+ const { transformArgs } = strapi.plugin('graphql').service('builders').utils;
21
+ const pageQuery = collectionTypes.map((collectionType) => {
22
+ return {
23
+ [`get${collectionType.type}Pages`]: {
24
+ resolve: async (_parent: any, args: Record<string, any>, ctx: any) => {
25
+ const filteredArgs: Record<string, any> = {
26
+ filters: { ...args.filters, hasPage: { $eq: true }, page: { ...args.pageFilters } },
27
+ publicationState: args.publicationState,
28
+ locale: args.locale,
29
+ pagination: args.pagination,
30
+ sort: args.sort
31
+ };
32
+
33
+ const { toEntityResponseCollection } = strapi.plugin('graphql').service('format').returnTypes;
34
+
35
+ const getPage = async () => {
36
+ const transformedArgs = transformArgs(filteredArgs, {
37
+ contentType: strapi.contentTypes[collectionType.uid],
38
+ usePagination: true
39
+ });
40
+
41
+ const results = await (strapi as Strapi)?.entityService?.findMany(collectionType.uid, {
42
+ populate: '*',
43
+ ...transformedArgs
44
+ });
45
+
46
+ const entityResponse = toEntityResponseCollection(results || [], {
47
+ args: transformedArgs,
48
+ resourceUID: collectionType.uid
49
+ });
50
+
51
+ return entityResponse;
52
+ };
53
+
54
+ const results: Record<string, any> = await getPage();
55
+
56
+ if (Object.values(results)?.filter(Boolean).length > 0) {
57
+ return results;
58
+ } else {
59
+ throw new Error(ctx.koaContext.response.message);
60
+ }
61
+ }
62
+ }
63
+ };
64
+ });
65
+
66
+ return {
67
+ Query: Object.assign({}, ...pageQuery)
68
+ };
69
+ };
70
+
71
+ const resolversConfig = () => {
72
+ const configQuery = collectionTypes.map((collectionType) => {
73
+ return {
74
+ [`Query.get${collectionType.type}Pages`]: {
75
+ auth: false
76
+ }
77
+ };
78
+ });
79
+ return Object.assign({}, ...configQuery);
80
+ };
81
+
82
+ return {
83
+ typeDefs: typeDefs(),
84
+ resolvers: resolvers(strapi),
85
+ resolversConfig: resolversConfig()
86
+ };
87
+ };
88
+
89
+ export default getPageInfoFromUID;
package/server/index.ts CHANGED
@@ -1,23 +1,23 @@
1
- import register from './register';
2
- import bootstrap from './bootstrap';
3
- import destroy from './destroy';
4
- import config from './config';
5
- import contentTypes from './content-types';
6
- import controllers from './controllers';
7
- import routes from './routes';
8
- import middlewares from './middlewares';
9
- import policies from './policies';
10
- import services from './services';
11
-
12
- export default {
13
- register,
14
- bootstrap,
15
- destroy,
16
- config,
17
- controllers,
18
- routes,
19
- services,
20
- contentTypes,
21
- policies,
22
- middlewares
23
- };
1
+ import register from './register';
2
+ import bootstrap from './bootstrap';
3
+ import destroy from './destroy';
4
+ import config from './config';
5
+ import contentTypes from './content-types';
6
+ import controllers from './controllers';
7
+ import routes from './routes';
8
+ import middlewares from './middlewares';
9
+ import policies from './policies';
10
+ import services from './services';
11
+
12
+ export default {
13
+ register,
14
+ bootstrap,
15
+ destroy,
16
+ config,
17
+ controllers,
18
+ routes,
19
+ services,
20
+ contentTypes,
21
+ policies,
22
+ middlewares
23
+ };
@@ -1 +1 @@
1
- export default {};
1
+ export default {};
@@ -1,5 +1,5 @@
1
- import isAuthorizedForPage from './isAuthorizedPage';
2
-
3
- export default {
4
- isAuthorizedForPage
5
- };
1
+ import isAuthorizedForPage from './isAuthorizedPage';
2
+
3
+ export default {
4
+ isAuthorizedForPage
5
+ };
@@ -1,11 +1,11 @@
1
- const isAuthorizedForPage = (policyContext, _config, { strapi }) => {
2
- const pageToken = policyContext.http.request.headers['x-strapi-page-secret'];
3
- const pageEnvToken = process.env.STRAPI_PAGE_SECRET;
4
-
5
- if (pageToken && pageEnvToken && pageToken === pageEnvToken) {
6
- return true;
7
- }
8
- return false;
9
- };
10
-
11
- export default isAuthorizedForPage;
1
+ const isAuthorizedForPage = (policyContext, _config, { strapi }) => {
2
+ const pageToken = policyContext.http.request.headers['x-strapi-page-secret'];
3
+ const pageEnvToken = process.env.STRAPI_PAGE_SECRET;
4
+
5
+ if (pageToken && pageEnvToken && pageToken === pageEnvToken) {
6
+ return true;
7
+ }
8
+ return false;
9
+ };
10
+
11
+ export default isAuthorizedForPage;
@@ -1,22 +1,22 @@
1
- import { Strapi } from '@strapi/strapi';
2
-
3
- import getPageByPath from './graphql/page-by-path';
4
- import pageType from './graphql/page-type';
5
- import getPageInfoFromUID from './graphql/pages-by-uid';
6
-
7
- export default async ({ strapi }: { strapi: Strapi }) => {
8
- strapi.customFields.register({
9
- name: 'filtered-select',
10
- plugin: 'page-builder',
11
- type: 'string'
12
- });
13
-
14
- const extensionService = strapi.plugin('graphql').service('extension');
15
-
16
- extensionService.use(pageType);
17
- extensionService.use(getPageByPath(strapi));
18
- extensionService.use(getPageInfoFromUID(strapi));
19
-
20
- await strapi.service('plugin::page-builder.builder').buildContentTypes();
21
- await strapi.service('plugin::page-builder.private-content').enablePrivateContent();
22
- };
1
+ import { Strapi } from '@strapi/strapi';
2
+
3
+ import getPageByPath from './graphql/page-by-path';
4
+ import pageType from './graphql/page-type';
5
+ import getPageInfoFromUID from './graphql/pages-by-uid';
6
+
7
+ export default async ({ strapi }: { strapi: Strapi }) => {
8
+ strapi.customFields.register({
9
+ name: 'filtered-select',
10
+ plugin: 'page-builder',
11
+ type: 'string'
12
+ });
13
+
14
+ const extensionService = strapi.plugin('graphql').service('extension');
15
+
16
+ extensionService.use(pageType);
17
+ extensionService.use(getPageByPath(strapi));
18
+ extensionService.use(getPageInfoFromUID(strapi));
19
+
20
+ await strapi.service('plugin::page-builder.builder').buildContentTypes();
21
+ await strapi.service('plugin::page-builder.private-content').enablePrivateContent();
22
+ };
@@ -1,115 +1,115 @@
1
- import userCategory from './user-category';
2
-
3
- const routes = {
4
- 'private-content': {
5
- type: 'content-api',
6
- prefix: undefined,
7
- routes: [
8
- {
9
- method: 'GET',
10
- path: '/activate/:token',
11
- handler: 'private-content.activateUser',
12
- config: { policies: [], auth: false }
13
- },
14
- {
15
- method: 'POST',
16
- path: '/removeInactiveUsers',
17
- handler: 'private-content.removeInactiveUsers'
18
- }
19
- ]
20
- },
21
- 'page-type': {
22
- type: 'admin',
23
- prefix: undefined,
24
- routes: [
25
- {
26
- method: 'GET',
27
- path: '/page-types/:uid/:platformId',
28
- handler: 'page-type.findOneByUid'
29
- }
30
- ]
31
- },
32
- page: {
33
- type: 'admin',
34
- prefix: undefined,
35
- routes: [
36
- {
37
- method: 'GET',
38
- path: '/page/:id',
39
- handler: 'page.getPage'
40
- }
41
- ]
42
- },
43
- 'collection-types': {
44
- type: 'admin',
45
- prefix: undefined,
46
- routes: [
47
- {
48
- method: 'GET',
49
- path: '/collection-types/:uid',
50
- handler: 'collection-types.hasPageRelation'
51
- },
52
- {
53
- method: 'GET',
54
- path: '/collection-types-page-links/:uid/:ids?',
55
- handler: 'collection-types.getTranslationPageLinks'
56
- },
57
- {
58
- method: 'GET',
59
- path: '/collection-types/hasPlatform/:uid',
60
- handler: 'collection-types.hasPlatformRelation'
61
- }
62
- ]
63
- },
64
- template: {
65
- type: 'admin',
66
- prefix: undefined,
67
- routes: [
68
- {
69
- method: 'GET',
70
- path: '/template',
71
- handler: 'template.findAll'
72
- },
73
- {
74
- method: 'GET',
75
- path: '/template/:id',
76
- handler: 'template.findOneById'
77
- }
78
- ]
79
- },
80
- platform: {
81
- type: 'admin',
82
- prefix: undefined,
83
- routes: [
84
- {
85
- method: 'GET',
86
- path: '/platform',
87
- handler: 'platform.findAll'
88
- },
89
- {
90
- method: 'GET',
91
- path: '/platform/:id',
92
- handler: 'platform.findOneById'
93
- },
94
- {
95
- method: 'GET',
96
- path: '/platform/:platform/page-types',
97
- handler: 'platform.findPageTypesByPlatform'
98
- }
99
- ]
100
- },
101
- sitemap: {
102
- type: 'content-api',
103
- prefix: undefined,
104
- routes: [
105
- {
106
- method: 'GET',
107
- path: '/sitemap',
108
- handler: 'sitemap.generate'
109
- }
110
- ]
111
- },
112
- 'user-category': userCategory
113
- };
114
-
115
- export default routes;
1
+ import userCategory from './user-category';
2
+
3
+ const routes = {
4
+ 'private-content': {
5
+ type: 'content-api',
6
+ prefix: undefined,
7
+ routes: [
8
+ {
9
+ method: 'GET',
10
+ path: '/activate/:token',
11
+ handler: 'private-content.activateUser',
12
+ config: { policies: [], auth: false }
13
+ },
14
+ {
15
+ method: 'POST',
16
+ path: '/removeInactiveUsers',
17
+ handler: 'private-content.removeInactiveUsers'
18
+ }
19
+ ]
20
+ },
21
+ 'page-type': {
22
+ type: 'admin',
23
+ prefix: undefined,
24
+ routes: [
25
+ {
26
+ method: 'GET',
27
+ path: '/page-types/:uid/:platformId',
28
+ handler: 'page-type.findOneByUid'
29
+ }
30
+ ]
31
+ },
32
+ page: {
33
+ type: 'admin',
34
+ prefix: undefined,
35
+ routes: [
36
+ {
37
+ method: 'GET',
38
+ path: '/page/:id',
39
+ handler: 'page.getPage'
40
+ }
41
+ ]
42
+ },
43
+ 'collection-types': {
44
+ type: 'admin',
45
+ prefix: undefined,
46
+ routes: [
47
+ {
48
+ method: 'GET',
49
+ path: '/collection-types/:uid',
50
+ handler: 'collection-types.hasPageRelation'
51
+ },
52
+ {
53
+ method: 'GET',
54
+ path: '/collection-types-page-links/:uid/:ids?',
55
+ handler: 'collection-types.getTranslationPageLinks'
56
+ },
57
+ {
58
+ method: 'GET',
59
+ path: '/collection-types/hasPlatform/:uid',
60
+ handler: 'collection-types.hasPlatformRelation'
61
+ }
62
+ ]
63
+ },
64
+ template: {
65
+ type: 'admin',
66
+ prefix: undefined,
67
+ routes: [
68
+ {
69
+ method: 'GET',
70
+ path: '/template',
71
+ handler: 'template.findAll'
72
+ },
73
+ {
74
+ method: 'GET',
75
+ path: '/template/:id',
76
+ handler: 'template.findOneById'
77
+ }
78
+ ]
79
+ },
80
+ platform: {
81
+ type: 'admin',
82
+ prefix: undefined,
83
+ routes: [
84
+ {
85
+ method: 'GET',
86
+ path: '/platform',
87
+ handler: 'platform.findAll'
88
+ },
89
+ {
90
+ method: 'GET',
91
+ path: '/platform/:id',
92
+ handler: 'platform.findOneById'
93
+ },
94
+ {
95
+ method: 'GET',
96
+ path: '/platform/:platform/page-types',
97
+ handler: 'platform.findPageTypesByPlatform'
98
+ }
99
+ ]
100
+ },
101
+ sitemap: {
102
+ type: 'content-api',
103
+ prefix: undefined,
104
+ routes: [
105
+ {
106
+ method: 'GET',
107
+ path: '/sitemap',
108
+ handler: 'sitemap.generate'
109
+ }
110
+ ]
111
+ },
112
+ 'user-category': userCategory
113
+ };
114
+
115
+ export default routes;