@esri/solution-creator 4.1.0 → 4.1.2-alpha.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,108 @@
1
+ /** @license
2
+ * Copyright 2018 Esri
3
+ *
4
+ * Licensed under the Apache License, Version 2.0 (the "License");
5
+ * you may not use this file except in compliance with the License.
6
+ * You may obtain a copy of the License at
7
+ *
8
+ * http://www.apache.org/licenses/LICENSE-2.0
9
+ *
10
+ * Unless required by applicable law or agreed to in writing, software
11
+ * distributed under the License is distributed on an "AS IS" BASIS,
12
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
+ * See the License for the specific language governing permissions and
14
+ * limitations under the License.
15
+ */
16
+ /**
17
+ * Manages creation of the template of a Solution item via the REST API.
18
+ *
19
+ * @module createItemTemplate
20
+ */
21
+ import { IDatasourceInfo, IItemProgressCallback, IItemTemplate, ISourceFile, UserSession } from "@esri/solution-common";
22
+ /**
23
+ * Creates template for an AGO item and its dependencies
24
+ *
25
+ * @param solutionItemId The solution to contain the item
26
+ * @param itemId AGO id string
27
+ * @param templateDictionary Hash of facts
28
+ * @param srcAuthentication Credentials for requests to source items
29
+ * @param destAuthentication Authentication for requesting information from AGO about items to be included in solution item
30
+ * @param existingTemplates A collection of AGO item templates that can be referenced by newly-created templates
31
+ * @returns A promise which resolves with an array of resources for the item and its dependencies
32
+ * @private
33
+ */
34
+ export declare function createItemTemplate(solutionItemId: string, itemId: string, templateDictionary: any, srcAuthentication: UserSession, destAuthentication: UserSession, existingTemplates: IItemTemplate[], itemProgressCallback: IItemProgressCallback): Promise<ISourceFile[]>;
35
+ /**
36
+ * Templatizes field references within specific template types.
37
+ * Currently only handles web applications
38
+ *
39
+ * @param templates List of solution templates
40
+ * @returns A list of templates that have templatized field references
41
+ */
42
+ export declare function postProcessFieldReferences(templates: IItemTemplate[]): IItemTemplate[];
43
+ /**
44
+ * Get common properties that will support the templatization of field references
45
+ *
46
+ * @param templates List of solution templates
47
+ * @returns A list of IDataSourceInfo objects with key properties
48
+ * @private
49
+ */
50
+ export declare function _getDatasourceInfos(templates: IItemTemplate[]): IDatasourceInfo[];
51
+ /**
52
+ * Creates a simple lookup object to quickly understand an items type and dependencies
53
+ * and associated web map layer ids based on itemId
54
+ *
55
+ * @param templates List of solution templates
56
+ * @returns The lookup object with type, dependencies, and webmap layer info
57
+ * @private
58
+ */
59
+ export declare function _getTemplateTypeHash(templates: IItemTemplate[]): any;
60
+ /**
61
+ * Updates the lookup object with webmap layer info
62
+ * so we can know the id used within a map for a given feature service
63
+ *
64
+ * @param template A webmap solution template
65
+ * @returns The lookup object with webmap layer info added
66
+ * @private
67
+ */
68
+ export declare function _updateWebMapHashInfo(template: IItemTemplate, hashItem: any): void;
69
+ /**
70
+ * Updates a templatized datasource URL with a layer id.
71
+ *
72
+ * @param dataSourceUrl Templatized datasource URL
73
+ * @param layerId Layer id
74
+ * @returns string Amended datasource URL
75
+ * @private
76
+ */
77
+ export declare function _addLayerIdToDatasourceUrl(datasourceUrl?: string, layerId?: any): string;
78
+ /**
79
+ * Updates the datasource info objects by passing the webmap layer IDs from the lookup hash
80
+ * to the underlying feature service datasource infos
81
+ *
82
+ * @param datasourceInfos A webmap solution template
83
+ * @param templateTypeHash A simple lookup object populated with key item info
84
+ * @returns The updated datasource infos
85
+ * @private
86
+ */
87
+ export declare function _addMapLayerIds(datasourceInfos: IDatasourceInfo[], templateTypeHash: any): IDatasourceInfo[];
88
+ /**
89
+ * Get feature service item IDs from applications webmaps
90
+ * As they are not explict dependencies of the application but are needed for field references
91
+ *
92
+ * @param template A webmap solution template
93
+ * @param templateTypeHash A simple lookup object populated with key item info
94
+ * @returns A list of feature service item IDs
95
+ * @private
96
+ */
97
+ export declare function _getWebMapFSDependencies(template: IItemTemplate, templateTypeHash: any): string[];
98
+ /**
99
+ * Perform templatizations needed in an item's resources
100
+ *
101
+ * @param itemTemplate Item being templatized
102
+ * @param resourceItemFiles Resources for the item; these resources are modified as needed
103
+ * by the templatization
104
+ * @param srcAuthentication Credentials for requests to source items
105
+ *
106
+ * @returns A promise that resolves when all templatization has completed
107
+ */
108
+ export declare function _templatizeResources(itemTemplate: IItemTemplate, resourceItemFiles: ISourceFile[], srcAuthentication: UserSession): Promise<void[]>;
@@ -0,0 +1,416 @@
1
+ "use strict";
2
+ /** @license
3
+ * Copyright 2018 Esri
4
+ *
5
+ * Licensed under the Apache License, Version 2.0 (the "License");
6
+ * you may not use this file except in compliance with the License.
7
+ * You may obtain a copy of the License at
8
+ *
9
+ * http://www.apache.org/licenses/LICENSE-2.0
10
+ *
11
+ * Unless required by applicable law or agreed to in writing, software
12
+ * distributed under the License is distributed on an "AS IS" BASIS,
13
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ * See the License for the specific language governing permissions and
15
+ * limitations under the License.
16
+ */
17
+ Object.defineProperty(exports, "__esModule", { value: true });
18
+ exports._templatizeResources = exports._getWebMapFSDependencies = exports._addMapLayerIds = exports._addLayerIdToDatasourceUrl = exports._updateWebMapHashInfo = exports._getTemplateTypeHash = exports._getDatasourceInfos = exports.postProcessFieldReferences = exports.createItemTemplate = void 0;
19
+ /**
20
+ * Manages creation of the template of a Solution item via the REST API.
21
+ *
22
+ * @module createItemTemplate
23
+ */
24
+ const solution_common_1 = require("@esri/solution-common");
25
+ const hub_common_1 = require("@esri/hub-common");
26
+ const module_map_1 = require("./module-map");
27
+ // ------------------------------------------------------------------------------------------------------------------ //
28
+ /**
29
+ * Creates template for an AGO item and its dependencies
30
+ *
31
+ * @param solutionItemId The solution to contain the item
32
+ * @param itemId AGO id string
33
+ * @param templateDictionary Hash of facts
34
+ * @param srcAuthentication Credentials for requests to source items
35
+ * @param destAuthentication Authentication for requesting information from AGO about items to be included in solution item
36
+ * @param existingTemplates A collection of AGO item templates that can be referenced by newly-created templates
37
+ * @returns A promise which resolves with an array of resources for the item and its dependencies
38
+ * @private
39
+ */
40
+ function createItemTemplate(solutionItemId, itemId, templateDictionary, srcAuthentication, destAuthentication, existingTemplates, itemProgressCallback) {
41
+ return new Promise(resolve => {
42
+ // Check if item and its dependents are already in list or are queued
43
+ if ((0, solution_common_1.findTemplateInList)(existingTemplates, itemId)) {
44
+ resolve([]);
45
+ }
46
+ else {
47
+ // Add the id as a placeholder to show that it is being fetched
48
+ existingTemplates.push((0, solution_common_1.createPlaceholderTemplate)(itemId));
49
+ itemProgressCallback(itemId, solution_common_1.EItemProgressStatus.Started, 0);
50
+ // Fetch the item
51
+ (0, solution_common_1.getItemBase)(itemId, srcAuthentication)
52
+ .catch(() => {
53
+ // If item query fails, try fetching item as a group
54
+ // Change its placeholder from an empty type to the Group type so that we can later distinguish
55
+ // between items and groups (the base info for a group doesn't include a type property)
56
+ (0, solution_common_1.replaceTemplate)(existingTemplates, itemId, (0, solution_common_1.createPlaceholderTemplate)(itemId, "Group"));
57
+ return (0, solution_common_1.getGroupBase)(itemId, srcAuthentication);
58
+ })
59
+ .then(itemInfo => {
60
+ itemInfo = (0, solution_common_1.sanitizeJSONAndReportChanges)(itemInfo);
61
+ // Save the URL as a symbol
62
+ if (itemInfo.url) {
63
+ templateDictionary[itemInfo.url] = "{{" + itemInfo.id + ".url}}";
64
+ itemInfo.origUrl = itemInfo.url;
65
+ }
66
+ const idTest = /^source-[0-9A-F]{32}/i;
67
+ // Remove any source-itemId type keywords
68
+ /* istanbul ignore else */
69
+ if (Array.isArray(itemInfo.typeKeywords)) {
70
+ itemInfo.typeKeywords = itemInfo.typeKeywords.filter(v => idTest.test(v) ? false : true);
71
+ }
72
+ // Remove any source-itemId tags
73
+ /* istanbul ignore else */
74
+ if (Array.isArray(itemInfo.tags)) {
75
+ itemInfo.tags = itemInfo.tags.filter(v => idTest.test(v) ? false : true);
76
+ }
77
+ const placeholder = (0, solution_common_1.findTemplateInList)(existingTemplates, itemId);
78
+ let itemType = placeholder.type;
79
+ if (!itemType) {
80
+ // Groups have this defined when their placeholder is created
81
+ itemType = itemInfo.type;
82
+ placeholder.type = itemType;
83
+ }
84
+ if (!itemInfo.type) {
85
+ itemInfo.type = itemType; // Groups don't have this property, so we'll patch it in
86
+ }
87
+ placeholder.item = {
88
+ ...itemInfo
89
+ };
90
+ // Interrupt process if progress callback returns `false`
91
+ if (!itemProgressCallback(itemId, solution_common_1.EItemProgressStatus.Created, 1)) {
92
+ itemProgressCallback(itemId, solution_common_1.EItemProgressStatus.Cancelled, 1);
93
+ resolve((0, solution_common_1.fail)("Cancelled"));
94
+ return;
95
+ }
96
+ const itemHandler = module_map_1.moduleMap[itemType];
97
+ if (!itemHandler || itemHandler === module_map_1.UNSUPPORTED) {
98
+ if (itemHandler === module_map_1.UNSUPPORTED) {
99
+ itemProgressCallback(itemId, solution_common_1.EItemProgressStatus.Ignored, 1);
100
+ resolve([]);
101
+ }
102
+ else {
103
+ itemProgressCallback(itemId, solution_common_1.EItemProgressStatus.Failed, 1);
104
+ placeholder.properties["failed"] = true;
105
+ (0, solution_common_1.replaceTemplate)(existingTemplates, itemId, placeholder);
106
+ resolve((0, solution_common_1.fail)("The type of AGO item " +
107
+ itemId +
108
+ " ('" +
109
+ itemType +
110
+ "') is not supported at this time"));
111
+ }
112
+ }
113
+ else {
114
+ // Handle original Story Maps with next-gen Story Maps
115
+ /* istanbul ignore else */
116
+ /* Not yet supported
117
+ if (storyMap.isAStoryMap(itemType, itemInfo.url)) {
118
+ itemHandler = storyMap;
119
+ } */
120
+ // Delegate the creation of the item to the handler
121
+ itemHandler
122
+ .convertItemToTemplate(solutionItemId, itemInfo, destAuthentication, srcAuthentication, templateDictionary)
123
+ .then(itemTemplate => {
124
+ // eslint-disable-next-line @typescript-eslint/no-floating-promises
125
+ (0, solution_common_1.getItemResourcesPaths)(itemTemplate, solutionItemId, srcAuthentication, solution_common_1.SolutionTemplateFormatVersion).then((resourceItemFilePaths) => {
126
+ itemTemplate.item.thumbnail = null; // not needed in this property; handled as a resource
127
+ // eslint-disable-next-line @typescript-eslint/no-floating-promises
128
+ (0, solution_common_1.getItemResourcesFilesFromPaths)(resourceItemFilePaths, srcAuthentication).then(async (resourceItemFiles) => {
129
+ await _templatizeResources(itemTemplate, resourceItemFiles, srcAuthentication);
130
+ // update the template's resources
131
+ itemTemplate.resources = itemTemplate.resources.concat(resourceItemFiles.map((file) => file.folder + "/" + file.filename));
132
+ // Set the value keyed by the id to the created template, replacing the placeholder template
133
+ (0, solution_common_1.replaceTemplate)(existingTemplates, itemTemplate.itemId, itemTemplate);
134
+ // Trace item dependencies
135
+ if (itemTemplate.dependencies.length === 0) {
136
+ itemProgressCallback(itemId, solution_common_1.EItemProgressStatus.Finished, 1);
137
+ resolve(resourceItemFiles);
138
+ }
139
+ else {
140
+ // Get its dependencies, asking each to get its dependents via
141
+ // recursive calls to this function
142
+ const dependentDfds = [];
143
+ itemTemplate.dependencies.forEach(dependentId => {
144
+ if (!(0, solution_common_1.findTemplateInList)(existingTemplates, dependentId)) {
145
+ dependentDfds.push(createItemTemplate(solutionItemId, dependentId, templateDictionary, srcAuthentication, destAuthentication, existingTemplates, itemProgressCallback));
146
+ }
147
+ });
148
+ // eslint-disable-next-line @typescript-eslint/no-floating-promises
149
+ Promise.all(dependentDfds).then((dependentResourceItemFiles) => {
150
+ // Templatization of item and its dependencies done
151
+ itemProgressCallback(itemId, solution_common_1.EItemProgressStatus.Finished, 1);
152
+ resourceItemFiles = dependentResourceItemFiles.reduce((accumulator, currentValue) => accumulator.concat(currentValue), resourceItemFiles);
153
+ resolve(resourceItemFiles);
154
+ });
155
+ }
156
+ ;
157
+ });
158
+ });
159
+ }, error => {
160
+ placeholder.properties["error"] = JSON.stringify(error);
161
+ (0, solution_common_1.replaceTemplate)(existingTemplates, itemId, placeholder);
162
+ itemProgressCallback(itemId, solution_common_1.EItemProgressStatus.Failed, 1);
163
+ resolve([]);
164
+ });
165
+ }
166
+ },
167
+ // Id not found or item is not accessible
168
+ () => {
169
+ // mock hasInvalidDesignations so this will be processed at the end
170
+ // as we do with living atlas layers
171
+ const t = (0, solution_common_1.findTemplateInList)(existingTemplates, itemId);
172
+ t.properties.hasInvalidDesignations = true;
173
+ // Skip items that we cannot fetch per issue #859
174
+ // Use finished rather than ignored
175
+ // ignored will cause the template to be removed before we can check for hasInvalidDesignations
176
+ itemProgressCallback(itemId, solution_common_1.EItemProgressStatus.Finished, 0);
177
+ resolve([]);
178
+ });
179
+ }
180
+ });
181
+ }
182
+ exports.createItemTemplate = createItemTemplate;
183
+ /**
184
+ * Templatizes field references within specific template types.
185
+ * Currently only handles web applications
186
+ *
187
+ * @param templates List of solution templates
188
+ * @returns A list of templates that have templatized field references
189
+ */
190
+ function postProcessFieldReferences(templates) {
191
+ const datasourceInfos = _getDatasourceInfos(templates);
192
+ const templateTypeHash = _getTemplateTypeHash(templates);
193
+ return templates.map(template => {
194
+ /* istanbul ignore else */
195
+ if (template.type === "Web Mapping Application" ||
196
+ template.type === "Dashboard" ||
197
+ template.type === "Web Map") {
198
+ const webMapFSDependencies = _getWebMapFSDependencies(template, templateTypeHash);
199
+ const itemHandler = module_map_1.moduleMap[template.item.type];
200
+ /* istanbul ignore else */
201
+ if (itemHandler) {
202
+ const dependencies = webMapFSDependencies.concat(template.dependencies);
203
+ let dependentDatasources = datasourceInfos.filter(ds => {
204
+ if (dependencies.indexOf(ds.itemId) > -1) {
205
+ return ds;
206
+ }
207
+ });
208
+ dependentDatasources = _addMapLayerIds(dependentDatasources, templateTypeHash);
209
+ if (dependentDatasources.length > 0) {
210
+ template = itemHandler.postProcessFieldReferences(template, dependentDatasources, template.item.type);
211
+ }
212
+ }
213
+ }
214
+ return template;
215
+ });
216
+ }
217
+ exports.postProcessFieldReferences = postProcessFieldReferences;
218
+ // ------------------------------------------------------------------------------------------------------------------ //
219
+ /**
220
+ * Get common properties that will support the templatization of field references
221
+ *
222
+ * @param templates List of solution templates
223
+ * @returns A list of IDataSourceInfo objects with key properties
224
+ * @private
225
+ */
226
+ function _getDatasourceInfos(templates) {
227
+ const datasourceInfos = [];
228
+ templates.forEach(t => {
229
+ if (t.type === "Feature Service") {
230
+ const layers = (0, hub_common_1.getProp)(t, "properties.layers") || [];
231
+ const tables = (0, hub_common_1.getProp)(t, "properties.tables") || [];
232
+ const layersAndTables = layers.concat(tables);
233
+ layersAndTables.forEach(obj => {
234
+ /* istanbul ignore else */
235
+ if (!(0, solution_common_1.hasDatasource)(datasourceInfos, t.itemId, obj.id)) {
236
+ datasourceInfos.push({
237
+ itemId: t.itemId,
238
+ layerId: obj.id,
239
+ fields: obj.fields,
240
+ basePath: t.itemId + ".layer" + obj.id + ".fields",
241
+ url: (0, hub_common_1.getProp)(t, "item.url"),
242
+ ids: [],
243
+ relationships: obj.relationships || [],
244
+ adminLayerInfo: obj.adminLayerInfo || {}
245
+ });
246
+ }
247
+ });
248
+ }
249
+ });
250
+ return datasourceInfos;
251
+ }
252
+ exports._getDatasourceInfos = _getDatasourceInfos;
253
+ /**
254
+ * Creates a simple lookup object to quickly understand an items type and dependencies
255
+ * and associated web map layer ids based on itemId
256
+ *
257
+ * @param templates List of solution templates
258
+ * @returns The lookup object with type, dependencies, and webmap layer info
259
+ * @private
260
+ */
261
+ function _getTemplateTypeHash(templates) {
262
+ const templateTypeHash = {};
263
+ templates.forEach(template => {
264
+ templateTypeHash[template.itemId] = {
265
+ type: template.type,
266
+ dependencies: template.dependencies
267
+ };
268
+ if (template.type === "Web Map") {
269
+ _updateWebMapHashInfo(template, templateTypeHash[template.itemId]);
270
+ }
271
+ });
272
+ return templateTypeHash;
273
+ }
274
+ exports._getTemplateTypeHash = _getTemplateTypeHash;
275
+ /**
276
+ * Updates the lookup object with webmap layer info
277
+ * so we can know the id used within a map for a given feature service
278
+ *
279
+ * @param template A webmap solution template
280
+ * @returns The lookup object with webmap layer info added
281
+ * @private
282
+ */
283
+ function _updateWebMapHashInfo(template, hashItem) {
284
+ const operationalLayers = (0, hub_common_1.getProp)(template, "data.operationalLayers") || [];
285
+ const tables = (0, hub_common_1.getProp)(template, "data.tables") || [];
286
+ const layersAndTables = operationalLayers.concat(tables);
287
+ if (layersAndTables && layersAndTables.length > 0) {
288
+ hashItem.layersAndTables = [];
289
+ layersAndTables.forEach(layer => {
290
+ const obj = {};
291
+ let itemId;
292
+ /* istanbul ignore else */
293
+ if (layer.itemId) {
294
+ itemId = layer.itemId;
295
+ }
296
+ /* istanbul ignore else */
297
+ if (itemId) {
298
+ obj[(0, solution_common_1.cleanLayerBasedItemId)(itemId)] = {
299
+ id: layer.id,
300
+ url: layer.url
301
+ };
302
+ hashItem.layersAndTables.push(obj);
303
+ }
304
+ });
305
+ }
306
+ }
307
+ exports._updateWebMapHashInfo = _updateWebMapHashInfo;
308
+ /**
309
+ * Updates a templatized datasource URL with a layer id.
310
+ *
311
+ * @param dataSourceUrl Templatized datasource URL
312
+ * @param layerId Layer id
313
+ * @returns string Amended datasource URL
314
+ * @private
315
+ */
316
+ function _addLayerIdToDatasourceUrl(datasourceUrl, layerId) {
317
+ return datasourceUrl && !isNaN(layerId)
318
+ ? datasourceUrl.replace(/[.]/, ".layer" + layerId + ".")
319
+ : "";
320
+ }
321
+ exports._addLayerIdToDatasourceUrl = _addLayerIdToDatasourceUrl;
322
+ /**
323
+ * Updates the datasource info objects by passing the webmap layer IDs from the lookup hash
324
+ * to the underlying feature service datasource infos
325
+ *
326
+ * @param datasourceInfos A webmap solution template
327
+ * @param templateTypeHash A simple lookup object populated with key item info
328
+ * @returns The updated datasource infos
329
+ * @private
330
+ */
331
+ function _addMapLayerIds(datasourceInfos, templateTypeHash) {
332
+ const webMapIds = Object.keys(templateTypeHash).filter(k => {
333
+ if (templateTypeHash[k].type === "Web Map") {
334
+ return templateTypeHash[k];
335
+ }
336
+ });
337
+ return datasourceInfos.map(ds => {
338
+ webMapIds.forEach(webMapId => {
339
+ templateTypeHash[webMapId].layersAndTables.forEach((opLayer) => {
340
+ const opLayerInfo = opLayer[ds.itemId];
341
+ const url = _addLayerIdToDatasourceUrl(ds.url, ds.layerId);
342
+ if (opLayerInfo &&
343
+ url === opLayerInfo.url &&
344
+ ds.ids.indexOf(opLayerInfo.id) < 0) {
345
+ ds.ids.push(opLayerInfo.id);
346
+ }
347
+ });
348
+ });
349
+ return ds;
350
+ });
351
+ }
352
+ exports._addMapLayerIds = _addMapLayerIds;
353
+ /**
354
+ * Get feature service item IDs from applications webmaps
355
+ * As they are not explict dependencies of the application but are needed for field references
356
+ *
357
+ * @param template A webmap solution template
358
+ * @param templateTypeHash A simple lookup object populated with key item info
359
+ * @returns A list of feature service item IDs
360
+ * @private
361
+ */
362
+ function _getWebMapFSDependencies(template, templateTypeHash) {
363
+ const webMapFSDependencies = [];
364
+ template.dependencies.forEach(dep => {
365
+ const depObj = templateTypeHash[dep];
366
+ if (depObj.type === "Web Map") {
367
+ depObj.dependencies.forEach((depObjDependency) => {
368
+ /* istanbul ignore else */
369
+ if (templateTypeHash[depObjDependency].type === "Feature Service") {
370
+ webMapFSDependencies.push(depObjDependency);
371
+ }
372
+ });
373
+ }
374
+ });
375
+ return webMapFSDependencies;
376
+ }
377
+ exports._getWebMapFSDependencies = _getWebMapFSDependencies;
378
+ /**
379
+ * Perform templatizations needed in an item's resources
380
+ *
381
+ * @param itemTemplate Item being templatized
382
+ * @param resourceItemFiles Resources for the item; these resources are modified as needed
383
+ * by the templatization
384
+ * @param srcAuthentication Credentials for requests to source items
385
+ *
386
+ * @returns A promise that resolves when all templatization has completed
387
+ */
388
+ function _templatizeResources(itemTemplate, resourceItemFiles, srcAuthentication) {
389
+ const synchronizePromises = [];
390
+ if (itemTemplate.type === "Vector Tile Service") {
391
+ // Get the root.json files
392
+ const rootJsonResources = resourceItemFiles.filter(file => file.filename === "root.json");
393
+ const resourcePath = srcAuthentication.portal + "/content/items/" + itemTemplate.itemId;
394
+ const templatizedResourcePath = "{{" + itemTemplate.itemId + ".url}}";
395
+ const replacer = new RegExp(resourcePath, "g");
396
+ // Templatize the paths in the files that reference the source item id
397
+ rootJsonResources.forEach(rootFileResource => {
398
+ synchronizePromises.push(new Promise(resolve => {
399
+ // Read the file
400
+ // eslint-disable-next-line @typescript-eslint/no-floating-promises
401
+ (0, solution_common_1.blobToJson)(rootFileResource.file)
402
+ .then(fileJson => {
403
+ // Templatize by turning JSON into string, replacing paths with template, and re-JSONing
404
+ const updatedFileJson = JSON.parse(JSON.stringify(fileJson)
405
+ .replace(replacer, templatizedResourcePath));
406
+ // Write the changes back into the file
407
+ rootFileResource.file = (0, solution_common_1.jsonToFile)(updatedFileJson, rootFileResource.filename);
408
+ resolve(null);
409
+ });
410
+ }));
411
+ });
412
+ }
413
+ return Promise.all(synchronizePromises);
414
+ }
415
+ exports._templatizeResources = _templatizeResources;
416
+ //# sourceMappingURL=createItemTemplate.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createItemTemplate.js","sourceRoot":"","sources":["../../src/createItemTemplate.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,97 @@
1
+ /** @license
2
+ * Copyright 2018 Esri
3
+ *
4
+ * Licensed under the Apache License, Version 2.0 (the "License");
5
+ * you may not use this file except in compliance with the License.
6
+ * You may obtain a copy of the License at
7
+ *
8
+ * http://www.apache.org/licenses/LICENSE-2.0
9
+ *
10
+ * Unless required by applicable law or agreed to in writing, software
11
+ * distributed under the License is distributed on an "AS IS" BASIS,
12
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
+ * See the License for the specific language governing permissions and
14
+ * limitations under the License.
15
+ */
16
+ /**
17
+ * Manages the creation of a Solution item.
18
+ *
19
+ * @module creator
20
+ */
21
+ import { ICreateSolutionOptions, IGroup, IItem, UserSession } from "@esri/solution-common";
22
+ import { IModel } from "@esri/hub-common";
23
+ /**
24
+ * Creates a solution item.
25
+ *
26
+ * @param sourceId AGO id of group whose contents are to be added to solution or of an item to convert into a solution
27
+ * @param srcAuthentication Credentials for requests to source items
28
+ * @param destAuthentication Credentials for the requests to destination solution
29
+ * @param options Customizations for creating the solution
30
+ * @returns A promise that resolves with the AGO id of the new solution
31
+ */
32
+ export declare function createSolution(sourceId: string, srcAuthentication: UserSession, destAuthentication: UserSession, options?: ICreateSolutionOptions): Promise<string>;
33
+ /**
34
+ * Update the createOptions with the group properties
35
+ *
36
+ * @param createOptions
37
+ * @param sourceInfo
38
+ * @param authentication
39
+ * @param isGroup Boolean to indicate if the files are associated with a group or item
40
+ * @private
41
+ */
42
+ export declare function _applySourceToCreateOptions(createOptions: ICreateSolutionOptions, sourceInfo: IGroup | IItem, srcAuthentication: UserSession, isGroup?: boolean): ICreateSolutionOptions;
43
+ /**
44
+ * Update the createOptions with the thumbnail file
45
+ *
46
+ * @param createOptions
47
+ * @param srcAuthentication
48
+ * @private
49
+ */
50
+ export declare function _addThumbnailFileToCreateOptions(createOptions: ICreateSolutionOptions, srcAuthentication: UserSession): Promise<ICreateSolutionOptions>;
51
+ /**
52
+ * Creates a solution item using a list of AGO item ids.
53
+ *
54
+ * @param options Customizations for creating the solution
55
+ * @param srcAuthentication Credentials for requests to source items
56
+ * @param destAuthentication Credentials for the requests to destination solution
57
+ * @returns A promise that resolves with the AGO id of the new solution; solution item is deleted if its
58
+ * there is a problem updating it
59
+ * @private
60
+ */
61
+ export declare function _createSolutionFromItemIds(options: ICreateSolutionOptions, srcAuthentication: UserSession, destAuthentication: UserSession): Promise<string>;
62
+ /**
63
+ * Creates an empty solution item.
64
+ *
65
+ * @param authentication Credentials for the request
66
+ * @param options Customizations for creating the solution
67
+ * @returns A promise that resolves with the AGO id of the new solution; solution item is deleted if its
68
+ * there is a problem updating its thumbnail
69
+ * @private
70
+ */
71
+ export declare function _createSolutionItem(authentication: UserSession, options?: ICreateSolutionOptions): Promise<string>;
72
+ /**
73
+ * Create the Solution Item model to be used to create
74
+ * the Solution Item itself
75
+ *
76
+ * @param options
77
+ * @private
78
+ */
79
+ export declare function _createSolutionItemModel(options: any): IModel;
80
+ /**
81
+ * Gets the deploy.id and deploy.version tag values.
82
+ *
83
+ * @param tags A list of item tags
84
+ * @returns A list containing the two values found in the tags, or defaulting to a new GUID and "1.0", respectively,
85
+ * as needed
86
+ * @private
87
+ */
88
+ export declare function _getDeploymentProperties(tags: string[]): string[];
89
+ /**
90
+ * Searches for a tag that has the specified prefix and returns the rest of the tag following that prefix.
91
+ *
92
+ * @param desiredTagPrefix Tag prefix to look for
93
+ * @param tags A list of item tags
94
+ * @returns The extracted value of the first matching tag or null if a tag with the specified prefix is not found
95
+ * @private
96
+ */
97
+ export declare function _getDeploymentProperty(desiredTagPrefix: string, tags: string[]): string | null;