@webiny/api-aco 0.0.0-unstable.99666aeb00 → 0.0.0-unstable.a9593f74dd
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/apps/AcoApp.d.ts +5 -0
- package/apps/AcoApp.js +56 -21
- package/apps/AcoApp.js.map +1 -1
- package/apps/AcoApps.js +7 -8
- package/apps/AcoApps.js.map +1 -1
- package/apps/app.gql.js +6 -4
- package/apps/app.gql.js.map +1 -1
- package/apps/index.js +3 -1
- package/apps/index.js.map +1 -1
- package/createAcoContext.d.ts +5 -1
- package/createAcoContext.js +119 -25
- package/createAcoContext.js.map +1 -1
- package/createAcoGraphQL.js +6 -2
- package/createAcoGraphQL.js.map +1 -1
- package/createAcoHooks.js +9 -3
- package/createAcoHooks.js.map +1 -1
- package/createAcoModels.js +6 -19
- package/createAcoModels.js.map +1 -1
- package/createAcoStorageOperations.d.ts +0 -1
- package/createAcoStorageOperations.js +10 -7
- package/createAcoStorageOperations.js.map +1 -1
- package/fields/index.js +3 -1
- package/fields/index.js.map +1 -1
- package/fields/location.js +3 -1
- package/fields/location.js.map +1 -1
- package/filter/filter.crud.d.ts +3 -0
- package/filter/filter.crud.js +94 -0
- package/filter/filter.crud.js.map +1 -0
- package/filter/filter.gql.d.ts +3 -0
- package/filter/filter.gql.js +153 -0
- package/filter/filter.gql.js.map +1 -0
- package/filter/filter.model.d.ts +2 -0
- package/filter/filter.model.js +125 -0
- package/filter/filter.model.js.map +1 -0
- package/filter/filter.so.d.ts +3 -0
- package/filter/filter.so.js +98 -0
- package/filter/filter.so.js.map +1 -0
- package/filter/filter.types.d.ts +95 -0
- package/filter/filter.types.js +14 -0
- package/filter/filter.types.js.map +1 -0
- package/folder/folder.crud.d.ts +8 -1
- package/folder/folder.crud.js +194 -15
- package/folder/folder.crud.js.map +1 -1
- package/folder/folder.gql.js +85 -8
- package/folder/folder.gql.js.map +1 -1
- package/folder/folder.model.d.ts +1 -3
- package/folder/folder.model.js +54 -7
- package/folder/folder.model.js.map +1 -1
- package/folder/folder.so.js +38 -18
- package/folder/folder.so.js.map +1 -1
- package/folder/folder.types.d.ts +28 -2
- package/folder/folder.types.js +3 -1
- package/folder/folder.types.js.map +1 -1
- package/folder/onFolderBeforeDeleteAco.hook.d.ts +2 -0
- package/folder/onFolderBeforeDeleteAco.hook.js +67 -0
- package/folder/onFolderBeforeDeleteAco.hook.js.map +1 -0
- package/folder/onFolderBeforeDeleteFm.hook.d.ts +2 -0
- package/folder/onFolderBeforeDeleteFm.hook.js +49 -0
- package/folder/onFolderBeforeDeleteFm.hook.js.map +1 -0
- package/folder/onFolderBeforeDeleteHcms.hook.d.ts +2 -0
- package/folder/onFolderBeforeDeleteHcms.hook.js +56 -0
- package/folder/onFolderBeforeDeleteHcms.hook.js.map +1 -0
- package/index.d.ts +5 -1
- package/index.js +14 -4
- package/index.js.map +1 -1
- package/package.json +31 -27
- package/plugins/AcoAppModifierPlugin.js +4 -5
- package/plugins/AcoAppModifierPlugin.js.map +1 -1
- package/plugins/AcoAppRegisterPlugin.js +4 -5
- package/plugins/AcoAppRegisterPlugin.js.map +1 -1
- package/plugins/index.js +3 -1
- package/plugins/index.js.map +1 -1
- package/record/graphql/createAppResolvers.js +26 -19
- package/record/graphql/createAppResolvers.js.map +1 -1
- package/record/graphql/createAppSchema.js +10 -5
- package/record/graphql/createAppSchema.js.map +1 -1
- package/record/record.crud.js +3 -1
- package/record/record.crud.js.map +1 -1
- package/record/record.gql.js +3 -1
- package/record/record.gql.js.map +1 -1
- package/record/record.model.d.ts +1 -3
- package/record/record.model.js +7 -7
- package/record/record.model.js.map +1 -1
- package/record/record.so.js +35 -23
- package/record/record.so.js.map +1 -1
- package/record/record.types.d.ts +4 -3
- package/record/record.types.js +3 -1
- package/record/record.types.js.map +1 -1
- package/types.d.ts +23 -6
- package/types.js +25 -4
- package/types.js.map +1 -1
- package/utils/FolderLevelPermissions.d.ts +71 -0
- package/utils/FolderLevelPermissions.js +353 -0
- package/utils/FolderLevelPermissions.js.map +1 -0
- package/utils/acoRecordId.js +3 -1
- package/utils/acoRecordId.js.map +1 -1
- package/utils/createListSort.js +3 -1
- package/utils/createListSort.js.map +1 -1
- package/utils/createModelField.js +3 -1
- package/utils/createModelField.js.map +1 -1
- package/utils/createOperationsWrapper.js +3 -1
- package/utils/createOperationsWrapper.js.map +1 -1
- package/utils/decorators/CmsEntriesCrudDecorators.d.ts +11 -0
- package/utils/decorators/CmsEntriesCrudDecorators.js +232 -0
- package/utils/decorators/CmsEntriesCrudDecorators.js.map +1 -0
- package/utils/decorators/constants.d.ts +1 -0
- package/utils/decorators/constants.js +10 -0
- package/utils/decorators/constants.js.map +1 -0
- package/utils/decorators/where.d.ts +14 -0
- package/utils/decorators/where.js +52 -0
- package/utils/decorators/where.js.map +1 -0
- package/utils/ensureAuthentication.d.ts +2 -0
- package/utils/{checkPermissions.js → ensureAuthentication.js} +5 -3
- package/utils/ensureAuthentication.js.map +1 -0
- package/utils/getFolderAndItsAncestors.d.ts +2 -2
- package/utils/getFolderAndItsAncestors.js +16 -11
- package/utils/getFolderAndItsAncestors.js.map +1 -1
- package/utils/isInstallationPending.js +3 -1
- package/utils/isInstallationPending.js.map +1 -1
- package/utils/modelFactory.d.ts +1 -3
- package/utils/modelFactory.js +7 -10
- package/utils/modelFactory.js.map +1 -1
- package/utils/pickEntryFieldValues.d.ts +3 -0
- package/utils/pickEntryFieldValues.js +31 -0
- package/utils/pickEntryFieldValues.js.map +1 -0
- package/utils/resolve.js +3 -1
- package/utils/resolve.js.map +1 -1
- package/folder/onFolderBeforeDelete.hook.d.ts +0 -2
- package/folder/onFolderBeforeDelete.hook.js +0 -66
- package/folder/onFolderBeforeDelete.hook.js.map +0 -1
- package/utils/checkPermissions.d.ts +0 -2
- package/utils/checkPermissions.js.map +0 -1
- package/utils/fieldResolver.d.ts +0 -16
- package/utils/fieldResolver.js +0 -44
- package/utils/fieldResolver.js.map +0 -1
- package/utils/getFieldValues.d.ts +0 -5
- package/utils/getFieldValues.js +0 -16
- package/utils/getFieldValues.js.map +0 -1
package/folder/folder.gql.js
CHANGED
|
@@ -6,24 +6,54 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
6
6
|
exports.folderSchema = void 0;
|
|
7
7
|
var _responses = require("@webiny/handler-graphql/responses");
|
|
8
8
|
var _GraphQLSchemaPlugin = require("@webiny/handler-graphql/plugins/GraphQLSchemaPlugin");
|
|
9
|
-
var
|
|
9
|
+
var _ensureAuthentication = require("../utils/ensureAuthentication");
|
|
10
10
|
var _resolve = require("../utils/resolve");
|
|
11
11
|
const folderSchema = new _GraphQLSchemaPlugin.GraphQLSchemaPlugin({
|
|
12
12
|
typeDefs: /* GraphQL */`
|
|
13
|
+
type FolderPermission {
|
|
14
|
+
target: String!
|
|
15
|
+
level: String!
|
|
16
|
+
inheritedFrom: ID
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
input FolderPermissionInput {
|
|
20
|
+
target: String!
|
|
21
|
+
level: String!
|
|
22
|
+
inheritedFrom: ID
|
|
23
|
+
}
|
|
24
|
+
|
|
13
25
|
type Folder {
|
|
14
26
|
id: ID!
|
|
15
27
|
title: String!
|
|
16
28
|
slug: String!
|
|
29
|
+
permissions: [FolderPermission]
|
|
30
|
+
|
|
31
|
+
# Tells us if the current user can manage folder structure.
|
|
32
|
+
canManageStructure: Boolean
|
|
33
|
+
|
|
34
|
+
# Tells us if the current user can manage folder permissions.
|
|
35
|
+
canManagePermissions: Boolean
|
|
36
|
+
|
|
37
|
+
# Tells us if the current user can manage folder content.
|
|
38
|
+
canManageContent: Boolean
|
|
39
|
+
|
|
40
|
+
# Tells us if the folder contains non-inherited permissions.
|
|
41
|
+
hasNonInheritedPermissions: Boolean
|
|
42
|
+
|
|
17
43
|
type: String!
|
|
18
44
|
parentId: ID
|
|
19
|
-
savedOn: DateTime
|
|
20
45
|
createdOn: DateTime
|
|
46
|
+
modifiedOn: DateTime
|
|
47
|
+
savedOn: DateTime
|
|
21
48
|
createdBy: AcoUser
|
|
49
|
+
modifiedBy: AcoUser
|
|
50
|
+
savedBy: AcoUser
|
|
22
51
|
}
|
|
23
52
|
|
|
24
53
|
input FolderCreateInput {
|
|
25
54
|
title: String!
|
|
26
55
|
slug: String!
|
|
56
|
+
permissions: [FolderPermissionInput]
|
|
27
57
|
type: String!
|
|
28
58
|
parentId: ID
|
|
29
59
|
}
|
|
@@ -31,6 +61,7 @@ const folderSchema = new _GraphQLSchemaPlugin.GraphQLSchemaPlugin({
|
|
|
31
61
|
input FolderUpdateInput {
|
|
32
62
|
title: String
|
|
33
63
|
slug: String
|
|
64
|
+
permissions: [FolderPermissionInput]
|
|
34
65
|
parentId: ID
|
|
35
66
|
}
|
|
36
67
|
|
|
@@ -48,6 +79,25 @@ const folderSchema = new _GraphQLSchemaPlugin.GraphQLSchemaPlugin({
|
|
|
48
79
|
type FoldersListResponse {
|
|
49
80
|
data: [Folder]
|
|
50
81
|
error: AcoError
|
|
82
|
+
meta: AcoMeta
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
type FolderLevelPermissionsTarget {
|
|
86
|
+
id: ID!
|
|
87
|
+
type: String!
|
|
88
|
+
target: ID!
|
|
89
|
+
name: String!
|
|
90
|
+
meta: JSON
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
type FolderLevelPermissionsTargetsListMeta {
|
|
94
|
+
totalCount: Int!
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
type FolderLevelPermissionsTargetsListResponse {
|
|
98
|
+
data: [FolderLevelPermissionsTarget]
|
|
99
|
+
meta: FolderLevelPermissionsTargetsListMeta
|
|
100
|
+
error: AcoError
|
|
51
101
|
}
|
|
52
102
|
|
|
53
103
|
extend type AcoQuery {
|
|
@@ -58,6 +108,8 @@ const folderSchema = new _GraphQLSchemaPlugin.GraphQLSchemaPlugin({
|
|
|
58
108
|
after: String
|
|
59
109
|
sort: AcoSort
|
|
60
110
|
): FoldersListResponse
|
|
111
|
+
|
|
112
|
+
listFolderLevelPermissionsTargets: FolderLevelPermissionsTargetsListResponse
|
|
61
113
|
}
|
|
62
114
|
|
|
63
115
|
extend type AcoMutation {
|
|
@@ -67,23 +119,46 @@ const folderSchema = new _GraphQLSchemaPlugin.GraphQLSchemaPlugin({
|
|
|
67
119
|
}
|
|
68
120
|
`,
|
|
69
121
|
resolvers: {
|
|
122
|
+
Folder: {
|
|
123
|
+
hasNonInheritedPermissions: (folder, _, context) => {
|
|
124
|
+
return context.aco.folderLevelPermissions.permissionsIncludeNonInheritedPermissions(folder.permissions);
|
|
125
|
+
},
|
|
126
|
+
canManageStructure: (folder, _, context) => {
|
|
127
|
+
return context.aco.folderLevelPermissions.canManageFolderStructure(folder);
|
|
128
|
+
},
|
|
129
|
+
canManagePermissions: (folder, _, context) => {
|
|
130
|
+
return context.aco.folderLevelPermissions.canManageFolderPermissions(folder);
|
|
131
|
+
},
|
|
132
|
+
canManageContent: (folder, _, context) => {
|
|
133
|
+
return context.aco.folderLevelPermissions.canManageFolderContent(folder);
|
|
134
|
+
}
|
|
135
|
+
},
|
|
70
136
|
AcoQuery: {
|
|
71
137
|
getFolder: async (_, {
|
|
72
138
|
id
|
|
73
139
|
}, context) => {
|
|
74
140
|
return (0, _resolve.resolve)(() => {
|
|
75
|
-
(0,
|
|
141
|
+
(0, _ensureAuthentication.ensureAuthentication)(context);
|
|
76
142
|
return context.aco.folder.get(id);
|
|
77
143
|
});
|
|
78
144
|
},
|
|
79
145
|
listFolders: async (_, args, context) => {
|
|
80
146
|
try {
|
|
81
|
-
(0,
|
|
147
|
+
(0, _ensureAuthentication.ensureAuthentication)(context);
|
|
82
148
|
const [entries, meta] = await context.aco.folder.list(args);
|
|
83
149
|
return new _responses.ListResponse(entries, meta);
|
|
84
150
|
} catch (e) {
|
|
85
151
|
return new _responses.ErrorResponse(e);
|
|
86
152
|
}
|
|
153
|
+
},
|
|
154
|
+
listFolderLevelPermissionsTargets: async (_, args, context) => {
|
|
155
|
+
try {
|
|
156
|
+
(0, _ensureAuthentication.ensureAuthentication)(context);
|
|
157
|
+
const [entries, meta] = await context.aco.folder.listFolderLevelPermissionsTargets();
|
|
158
|
+
return new _responses.ListResponse(entries, meta);
|
|
159
|
+
} catch (e) {
|
|
160
|
+
return new _responses.ErrorResponse(e);
|
|
161
|
+
}
|
|
87
162
|
}
|
|
88
163
|
},
|
|
89
164
|
AcoMutation: {
|
|
@@ -91,7 +166,7 @@ const folderSchema = new _GraphQLSchemaPlugin.GraphQLSchemaPlugin({
|
|
|
91
166
|
data
|
|
92
167
|
}, context) => {
|
|
93
168
|
return (0, _resolve.resolve)(() => {
|
|
94
|
-
(0,
|
|
169
|
+
(0, _ensureAuthentication.ensureAuthentication)(context);
|
|
95
170
|
return context.aco.folder.create(data);
|
|
96
171
|
});
|
|
97
172
|
},
|
|
@@ -100,7 +175,7 @@ const folderSchema = new _GraphQLSchemaPlugin.GraphQLSchemaPlugin({
|
|
|
100
175
|
data
|
|
101
176
|
}, context) => {
|
|
102
177
|
return (0, _resolve.resolve)(() => {
|
|
103
|
-
(0,
|
|
178
|
+
(0, _ensureAuthentication.ensureAuthentication)(context);
|
|
104
179
|
return context.aco.folder.update(id, data);
|
|
105
180
|
});
|
|
106
181
|
},
|
|
@@ -108,11 +183,13 @@ const folderSchema = new _GraphQLSchemaPlugin.GraphQLSchemaPlugin({
|
|
|
108
183
|
id
|
|
109
184
|
}, context) => {
|
|
110
185
|
return (0, _resolve.resolve)(() => {
|
|
111
|
-
(0,
|
|
186
|
+
(0, _ensureAuthentication.ensureAuthentication)(context);
|
|
112
187
|
return context.aco.folder.delete(id);
|
|
113
188
|
});
|
|
114
189
|
}
|
|
115
190
|
}
|
|
116
191
|
}
|
|
117
192
|
});
|
|
118
|
-
exports.folderSchema = folderSchema;
|
|
193
|
+
exports.folderSchema = folderSchema;
|
|
194
|
+
|
|
195
|
+
//# sourceMappingURL=folder.gql.js.map
|
package/folder/folder.gql.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["folderSchema","GraphQLSchemaPlugin","typeDefs","resolvers","AcoQuery","getFolder","_","id","context","resolve","checkPermissions","aco","folder","get","listFolders","args","entries","meta","list","ListResponse","e","ErrorResponse","AcoMutation","createFolder","data","create","updateFolder","update","deleteFolder","delete"],"sources":["folder.gql.ts"],"sourcesContent":["import { ErrorResponse, ListResponse } from \"@webiny/handler-graphql/responses\";\nimport { GraphQLSchemaPlugin } from \"@webiny/handler-graphql/plugins/GraphQLSchemaPlugin\";\n\nimport { checkPermissions } from \"~/utils/checkPermissions\";\nimport { resolve } from \"~/utils/resolve\";\n\nimport { AcoContext } from \"~/types\";\n\nexport const folderSchema = new GraphQLSchemaPlugin<AcoContext>({\n typeDefs: /* GraphQL */ `\n type Folder {\n id: ID!\n title: String!\n slug: String!\n type: String!\n parentId: ID\n savedOn: DateTime\n createdOn: DateTime\n createdBy: AcoUser\n }\n\n input FolderCreateInput {\n title: String!\n slug: String!\n type: String!\n parentId: ID\n }\n\n input FolderUpdateInput {\n title: String\n slug: String\n parentId: ID\n }\n\n input FoldersListWhereInput {\n type: String!\n parentId: String\n createdBy: ID\n }\n\n type FolderResponse {\n data: Folder\n error: AcoError\n }\n\n type FoldersListResponse {\n data: [Folder]\n error: AcoError\n }\n\n extend type AcoQuery {\n getFolder(id: ID!): FolderResponse\n listFolders(\n where: FoldersListWhereInput!\n limit: Int\n after: String\n sort: AcoSort\n ): FoldersListResponse\n }\n\n extend type AcoMutation {\n createFolder(data: FolderCreateInput!): FolderResponse\n updateFolder(id: ID!, data: FolderUpdateInput!): FolderResponse\n deleteFolder(id: ID!): AcoBooleanResponse\n }\n `,\n resolvers: {\n AcoQuery: {\n getFolder: async (_, { id }, context) => {\n return resolve(() => {\n checkPermissions(context);\n return context.aco.folder.get(id);\n });\n },\n listFolders: async (_, args: any, context) => {\n try {\n checkPermissions(context);\n const [entries, meta] = await context.aco.folder.list(args);\n return new ListResponse(entries, meta);\n } catch (e) {\n return new ErrorResponse(e);\n }\n }\n },\n AcoMutation: {\n createFolder: async (_, { data }, context) => {\n return resolve(() => {\n checkPermissions(context);\n return context.aco.folder.create(data);\n });\n },\n updateFolder: async (_, { id, data }, context) => {\n return resolve(() => {\n checkPermissions(context);\n return context.aco.folder.update(id, data);\n });\n },\n deleteFolder: async (_, { id }, context) => {\n return resolve(() => {\n checkPermissions(context);\n return context.aco.folder.delete(id);\n });\n }\n }\n }\n});\n"],"mappings":";;;;;;AAAA;AACA;AAEA;AACA;AAIO,MAAMA,YAAY,GAAG,IAAIC,wCAAmB,CAAa;EAC5DC,QAAQ,EAAE,aAAe;AAC7B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;EACDC,SAAS,EAAE;IACPC,QAAQ,EAAE;MACNC,SAAS,EAAE,OAAOC,CAAC,EAAE;QAAEC;MAAG,CAAC,EAAEC,OAAO,KAAK;QACrC,OAAO,IAAAC,gBAAO,EAAC,MAAM;UACjB,IAAAC,kCAAgB,EAACF,OAAO,CAAC;UACzB,OAAOA,OAAO,CAACG,GAAG,CAACC,MAAM,CAACC,GAAG,CAACN,EAAE,CAAC;QACrC,CAAC,CAAC;MACN,CAAC;MACDO,WAAW,EAAE,OAAOR,CAAC,EAAES,IAAS,EAAEP,OAAO,KAAK;QAC1C,IAAI;UACA,IAAAE,kCAAgB,EAACF,OAAO,CAAC;UACzB,MAAM,CAACQ,OAAO,EAAEC,IAAI,CAAC,GAAG,MAAMT,OAAO,CAACG,GAAG,CAACC,MAAM,CAACM,IAAI,CAACH,IAAI,CAAC;UAC3D,OAAO,IAAII,uBAAY,CAACH,OAAO,EAAEC,IAAI,CAAC;QAC1C,CAAC,CAAC,OAAOG,CAAC,EAAE;UACR,OAAO,IAAIC,wBAAa,CAACD,CAAC,CAAC;QAC/B;MACJ;IACJ,CAAC;IACDE,WAAW,EAAE;MACTC,YAAY,EAAE,OAAOjB,CAAC,EAAE;QAAEkB;MAAK,CAAC,EAAEhB,OAAO,KAAK;QAC1C,OAAO,IAAAC,gBAAO,EAAC,MAAM;UACjB,IAAAC,kCAAgB,EAACF,OAAO,CAAC;UACzB,OAAOA,OAAO,CAACG,GAAG,CAACC,MAAM,CAACa,MAAM,CAACD,IAAI,CAAC;QAC1C,CAAC,CAAC;MACN,CAAC;MACDE,YAAY,EAAE,OAAOpB,CAAC,EAAE;QAAEC,EAAE;QAAEiB;MAAK,CAAC,EAAEhB,OAAO,KAAK;QAC9C,OAAO,IAAAC,gBAAO,EAAC,MAAM;UACjB,IAAAC,kCAAgB,EAACF,OAAO,CAAC;UACzB,OAAOA,OAAO,CAACG,GAAG,CAACC,MAAM,CAACe,MAAM,CAACpB,EAAE,EAAEiB,IAAI,CAAC;QAC9C,CAAC,CAAC;MACN,CAAC;MACDI,YAAY,EAAE,OAAOtB,CAAC,EAAE;QAAEC;MAAG,CAAC,EAAEC,OAAO,KAAK;QACxC,OAAO,IAAAC,gBAAO,EAAC,MAAM;UACjB,IAAAC,kCAAgB,EAACF,OAAO,CAAC;UACzB,OAAOA,OAAO,CAACG,GAAG,CAACC,MAAM,CAACiB,MAAM,CAACtB,EAAE,CAAC;QACxC,CAAC,CAAC;MACN;IACJ;EACJ;AACJ,CAAC,CAAC;AAAC"}
|
|
1
|
+
{"version":3,"names":["_responses","require","_GraphQLSchemaPlugin","_ensureAuthentication","_resolve","folderSchema","GraphQLSchemaPlugin","typeDefs","resolvers","Folder","hasNonInheritedPermissions","folder","_","context","aco","folderLevelPermissions","permissionsIncludeNonInheritedPermissions","permissions","canManageStructure","canManageFolderStructure","canManagePermissions","canManageFolderPermissions","canManageContent","canManageFolderContent","AcoQuery","getFolder","id","resolve","ensureAuthentication","get","listFolders","args","entries","meta","list","ListResponse","e","ErrorResponse","listFolderLevelPermissionsTargets","AcoMutation","createFolder","data","create","updateFolder","update","deleteFolder","delete","exports"],"sources":["folder.gql.ts"],"sourcesContent":["import { ErrorResponse, ListResponse } from \"@webiny/handler-graphql/responses\";\nimport { GraphQLSchemaPlugin } from \"@webiny/handler-graphql/plugins/GraphQLSchemaPlugin\";\n\nimport { ensureAuthentication } from \"~/utils/ensureAuthentication\";\nimport { resolve } from \"~/utils/resolve\";\n\nimport { AcoContext, Folder } from \"~/types\";\n\nexport const folderSchema = new GraphQLSchemaPlugin<AcoContext>({\n typeDefs: /* GraphQL */ `\n type FolderPermission {\n target: String!\n level: String!\n inheritedFrom: ID\n }\n\n input FolderPermissionInput {\n target: String!\n level: String!\n inheritedFrom: ID\n }\n\n type Folder {\n id: ID!\n title: String!\n slug: String!\n permissions: [FolderPermission]\n\n # Tells us if the current user can manage folder structure.\n canManageStructure: Boolean\n\n # Tells us if the current user can manage folder permissions.\n canManagePermissions: Boolean\n\n # Tells us if the current user can manage folder content.\n canManageContent: Boolean\n\n # Tells us if the folder contains non-inherited permissions.\n hasNonInheritedPermissions: Boolean\n\n type: String!\n parentId: ID\n createdOn: DateTime\n modifiedOn: DateTime\n savedOn: DateTime\n createdBy: AcoUser\n modifiedBy: AcoUser\n savedBy: AcoUser\n }\n\n input FolderCreateInput {\n title: String!\n slug: String!\n permissions: [FolderPermissionInput]\n type: String!\n parentId: ID\n }\n\n input FolderUpdateInput {\n title: String\n slug: String\n permissions: [FolderPermissionInput]\n parentId: ID\n }\n\n input FoldersListWhereInput {\n type: String!\n parentId: String\n createdBy: ID\n }\n\n type FolderResponse {\n data: Folder\n error: AcoError\n }\n\n type FoldersListResponse {\n data: [Folder]\n error: AcoError\n meta: AcoMeta\n }\n\n type FolderLevelPermissionsTarget {\n id: ID!\n type: String!\n target: ID!\n name: String!\n meta: JSON\n }\n\n type FolderLevelPermissionsTargetsListMeta {\n totalCount: Int!\n }\n\n type FolderLevelPermissionsTargetsListResponse {\n data: [FolderLevelPermissionsTarget]\n meta: FolderLevelPermissionsTargetsListMeta\n error: AcoError\n }\n\n extend type AcoQuery {\n getFolder(id: ID!): FolderResponse\n listFolders(\n where: FoldersListWhereInput!\n limit: Int\n after: String\n sort: AcoSort\n ): FoldersListResponse\n\n listFolderLevelPermissionsTargets: FolderLevelPermissionsTargetsListResponse\n }\n\n extend type AcoMutation {\n createFolder(data: FolderCreateInput!): FolderResponse\n updateFolder(id: ID!, data: FolderUpdateInput!): FolderResponse\n deleteFolder(id: ID!): AcoBooleanResponse\n }\n `,\n resolvers: {\n Folder: {\n hasNonInheritedPermissions: (folder: Folder, _, context) => {\n return context.aco.folderLevelPermissions.permissionsIncludeNonInheritedPermissions(\n folder.permissions\n );\n },\n canManageStructure: (folder, _, context) => {\n return context.aco.folderLevelPermissions.canManageFolderStructure(folder);\n },\n canManagePermissions: (folder, _, context) => {\n return context.aco.folderLevelPermissions.canManageFolderPermissions(folder);\n },\n canManageContent: (folder, _, context) => {\n return context.aco.folderLevelPermissions.canManageFolderContent(folder);\n }\n },\n AcoQuery: {\n getFolder: async (_, { id }, context) => {\n return resolve(() => {\n ensureAuthentication(context);\n return context.aco.folder.get(id);\n });\n },\n listFolders: async (_, args: any, context) => {\n try {\n ensureAuthentication(context);\n const [entries, meta] = await context.aco.folder.list(args);\n return new ListResponse(entries, meta);\n } catch (e) {\n return new ErrorResponse(e);\n }\n },\n listFolderLevelPermissionsTargets: async (_, args: any, context) => {\n try {\n ensureAuthentication(context);\n const [entries, meta] =\n await context.aco.folder.listFolderLevelPermissionsTargets();\n return new ListResponse(entries, meta);\n } catch (e) {\n return new ErrorResponse(e);\n }\n }\n },\n AcoMutation: {\n createFolder: async (_, { data }, context) => {\n return resolve(() => {\n ensureAuthentication(context);\n return context.aco.folder.create(data);\n });\n },\n updateFolder: async (_, { id, data }, context) => {\n return resolve(() => {\n ensureAuthentication(context);\n return context.aco.folder.update(id, data);\n });\n },\n deleteFolder: async (_, { id }, context) => {\n return resolve(() => {\n ensureAuthentication(context);\n return context.aco.folder.delete(id);\n });\n }\n }\n }\n});\n"],"mappings":";;;;;;AAAA,IAAAA,UAAA,GAAAC,OAAA;AACA,IAAAC,oBAAA,GAAAD,OAAA;AAEA,IAAAE,qBAAA,GAAAF,OAAA;AACA,IAAAG,QAAA,GAAAH,OAAA;AAIO,MAAMI,YAAY,GAAG,IAAIC,wCAAmB,CAAa;EAC5DC,QAAQ,EAAE,aAAe;AAC7B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;EACDC,SAAS,EAAE;IACPC,MAAM,EAAE;MACJC,0BAA0B,EAAEA,CAACC,MAAc,EAAEC,CAAC,EAAEC,OAAO,KAAK;QACxD,OAAOA,OAAO,CAACC,GAAG,CAACC,sBAAsB,CAACC,yCAAyC,CAC/EL,MAAM,CAACM,WACX,CAAC;MACL,CAAC;MACDC,kBAAkB,EAAEA,CAACP,MAAM,EAAEC,CAAC,EAAEC,OAAO,KAAK;QACxC,OAAOA,OAAO,CAACC,GAAG,CAACC,sBAAsB,CAACI,wBAAwB,CAACR,MAAM,CAAC;MAC9E,CAAC;MACDS,oBAAoB,EAAEA,CAACT,MAAM,EAAEC,CAAC,EAAEC,OAAO,KAAK;QAC1C,OAAOA,OAAO,CAACC,GAAG,CAACC,sBAAsB,CAACM,0BAA0B,CAACV,MAAM,CAAC;MAChF,CAAC;MACDW,gBAAgB,EAAEA,CAACX,MAAM,EAAEC,CAAC,EAAEC,OAAO,KAAK;QACtC,OAAOA,OAAO,CAACC,GAAG,CAACC,sBAAsB,CAACQ,sBAAsB,CAACZ,MAAM,CAAC;MAC5E;IACJ,CAAC;IACDa,QAAQ,EAAE;MACNC,SAAS,EAAE,MAAAA,CAAOb,CAAC,EAAE;QAAEc;MAAG,CAAC,EAAEb,OAAO,KAAK;QACrC,OAAO,IAAAc,gBAAO,EAAC,MAAM;UACjB,IAAAC,0CAAoB,EAACf,OAAO,CAAC;UAC7B,OAAOA,OAAO,CAACC,GAAG,CAACH,MAAM,CAACkB,GAAG,CAACH,EAAE,CAAC;QACrC,CAAC,CAAC;MACN,CAAC;MACDI,WAAW,EAAE,MAAAA,CAAOlB,CAAC,EAAEmB,IAAS,EAAElB,OAAO,KAAK;QAC1C,IAAI;UACA,IAAAe,0CAAoB,EAACf,OAAO,CAAC;UAC7B,MAAM,CAACmB,OAAO,EAAEC,IAAI,CAAC,GAAG,MAAMpB,OAAO,CAACC,GAAG,CAACH,MAAM,CAACuB,IAAI,CAACH,IAAI,CAAC;UAC3D,OAAO,IAAII,uBAAY,CAACH,OAAO,EAAEC,IAAI,CAAC;QAC1C,CAAC,CAAC,OAAOG,CAAC,EAAE;UACR,OAAO,IAAIC,wBAAa,CAACD,CAAC,CAAC;QAC/B;MACJ,CAAC;MACDE,iCAAiC,EAAE,MAAAA,CAAO1B,CAAC,EAAEmB,IAAS,EAAElB,OAAO,KAAK;QAChE,IAAI;UACA,IAAAe,0CAAoB,EAACf,OAAO,CAAC;UAC7B,MAAM,CAACmB,OAAO,EAAEC,IAAI,CAAC,GACjB,MAAMpB,OAAO,CAACC,GAAG,CAACH,MAAM,CAAC2B,iCAAiC,CAAC,CAAC;UAChE,OAAO,IAAIH,uBAAY,CAACH,OAAO,EAAEC,IAAI,CAAC;QAC1C,CAAC,CAAC,OAAOG,CAAC,EAAE;UACR,OAAO,IAAIC,wBAAa,CAACD,CAAC,CAAC;QAC/B;MACJ;IACJ,CAAC;IACDG,WAAW,EAAE;MACTC,YAAY,EAAE,MAAAA,CAAO5B,CAAC,EAAE;QAAE6B;MAAK,CAAC,EAAE5B,OAAO,KAAK;QAC1C,OAAO,IAAAc,gBAAO,EAAC,MAAM;UACjB,IAAAC,0CAAoB,EAACf,OAAO,CAAC;UAC7B,OAAOA,OAAO,CAACC,GAAG,CAACH,MAAM,CAAC+B,MAAM,CAACD,IAAI,CAAC;QAC1C,CAAC,CAAC;MACN,CAAC;MACDE,YAAY,EAAE,MAAAA,CAAO/B,CAAC,EAAE;QAAEc,EAAE;QAAEe;MAAK,CAAC,EAAE5B,OAAO,KAAK;QAC9C,OAAO,IAAAc,gBAAO,EAAC,MAAM;UACjB,IAAAC,0CAAoB,EAACf,OAAO,CAAC;UAC7B,OAAOA,OAAO,CAACC,GAAG,CAACH,MAAM,CAACiC,MAAM,CAAClB,EAAE,EAAEe,IAAI,CAAC;QAC9C,CAAC,CAAC;MACN,CAAC;MACDI,YAAY,EAAE,MAAAA,CAAOjC,CAAC,EAAE;QAAEc;MAAG,CAAC,EAAEb,OAAO,KAAK;QACxC,OAAO,IAAAc,gBAAO,EAAC,MAAM;UACjB,IAAAC,0CAAoB,EAACf,OAAO,CAAC;UAC7B,OAAOA,OAAO,CAACC,GAAG,CAACH,MAAM,CAACmC,MAAM,CAACpB,EAAE,CAAC;QACxC,CAAC,CAAC;MACN;IACJ;EACJ;AACJ,CAAC,CAAC;AAACqB,OAAA,CAAA1C,YAAA,GAAAA,YAAA"}
|
package/folder/folder.model.d.ts
CHANGED
|
@@ -1,4 +1,2 @@
|
|
|
1
|
-
import { CmsPrivateModelFull } from "@webiny/api-headless-cms";
|
|
2
|
-
export declare type FolderModelDefinition = Omit<CmsPrivateModelFull, "noValidate" | "group">;
|
|
3
1
|
export declare const FOLDER_MODEL_ID = "acoFolder";
|
|
4
|
-
export declare const createFolderModelDefinition: () =>
|
|
2
|
+
export declare const createFolderModelDefinition: () => import("@webiny/api-headless-cms").CmsPrivateModelFull;
|
package/folder/folder.model.js
CHANGED
|
@@ -5,6 +5,7 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
5
5
|
});
|
|
6
6
|
exports.createFolderModelDefinition = exports.FOLDER_MODEL_ID = void 0;
|
|
7
7
|
var _createModelField = require("../utils/createModelField");
|
|
8
|
+
var _apiHeadlessCms = require("@webiny/api-headless-cms");
|
|
8
9
|
const titleField = () => (0, _createModelField.createModelField)({
|
|
9
10
|
label: "Title",
|
|
10
11
|
type: "text",
|
|
@@ -41,17 +42,63 @@ const parentIdField = () => (0, _createModelField.createModelField)({
|
|
|
41
42
|
label: "Parent Id",
|
|
42
43
|
type: "text"
|
|
43
44
|
});
|
|
45
|
+
const permissionsField = () => (0, _createModelField.createModelField)({
|
|
46
|
+
label: "Permissions",
|
|
47
|
+
fieldId: "permissions",
|
|
48
|
+
type: "object",
|
|
49
|
+
multipleValues: true,
|
|
50
|
+
listValidation: [],
|
|
51
|
+
settings: {
|
|
52
|
+
fields: [{
|
|
53
|
+
id: "target",
|
|
54
|
+
type: "text",
|
|
55
|
+
storageId: "text@target",
|
|
56
|
+
fieldId: "target",
|
|
57
|
+
label: "Target",
|
|
58
|
+
validation: [{
|
|
59
|
+
name: "required",
|
|
60
|
+
message: "Value is required."
|
|
61
|
+
}]
|
|
62
|
+
}, {
|
|
63
|
+
id: "level",
|
|
64
|
+
type: "text",
|
|
65
|
+
storageId: "text@level",
|
|
66
|
+
fieldId: "level",
|
|
67
|
+
label: "Level",
|
|
68
|
+
validation: [{
|
|
69
|
+
name: "required",
|
|
70
|
+
message: "Value is required."
|
|
71
|
+
}],
|
|
72
|
+
predefinedValues: {
|
|
73
|
+
enabled: true,
|
|
74
|
+
values: [{
|
|
75
|
+
label: "Viewer",
|
|
76
|
+
value: "viewer"
|
|
77
|
+
}, {
|
|
78
|
+
label: "Editor",
|
|
79
|
+
value: "editor"
|
|
80
|
+
}, {
|
|
81
|
+
label: "Owner",
|
|
82
|
+
value: "owner"
|
|
83
|
+
}, {
|
|
84
|
+
label: "Public",
|
|
85
|
+
value: "public"
|
|
86
|
+
}]
|
|
87
|
+
}
|
|
88
|
+
}],
|
|
89
|
+
layout: [["target"], ["level"]]
|
|
90
|
+
}
|
|
91
|
+
});
|
|
44
92
|
const FOLDER_MODEL_ID = "acoFolder";
|
|
45
93
|
exports.FOLDER_MODEL_ID = FOLDER_MODEL_ID;
|
|
46
94
|
const createFolderModelDefinition = () => {
|
|
47
|
-
return {
|
|
95
|
+
return (0, _apiHeadlessCms.createPrivateModelDefinition)({
|
|
48
96
|
name: "ACO - Folder",
|
|
49
97
|
modelId: FOLDER_MODEL_ID,
|
|
50
98
|
titleFieldId: "title",
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
description: "ACO - Folder content model",
|
|
54
|
-
isPrivate: true
|
|
55
|
-
};
|
|
99
|
+
fields: [titleField(), slugField(), typeField(), parentIdField(), permissionsField()]
|
|
100
|
+
});
|
|
56
101
|
};
|
|
57
|
-
exports.createFolderModelDefinition = createFolderModelDefinition;
|
|
102
|
+
exports.createFolderModelDefinition = createFolderModelDefinition;
|
|
103
|
+
|
|
104
|
+
//# sourceMappingURL=folder.model.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["titleField","createModelField","label","type","validation","name","message","slugField","settings","preset","regex","flags","typeField","parentIdField","
|
|
1
|
+
{"version":3,"names":["_createModelField","require","_apiHeadlessCms","titleField","createModelField","label","type","validation","name","message","slugField","settings","preset","regex","flags","typeField","parentIdField","permissionsField","fieldId","multipleValues","listValidation","fields","id","storageId","predefinedValues","enabled","values","value","layout","FOLDER_MODEL_ID","exports","createFolderModelDefinition","createPrivateModelDefinition","modelId","titleFieldId"],"sources":["folder.model.ts"],"sourcesContent":["import { createModelField } from \"~/utils/createModelField\";\nimport { createPrivateModelDefinition } from \"@webiny/api-headless-cms\";\n\nconst titleField = () =>\n createModelField({\n label: \"Title\",\n type: \"text\",\n validation: [\n {\n name: \"required\",\n message: \"Value is required.\"\n }\n ]\n });\n\nconst slugField = () =>\n createModelField({\n label: \"Slug\",\n type: \"text\",\n validation: [\n {\n name: \"required\",\n message: \"Value is required.\"\n },\n {\n name: \"pattern\",\n settings: {\n preset: \"custom\",\n regex: \"^[a-z0-9]+(-[a-z0-9]+)*$\",\n flags: \"g\"\n },\n message: \"Value must consist of only 'a-z', '0-9' and '-'.\"\n }\n ]\n });\n\nconst typeField = () =>\n createModelField({\n label: \"Type\",\n type: \"text\",\n validation: [\n {\n name: \"required\",\n message: \"Value is required.\"\n }\n ]\n });\n\nconst parentIdField = () =>\n createModelField({\n label: \"Parent Id\",\n type: \"text\"\n });\n\nconst permissionsField = () =>\n createModelField({\n label: \"Permissions\",\n fieldId: \"permissions\",\n type: \"object\",\n multipleValues: true,\n listValidation: [],\n settings: {\n fields: [\n {\n id: \"target\",\n type: \"text\",\n storageId: \"text@target\",\n fieldId: \"target\",\n label: \"Target\",\n validation: [\n {\n name: \"required\",\n message: \"Value is required.\"\n }\n ]\n },\n {\n id: \"level\",\n type: \"text\",\n storageId: \"text@level\",\n fieldId: \"level\",\n label: \"Level\",\n validation: [\n {\n name: \"required\",\n message: \"Value is required.\"\n }\n ],\n predefinedValues: {\n enabled: true,\n values: [\n {\n label: \"Viewer\",\n value: \"viewer\"\n },\n {\n label: \"Editor\",\n value: \"editor\"\n },\n {\n label: \"Owner\",\n value: \"owner\"\n },\n {\n label: \"Public\",\n value: \"public\"\n }\n ]\n }\n }\n ],\n layout: [[\"target\"], [\"level\"]]\n }\n });\n\nexport const FOLDER_MODEL_ID = \"acoFolder\";\n\nexport const createFolderModelDefinition = () => {\n return createPrivateModelDefinition({\n name: \"ACO - Folder\",\n modelId: FOLDER_MODEL_ID,\n titleFieldId: \"title\",\n fields: [titleField(), slugField(), typeField(), parentIdField(), permissionsField()]\n });\n};\n"],"mappings":"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"}
|
package/folder/folder.so.js
CHANGED
|
@@ -5,22 +5,23 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
5
5
|
value: true
|
|
6
6
|
});
|
|
7
7
|
exports.createFolderOperations = void 0;
|
|
8
|
-
var
|
|
8
|
+
var _omit = _interopRequireDefault(require("lodash/omit"));
|
|
9
9
|
var _error = _interopRequireDefault(require("@webiny/error"));
|
|
10
10
|
var _folder = require("./folder.model");
|
|
11
|
-
var _createAcoStorageOperations = require("../createAcoStorageOperations");
|
|
12
11
|
var _createListSort = require("../utils/createListSort");
|
|
13
12
|
var _createOperationsWrapper = require("../utils/createOperationsWrapper");
|
|
14
|
-
var
|
|
13
|
+
var _pickEntryFieldValues = require("../utils/pickEntryFieldValues");
|
|
14
|
+
var _constants = require("@webiny/api-headless-cms/constants");
|
|
15
15
|
const createFolderOperations = params => {
|
|
16
16
|
const {
|
|
17
17
|
cms
|
|
18
18
|
} = params;
|
|
19
19
|
const {
|
|
20
20
|
withModel
|
|
21
|
-
} = (0, _createOperationsWrapper.createOperationsWrapper)(
|
|
21
|
+
} = (0, _createOperationsWrapper.createOperationsWrapper)({
|
|
22
|
+
...params,
|
|
22
23
|
modelName: _folder.FOLDER_MODEL_ID
|
|
23
|
-
})
|
|
24
|
+
});
|
|
24
25
|
const getFolder = ({
|
|
25
26
|
id,
|
|
26
27
|
slug,
|
|
@@ -49,7 +50,7 @@ const createFolderOperations = params => {
|
|
|
49
50
|
parentId
|
|
50
51
|
});
|
|
51
52
|
}
|
|
52
|
-
return (0,
|
|
53
|
+
return (0, _pickEntryFieldValues.pickEntryFieldValues)(entry);
|
|
53
54
|
});
|
|
54
55
|
};
|
|
55
56
|
const checkExistingFolder = ({
|
|
@@ -62,8 +63,14 @@ const createFolderOperations = params => {
|
|
|
62
63
|
slug,
|
|
63
64
|
parentId
|
|
64
65
|
} = params;
|
|
65
|
-
|
|
66
|
+
|
|
67
|
+
// We don't need to perform any kind of authorization or checks here. We just need to check
|
|
68
|
+
// if the folder already exists in the database. Hence the direct storage operations access.
|
|
69
|
+
const listResult = await cms.storageOperations.entries.list(model, {
|
|
70
|
+
...params,
|
|
66
71
|
where: {
|
|
72
|
+
// Folders always work with latest entries. We never publish them.
|
|
73
|
+
latest: true,
|
|
67
74
|
type,
|
|
68
75
|
slug,
|
|
69
76
|
parentId,
|
|
@@ -71,7 +78,7 @@ const createFolderOperations = params => {
|
|
|
71
78
|
},
|
|
72
79
|
limit: 1
|
|
73
80
|
});
|
|
74
|
-
if (
|
|
81
|
+
if (listResult?.items?.length > 0) {
|
|
75
82
|
throw new _error.default(`Folder with slug "${slug}" already exists at this level.`, "FOLDER_ALREADY_EXISTS", {
|
|
76
83
|
id,
|
|
77
84
|
params
|
|
@@ -88,11 +95,14 @@ const createFolderOperations = params => {
|
|
|
88
95
|
sort,
|
|
89
96
|
where
|
|
90
97
|
} = params;
|
|
91
|
-
const [entries, meta] = await cms.listLatestEntries(model,
|
|
98
|
+
const [entries, meta] = await cms.listLatestEntries(model, {
|
|
99
|
+
...params,
|
|
92
100
|
sort: (0, _createListSort.createListSort)(sort),
|
|
93
|
-
where:
|
|
94
|
-
|
|
95
|
-
|
|
101
|
+
where: {
|
|
102
|
+
...(where || {})
|
|
103
|
+
}
|
|
104
|
+
});
|
|
105
|
+
return [entries.map(_pickEntryFieldValues.pickEntryFieldValues), meta];
|
|
96
106
|
});
|
|
97
107
|
},
|
|
98
108
|
createFolder({
|
|
@@ -106,10 +116,11 @@ const createFolderOperations = params => {
|
|
|
106
116
|
parentId: data.parentId
|
|
107
117
|
}
|
|
108
118
|
});
|
|
109
|
-
const entry = await cms.createEntry(model,
|
|
119
|
+
const entry = await cms.createEntry(model, {
|
|
120
|
+
...data,
|
|
110
121
|
parentId: data.parentId || null
|
|
111
|
-
})
|
|
112
|
-
return (0,
|
|
122
|
+
});
|
|
123
|
+
return (0, _pickEntryFieldValues.pickEntryFieldValues)(entry);
|
|
113
124
|
});
|
|
114
125
|
},
|
|
115
126
|
updateFolder({
|
|
@@ -133,9 +144,16 @@ const createFolderOperations = params => {
|
|
|
133
144
|
}
|
|
134
145
|
});
|
|
135
146
|
|
|
136
|
-
const input =
|
|
147
|
+
const input = {
|
|
148
|
+
/**
|
|
149
|
+
* We are omitting the standard entry meta fields:
|
|
150
|
+
* we don't want to override them with the ones coming from the `original` entry.
|
|
151
|
+
*/
|
|
152
|
+
...(0, _omit.default)(original, _constants.ENTRY_META_FIELDS),
|
|
153
|
+
...data
|
|
154
|
+
};
|
|
137
155
|
const entry = await cms.updateEntry(model, id, input);
|
|
138
|
-
return (0,
|
|
156
|
+
return (0, _pickEntryFieldValues.pickEntryFieldValues)(entry);
|
|
139
157
|
});
|
|
140
158
|
},
|
|
141
159
|
deleteFolder({
|
|
@@ -148,4 +166,6 @@ const createFolderOperations = params => {
|
|
|
148
166
|
}
|
|
149
167
|
};
|
|
150
168
|
};
|
|
151
|
-
exports.createFolderOperations = createFolderOperations;
|
|
169
|
+
exports.createFolderOperations = createFolderOperations;
|
|
170
|
+
|
|
171
|
+
//# sourceMappingURL=folder.so.js.map
|
package/folder/folder.so.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["createFolderOperations","params","cms","withModel","createOperationsWrapper","modelName","FOLDER_MODEL_ID","getFolder","id","slug","type","parentId","model","entry","getEntryById","getEntry","where","latest","WebinyError","
|
|
1
|
+
{"version":3,"names":["_omit","_interopRequireDefault","require","_error","_folder","_createListSort","_createOperationsWrapper","_pickEntryFieldValues","_constants","createFolderOperations","params","cms","withModel","createOperationsWrapper","modelName","FOLDER_MODEL_ID","getFolder","id","slug","type","parentId","model","entry","getEntryById","getEntry","where","latest","WebinyError","pickEntryFieldValues","checkExistingFolder","listResult","storageOperations","entries","list","id_not","limit","items","length","listFolders","sort","meta","listLatestEntries","createListSort","map","createFolder","data","createEntry","updateFolder","original","undefined","input","omit","ENTRY_META_FIELDS","updateEntry","deleteFolder","deleteEntry","exports"],"sources":["folder.so.ts"],"sourcesContent":["import omit from \"lodash/omit\";\nimport WebinyError from \"@webiny/error\";\nimport { FOLDER_MODEL_ID } from \"./folder.model\";\nimport { CreateAcoStorageOperationsParams } from \"~/createAcoStorageOperations\";\nimport { createListSort } from \"~/utils/createListSort\";\nimport { createOperationsWrapper } from \"~/utils/createOperationsWrapper\";\nimport { pickEntryFieldValues } from \"~/utils/pickEntryFieldValues\";\nimport { AcoFolderStorageOperations, Folder } from \"./folder.types\";\nimport { ENTRY_META_FIELDS } from \"@webiny/api-headless-cms/constants\";\n\ninterface AcoCheckExistingFolderParams {\n params: {\n type: string;\n slug: string;\n parentId?: string | null;\n };\n id?: string;\n}\n\nexport const createFolderOperations = (\n params: CreateAcoStorageOperationsParams\n): AcoFolderStorageOperations => {\n const { cms } = params;\n\n const { withModel } = createOperationsWrapper({\n ...params,\n modelName: FOLDER_MODEL_ID\n });\n\n const getFolder: AcoFolderStorageOperations[\"getFolder\"] = ({ id, slug, type, parentId }) => {\n return withModel(async model => {\n let entry;\n\n if (id) {\n entry = await cms.getEntryById(model, id);\n } else if (slug && type) {\n entry = await cms.getEntry(model, {\n where: { slug, type, parentId, latest: true }\n });\n }\n\n if (!entry) {\n throw new WebinyError(\"Could not load folder.\", \"GET_FOLDER_ERROR\", {\n id,\n slug,\n type,\n parentId\n });\n }\n\n return pickEntryFieldValues(entry);\n });\n };\n\n const checkExistingFolder = ({ id, params }: AcoCheckExistingFolderParams) => {\n return withModel(async model => {\n const { type, slug, parentId } = params;\n\n // We don't need to perform any kind of authorization or checks here. We just need to check\n // if the folder already exists in the database. Hence the direct storage operations access.\n const listResult = await cms.storageOperations.entries.list(model, {\n ...params,\n where: {\n // Folders always work with latest entries. We never publish them.\n latest: true,\n type,\n slug,\n parentId,\n id_not: id\n },\n limit: 1\n });\n\n if (listResult?.items?.length > 0) {\n throw new WebinyError(\n `Folder with slug \"${slug}\" already exists at this level.`,\n \"FOLDER_ALREADY_EXISTS\",\n {\n id,\n params\n }\n );\n }\n\n return;\n });\n };\n\n return {\n getFolder,\n listFolders(params) {\n return withModel(async model => {\n const { sort, where } = params;\n\n const [entries, meta] = await cms.listLatestEntries(model, {\n ...params,\n sort: createListSort(sort),\n where: {\n ...(where || {})\n }\n });\n\n return [entries.map(pickEntryFieldValues<Folder>), meta];\n });\n },\n createFolder({ data }) {\n return withModel(async model => {\n await checkExistingFolder({\n params: {\n type: data.type,\n slug: data.slug,\n parentId: data.parentId\n }\n });\n\n const entry = await cms.createEntry(model, {\n ...data,\n parentId: data.parentId || null\n });\n\n return pickEntryFieldValues(entry);\n });\n },\n updateFolder({ id, data }) {\n return withModel(async model => {\n const { slug, parentId } = data;\n\n const original = await getFolder({ id });\n\n await checkExistingFolder({\n id,\n params: {\n type: original.type,\n slug: slug || original.slug,\n parentId: parentId !== undefined ? parentId : original.parentId // parentId can be `null`\n }\n });\n\n const input = {\n /**\n * We are omitting the standard entry meta fields:\n * we don't want to override them with the ones coming from the `original` entry.\n */\n ...omit(original, ENTRY_META_FIELDS),\n ...data\n };\n\n const entry = await cms.updateEntry(model, id, input);\n return pickEntryFieldValues(entry);\n });\n },\n deleteFolder({ id }) {\n return withModel(async model => {\n await cms.deleteEntry(model, id);\n return true;\n });\n }\n };\n};\n"],"mappings":"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"}
|
package/folder/folder.types.d.ts
CHANGED
|
@@ -1,13 +1,18 @@
|
|
|
1
1
|
import { ListMeta, ListSort, User } from "../types";
|
|
2
2
|
import { Topic } from "@webiny/pubsub/types";
|
|
3
|
+
import { FolderPermission } from "../utils/FolderLevelPermissions";
|
|
3
4
|
export interface Folder {
|
|
4
5
|
id: string;
|
|
5
6
|
entryId: string;
|
|
6
7
|
createdOn: string;
|
|
7
|
-
|
|
8
|
+
modifiedOn: string | null;
|
|
8
9
|
savedOn: string;
|
|
10
|
+
createdBy: User;
|
|
11
|
+
modifiedBy: User | null;
|
|
12
|
+
savedBy: User;
|
|
9
13
|
title: string;
|
|
10
14
|
slug: string;
|
|
15
|
+
permissions?: FolderPermission[];
|
|
11
16
|
type: string;
|
|
12
17
|
parentId?: string | null;
|
|
13
18
|
}
|
|
@@ -21,15 +26,27 @@ export interface ListFoldersParams {
|
|
|
21
26
|
limit?: number;
|
|
22
27
|
after?: string | null;
|
|
23
28
|
}
|
|
29
|
+
export declare type ListAllFoldersParams = Omit<ListFoldersParams, "limit" | "after">;
|
|
24
30
|
export declare type CreateFolderParams = Pick<Folder, "title" | "slug" | "type" | "parentId">;
|
|
25
31
|
export interface UpdateFolderParams {
|
|
26
32
|
title?: string;
|
|
27
33
|
slug?: string;
|
|
34
|
+
permissions?: FolderPermission[];
|
|
28
35
|
parentId?: string;
|
|
29
36
|
}
|
|
30
37
|
export interface DeleteFolderParams {
|
|
31
38
|
id: string;
|
|
32
39
|
}
|
|
40
|
+
export interface FolderLevelPermissionsTarget<TMeta = Record<string, any>> {
|
|
41
|
+
id: string;
|
|
42
|
+
target: string;
|
|
43
|
+
name: string;
|
|
44
|
+
type: string;
|
|
45
|
+
meta: TMeta;
|
|
46
|
+
}
|
|
47
|
+
export interface FolderLevelPermissionsTargetListMeta {
|
|
48
|
+
totalCount: number;
|
|
49
|
+
}
|
|
33
50
|
export interface StorageOperationsGetFolderParams {
|
|
34
51
|
id?: string;
|
|
35
52
|
slug?: string;
|
|
@@ -69,9 +86,18 @@ export interface OnFolderAfterDeleteTopicParams {
|
|
|
69
86
|
export interface AcoFolderCrud {
|
|
70
87
|
get(id: string): Promise<Folder>;
|
|
71
88
|
list(params: ListFoldersParams): Promise<[Folder[], ListMeta]>;
|
|
89
|
+
listFolderLevelPermissionsTargets(): Promise<[
|
|
90
|
+
FolderLevelPermissionsTarget[],
|
|
91
|
+
FolderLevelPermissionsTargetListMeta
|
|
92
|
+
]>;
|
|
93
|
+
listAll(params: ListAllFoldersParams): Promise<[Folder[], ListMeta]>;
|
|
72
94
|
create(data: CreateFolderParams): Promise<Folder>;
|
|
73
95
|
update(id: string, data: UpdateFolderParams): Promise<Folder>;
|
|
74
|
-
delete(id: string): Promise<
|
|
96
|
+
delete(id: string): Promise<boolean>;
|
|
97
|
+
getAncestors(folder: Folder): Promise<Folder[]>;
|
|
98
|
+
/**
|
|
99
|
+
* @deprecated use `getAncestors` instead
|
|
100
|
+
*/
|
|
75
101
|
getFolderWithAncestors(id: string): Promise<Folder[]>;
|
|
76
102
|
onFolderBeforeCreate: Topic<OnFolderBeforeCreateTopicParams>;
|
|
77
103
|
onFolderAfterCreate: Topic<OnFolderAfterCreateTopicParams>;
|
package/folder/folder.types.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":[],"sources":["folder.types.ts"],"sourcesContent":["import { ListMeta, ListSort, User } from \"~/types\";\nimport { Topic } from \"@webiny/pubsub/types\";\n\nexport interface Folder {\n id: string;\n entryId: string;\n createdOn: string;\n
|
|
1
|
+
{"version":3,"names":[],"sources":["folder.types.ts"],"sourcesContent":["import { ListMeta, ListSort, User } from \"~/types\";\nimport { Topic } from \"@webiny/pubsub/types\";\nimport { FolderPermission } from \"~/utils/FolderLevelPermissions\";\n\nexport interface Folder {\n id: string;\n entryId: string;\n createdOn: string;\n modifiedOn: string | null;\n savedOn: string;\n createdBy: User;\n modifiedBy: User | null;\n savedBy: User;\n title: string;\n slug: string;\n permissions?: FolderPermission[];\n type: string;\n parentId?: string | null;\n}\n\nexport interface ListFoldersWhere {\n type: string;\n parentId?: string | null;\n}\n\nexport interface ListFoldersParams {\n where: ListFoldersWhere;\n sort?: ListSort;\n limit?: number;\n after?: string | null;\n}\n\nexport type ListAllFoldersParams = Omit<ListFoldersParams, \"limit\" | \"after\">;\n\nexport type CreateFolderParams = Pick<Folder, \"title\" | \"slug\" | \"type\" | \"parentId\">;\n\nexport interface UpdateFolderParams {\n title?: string;\n slug?: string;\n permissions?: FolderPermission[];\n parentId?: string;\n}\n\nexport interface DeleteFolderParams {\n id: string;\n}\n\nexport interface FolderLevelPermissionsTarget<TMeta = Record<string, any>> {\n id: string;\n target: string;\n name: string;\n type: string;\n meta: TMeta;\n}\n\nexport interface FolderLevelPermissionsTargetListMeta {\n totalCount: number;\n}\n\nexport interface StorageOperationsGetFolderParams {\n id?: string;\n slug?: string;\n type?: string;\n parentId?: string | null;\n}\n\nexport type StorageOperationsListFoldersParams = ListFoldersParams;\n\nexport interface StorageOperationsCreateFolderParams {\n data: CreateFolderParams;\n}\n\nexport interface StorageOperationsUpdateFolderParams {\n id: string;\n data: UpdateFolderParams;\n}\n\nexport type StorageOperationsDeleteFolderParams = DeleteFolderParams;\n\nexport interface OnFolderBeforeCreateTopicParams {\n input: CreateFolderParams;\n}\n\nexport interface OnFolderAfterCreateTopicParams {\n folder: Folder;\n}\n\nexport interface OnFolderBeforeUpdateTopicParams {\n original: Folder;\n input: Record<string, any>;\n}\n\nexport interface OnFolderAfterUpdateTopicParams {\n original: Folder;\n folder: Folder;\n input: Record<string, any>;\n}\n\nexport interface OnFolderBeforeDeleteTopicParams {\n folder: Folder;\n}\n\nexport interface OnFolderAfterDeleteTopicParams {\n folder: Folder;\n}\n\nexport interface AcoFolderCrud {\n get(id: string): Promise<Folder>;\n\n list(params: ListFoldersParams): Promise<[Folder[], ListMeta]>;\n\n listFolderLevelPermissionsTargets(): Promise<\n [FolderLevelPermissionsTarget[], FolderLevelPermissionsTargetListMeta]\n >;\n\n listAll(params: ListAllFoldersParams): Promise<[Folder[], ListMeta]>;\n\n create(data: CreateFolderParams): Promise<Folder>;\n\n update(id: string, data: UpdateFolderParams): Promise<Folder>;\n\n delete(id: string): Promise<boolean>;\n\n getAncestors(folder: Folder): Promise<Folder[]>;\n\n /**\n * @deprecated use `getAncestors` instead\n */\n getFolderWithAncestors(id: string): Promise<Folder[]>;\n\n onFolderBeforeCreate: Topic<OnFolderBeforeCreateTopicParams>;\n onFolderAfterCreate: Topic<OnFolderAfterCreateTopicParams>;\n onFolderBeforeUpdate: Topic<OnFolderBeforeUpdateTopicParams>;\n onFolderAfterUpdate: Topic<OnFolderAfterUpdateTopicParams>;\n onFolderBeforeDelete: Topic<OnFolderBeforeDeleteTopicParams>;\n onFolderAfterDelete: Topic<OnFolderAfterDeleteTopicParams>;\n}\n\nexport interface AcoFolderStorageOperations {\n getFolder(params: StorageOperationsGetFolderParams): Promise<Folder>;\n\n listFolders(params: StorageOperationsListFoldersParams): Promise<[Folder[], ListMeta]>;\n\n createFolder(params: StorageOperationsCreateFolderParams): Promise<Folder>;\n\n updateFolder(params: StorageOperationsUpdateFolderParams): Promise<Folder>;\n\n deleteFolder(params: StorageOperationsDeleteFolderParams): Promise<boolean>;\n}\n"],"mappings":""}
|