cdk-import 0.2.144 → 0.2.145

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/lib/index.d.ts CHANGED
@@ -1,4 +1,5 @@
1
1
  import { DescribeResourceTypeOptions } from './cfn-registry';
2
+ import { DescribeProductAggregateOptions } from './service-catalog';
2
3
  export interface ImportResourceTypeOptions extends DescribeResourceTypeOptions {
3
4
  /**
4
5
  * @default "."
@@ -14,3 +15,25 @@ export interface ImportResourceTypeOptions extends DescribeResourceTypeOptions {
14
15
  * @returns name of the resource type
15
16
  */
16
17
  export declare function importResourceType(resourceName: string, _resourceVersion: string, options: ImportResourceTypeOptions): Promise<string>;
18
+ /**
19
+ * Configure options for importing products into your local workspace
20
+ */
21
+ export interface ImportProductOptions extends DescribeProductAggregateOptions {
22
+ /**
23
+ * The folder in which product constructs (as separate class files) will be output to.
24
+ * @default "./sc-products"
25
+ */
26
+ readonly outdir?: string;
27
+ }
28
+ /**
29
+ * Entry point to import Service Catalog product resource.
30
+ *
31
+ * @returns name of the product version
32
+ */
33
+ export declare function importProduct(options: ImportProductOptions): Promise<string>;
34
+ /**
35
+ * Entry point to import all available Service Catalog product resources with `DEFAULT` parameters.
36
+ *
37
+ * @returns names of the product versions
38
+ */
39
+ export declare function importProducts(options: ImportProductOptions): Promise<string[]>;
package/lib/index.js CHANGED
@@ -23,11 +23,12 @@ var __importStar = (this && this.__importStar) || function (mod) {
23
23
  return result;
24
24
  };
25
25
  Object.defineProperty(exports, "__esModule", { value: true });
26
- exports.importResourceType = void 0;
26
+ exports.importProducts = exports.importProduct = exports.importResourceType = void 0;
27
27
  const fs = __importStar(require("fs"));
28
28
  const path = __importStar(require("path"));
29
29
  const cfn_registry_1 = require("./cfn-registry");
30
30
  const cfn_resource_generator_1 = require("./cfn-resource-generator");
31
+ const service_catalog_1 = require("./service-catalog");
31
32
  /**
32
33
  * Entry point to import CFN resource types
33
34
  *
@@ -48,4 +49,39 @@ async function importResourceType(resourceName, _resourceVersion, options) {
48
49
  }
49
50
  exports.importResourceType = importResourceType;
50
51
  ;
51
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSx1Q0FBeUI7QUFDekIsMkNBQTZCO0FBQzdCLGlEQUFtRjtBQUNuRixxRUFBZ0U7QUFTaEU7Ozs7Ozs7R0FPRztBQUNJLEtBQUssVUFBVSxrQkFBa0IsQ0FBQyxZQUFvQixFQUFFLGdCQUF3QixFQUFFLE9BQWtDOztJQUN6SCxNQUFNLE1BQU0sR0FBRyxNQUFBLE9BQU8sQ0FBQyxNQUFNLG1DQUFJLEdBQUcsQ0FBQztJQUNyQyxNQUFNLElBQUksR0FBRyxNQUFNLElBQUEsbUNBQW9CLEVBQUMsWUFBWSxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBRS9ELE1BQU0sVUFBVSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLE1BQU8sQ0FBQyxDQUFDO0lBRTVDLE1BQU0sR0FBRyxHQUFHLElBQUksNkNBQW9CLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxJQUFJLEVBQUUsVUFBVSxDQUFDLENBQUM7SUFFdEUsRUFBRSxDQUFDLFNBQVMsQ0FBQyxNQUFNLEVBQUUsRUFBRSxTQUFTLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUUxQyxFQUFFLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLFVBQVUsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDO0lBRTlELE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQztBQUN2QixDQUFDO0FBYkQsZ0RBYUM7QUFBQSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgZnMgZnJvbSAnZnMnO1xuaW1wb3J0ICogYXMgcGF0aCBmcm9tICdwYXRoJztcbmltcG9ydCB7IGRlc2NyaWJlUmVzb3VyY2VUeXBlLCBEZXNjcmliZVJlc291cmNlVHlwZU9wdGlvbnMgfSBmcm9tICcuL2Nmbi1yZWdpc3RyeSc7XG5pbXBvcnQgeyBDZm5SZXNvdXJjZUdlbmVyYXRvciB9IGZyb20gJy4vY2ZuLXJlc291cmNlLWdlbmVyYXRvcic7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSW1wb3J0UmVzb3VyY2VUeXBlT3B0aW9ucyBleHRlbmRzIERlc2NyaWJlUmVzb3VyY2VUeXBlT3B0aW9ucyB7XG4gIC8qKlxuICAgKiBAZGVmYXVsdCBcIi5cIlxuICAgKi9cbiAgcmVhZG9ubHkgb3V0ZGlyPzogc3RyaW5nO1xufVxuXG4vKipcbiAqIEVudHJ5IHBvaW50IHRvIGltcG9ydCBDRk4gcmVzb3VyY2UgdHlwZXNcbiAqXG4gKiBAcGFyYW0gcmVzb3VyY2VOYW1lIHRoZSBuYW1lIG9yIEFSTiBvZiB0aGUgcmVzb3VyY2UgdHlwZVxuICogQHBhcmFtIF9yZXNvdXJjZVZlcnNpb24gdGhlIHZlcnNpb24gb2YgdGhlIHJlc291cmNlIHR5cGUgKGlnbm9yZWQgZm9yIG5vdylcbiAqIEBwYXJhbSBvdXRkaXIgdGhlIG91dCBmb2xkZXIgdG8gdXNlIChkZWZhdWx0cyB0byB0aGUgY3VycmVudCBkaXJlY3RvcnkpXG4gKiBAcmV0dXJucyBuYW1lIG9mIHRoZSByZXNvdXJjZSB0eXBlXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBpbXBvcnRSZXNvdXJjZVR5cGUocmVzb3VyY2VOYW1lOiBzdHJpbmcsIF9yZXNvdXJjZVZlcnNpb246IHN0cmluZywgb3B0aW9uczogSW1wb3J0UmVzb3VyY2VUeXBlT3B0aW9ucyk6IFByb21pc2U8c3RyaW5nPiB7XG4gIGNvbnN0IG91dGRpciA9IG9wdGlvbnMub3V0ZGlyID8/ICcuJztcbiAgY29uc3QgdHlwZSA9IGF3YWl0IGRlc2NyaWJlUmVzb3VyY2VUeXBlKHJlc291cmNlTmFtZSwgb3B0aW9ucyk7XG5cbiAgY29uc3QgdHlwZVNjaGVtYSA9IEpTT04ucGFyc2UodHlwZS5TY2hlbWEhKTtcblxuICBjb25zdCBnZW4gPSBuZXcgQ2ZuUmVzb3VyY2VHZW5lcmF0b3IodHlwZS5UeXBlTmFtZSwgdHlwZSwgdHlwZVNjaGVtYSk7XG5cbiAgZnMubWtkaXJTeW5jKG91dGRpciwgeyByZWN1cnNpdmU6IHRydWUgfSk7XG5cbiAgZnMud3JpdGVGaWxlU3luYyhwYXRoLmpvaW4ob3V0ZGlyLCAnaW5kZXgudHMnKSwgZ2VuLnJlbmRlcigpKTtcblxuICByZXR1cm4gdHlwZS5UeXBlTmFtZTtcbn07XG4iXX0=
52
+ /**
53
+ * Entry point to import Service Catalog product resource.
54
+ *
55
+ * @returns name of the product version
56
+ */
57
+ async function importProduct(options) {
58
+ var _a;
59
+ const outdir = (_a = options.outdir) !== null && _a !== void 0 ? _a : '.';
60
+ await (0, service_catalog_1.describeProductAggregate)(options);
61
+ //TODO CodeGen
62
+ return outdir; //just for typechecking
63
+ }
64
+ exports.importProduct = importProduct;
65
+ ;
66
+ /**
67
+ * Entry point to import all available Service Catalog product resources with `DEFAULT` parameters.
68
+ *
69
+ * @returns names of the product versions
70
+ */
71
+ async function importProducts(options) {
72
+ var _a;
73
+ const outdir = (_a = options.outdir) !== null && _a !== void 0 ? _a : '.';
74
+ let productVersions = [];
75
+ const availableProducts = await (0, service_catalog_1.fetchAvailableProducts)();
76
+ await Promise.all(availableProducts.map(async (product) => {
77
+ const productVersion = await importProduct({
78
+ outdir: outdir,
79
+ productId: product.Id,
80
+ });
81
+ productVersions.push(productVersion);
82
+ }));
83
+ return productVersions;
84
+ }
85
+ exports.importProducts = importProducts;
86
+ ;
87
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSx1Q0FBeUI7QUFDekIsMkNBQTZCO0FBQzdCLGlEQUFtRjtBQUNuRixxRUFBZ0U7QUFDaEUsdURBQXNIO0FBU3RIOzs7Ozs7O0dBT0c7QUFDSSxLQUFLLFVBQVUsa0JBQWtCLENBQUMsWUFBb0IsRUFBRSxnQkFBd0IsRUFBRSxPQUFrQzs7SUFDekgsTUFBTSxNQUFNLEdBQUcsTUFBQSxPQUFPLENBQUMsTUFBTSxtQ0FBSSxHQUFHLENBQUM7SUFDckMsTUFBTSxJQUFJLEdBQUcsTUFBTSxJQUFBLG1DQUFvQixFQUFDLFlBQVksRUFBRSxPQUFPLENBQUMsQ0FBQztJQUUvRCxNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxNQUFPLENBQUMsQ0FBQztJQUU1QyxNQUFNLEdBQUcsR0FBRyxJQUFJLDZDQUFvQixDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsSUFBSSxFQUFFLFVBQVUsQ0FBQyxDQUFDO0lBRXRFLEVBQUUsQ0FBQyxTQUFTLENBQUMsTUFBTSxFQUFFLEVBQUUsU0FBUyxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7SUFFMUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxVQUFVLENBQUMsRUFBRSxHQUFHLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQztJQUU5RCxPQUFPLElBQUksQ0FBQyxRQUFRLENBQUM7QUFDdkIsQ0FBQztBQWJELGdEQWFDO0FBQUEsQ0FBQztBQWFGOzs7O0dBSUc7QUFDSSxLQUFLLFVBQVUsYUFBYSxDQUFDLE9BQTZCOztJQUMvRCxNQUFNLE1BQU0sR0FBRyxNQUFBLE9BQU8sQ0FBQyxNQUFNLG1DQUFJLEdBQUcsQ0FBQztJQUVyQyxNQUFNLElBQUEsMENBQXdCLEVBQUMsT0FBTyxDQUFDLENBQUM7SUFFeEMsY0FBYztJQUVkLE9BQU8sTUFBTSxDQUFDLENBQUMsdUJBQXVCO0FBQ3hDLENBQUM7QUFSRCxzQ0FRQztBQUFBLENBQUM7QUFFRjs7OztHQUlHO0FBQ0ksS0FBSyxVQUFVLGNBQWMsQ0FBQyxPQUE2Qjs7SUFDaEUsTUFBTSxNQUFNLEdBQUcsTUFBQSxPQUFPLENBQUMsTUFBTSxtQ0FBSSxHQUFHLENBQUM7SUFDckMsSUFBSSxlQUFlLEdBQWEsRUFBRSxDQUFDO0lBRW5DLE1BQU0saUJBQWlCLEdBQUcsTUFBTSxJQUFBLHdDQUFzQixHQUFFLENBQUM7SUFFekQsTUFBTSxPQUFPLENBQUMsR0FBRyxDQUFDLGlCQUFpQixDQUFDLEdBQUcsQ0FBQyxLQUFLLEVBQUUsT0FBTyxFQUFFLEVBQUU7UUFDeEQsTUFBTSxjQUFjLEdBQUcsTUFBTSxhQUFhLENBQUU7WUFDMUMsTUFBTSxFQUFFLE1BQU07WUFDZCxTQUFTLEVBQUUsT0FBTyxDQUFDLEVBQUc7U0FDdkIsQ0FBQyxDQUFDO1FBQ0gsZUFBZSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQztJQUN2QyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBRUosT0FBTyxlQUFlLENBQUM7QUFDekIsQ0FBQztBQWZELHdDQWVDO0FBQUEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIGZzIGZyb20gJ2ZzJztcbmltcG9ydCAqIGFzIHBhdGggZnJvbSAncGF0aCc7XG5pbXBvcnQgeyBkZXNjcmliZVJlc291cmNlVHlwZSwgRGVzY3JpYmVSZXNvdXJjZVR5cGVPcHRpb25zIH0gZnJvbSAnLi9jZm4tcmVnaXN0cnknO1xuaW1wb3J0IHsgQ2ZuUmVzb3VyY2VHZW5lcmF0b3IgfSBmcm9tICcuL2Nmbi1yZXNvdXJjZS1nZW5lcmF0b3InO1xuaW1wb3J0IHsgZGVzY3JpYmVQcm9kdWN0QWdncmVnYXRlLCBEZXNjcmliZVByb2R1Y3RBZ2dyZWdhdGVPcHRpb25zLCBmZXRjaEF2YWlsYWJsZVByb2R1Y3RzIH0gZnJvbSAnLi9zZXJ2aWNlLWNhdGFsb2cnO1xuXG5leHBvcnQgaW50ZXJmYWNlIEltcG9ydFJlc291cmNlVHlwZU9wdGlvbnMgZXh0ZW5kcyBEZXNjcmliZVJlc291cmNlVHlwZU9wdGlvbnMge1xuICAvKipcbiAgICogQGRlZmF1bHQgXCIuXCJcbiAgICovXG4gIHJlYWRvbmx5IG91dGRpcj86IHN0cmluZztcbn1cblxuLyoqXG4gKiBFbnRyeSBwb2ludCB0byBpbXBvcnQgQ0ZOIHJlc291cmNlIHR5cGVzXG4gKlxuICogQHBhcmFtIHJlc291cmNlTmFtZSB0aGUgbmFtZSBvciBBUk4gb2YgdGhlIHJlc291cmNlIHR5cGVcbiAqIEBwYXJhbSBfcmVzb3VyY2VWZXJzaW9uIHRoZSB2ZXJzaW9uIG9mIHRoZSByZXNvdXJjZSB0eXBlIChpZ25vcmVkIGZvciBub3cpXG4gKiBAcGFyYW0gb3V0ZGlyIHRoZSBvdXQgZm9sZGVyIHRvIHVzZSAoZGVmYXVsdHMgdG8gdGhlIGN1cnJlbnQgZGlyZWN0b3J5KVxuICogQHJldHVybnMgbmFtZSBvZiB0aGUgcmVzb3VyY2UgdHlwZVxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gaW1wb3J0UmVzb3VyY2VUeXBlKHJlc291cmNlTmFtZTogc3RyaW5nLCBfcmVzb3VyY2VWZXJzaW9uOiBzdHJpbmcsIG9wdGlvbnM6IEltcG9ydFJlc291cmNlVHlwZU9wdGlvbnMpOiBQcm9taXNlPHN0cmluZz4ge1xuICBjb25zdCBvdXRkaXIgPSBvcHRpb25zLm91dGRpciA/PyAnLic7XG4gIGNvbnN0IHR5cGUgPSBhd2FpdCBkZXNjcmliZVJlc291cmNlVHlwZShyZXNvdXJjZU5hbWUsIG9wdGlvbnMpO1xuXG4gIGNvbnN0IHR5cGVTY2hlbWEgPSBKU09OLnBhcnNlKHR5cGUuU2NoZW1hISk7XG5cbiAgY29uc3QgZ2VuID0gbmV3IENmblJlc291cmNlR2VuZXJhdG9yKHR5cGUuVHlwZU5hbWUsIHR5cGUsIHR5cGVTY2hlbWEpO1xuXG4gIGZzLm1rZGlyU3luYyhvdXRkaXIsIHsgcmVjdXJzaXZlOiB0cnVlIH0pO1xuXG4gIGZzLndyaXRlRmlsZVN5bmMocGF0aC5qb2luKG91dGRpciwgJ2luZGV4LnRzJyksIGdlbi5yZW5kZXIoKSk7XG5cbiAgcmV0dXJuIHR5cGUuVHlwZU5hbWU7XG59O1xuXG4vKipcbiAqIENvbmZpZ3VyZSBvcHRpb25zIGZvciBpbXBvcnRpbmcgcHJvZHVjdHMgaW50byB5b3VyIGxvY2FsIHdvcmtzcGFjZVxuICovXG5leHBvcnQgaW50ZXJmYWNlIEltcG9ydFByb2R1Y3RPcHRpb25zIGV4dGVuZHMgRGVzY3JpYmVQcm9kdWN0QWdncmVnYXRlT3B0aW9ucyB7XG4gIC8qKlxuICAgKiBUaGUgZm9sZGVyIGluIHdoaWNoIHByb2R1Y3QgY29uc3RydWN0cyAoYXMgc2VwYXJhdGUgY2xhc3MgZmlsZXMpIHdpbGwgYmUgb3V0cHV0IHRvLlxuICAgKiBAZGVmYXVsdCBcIi4vc2MtcHJvZHVjdHNcIlxuICAgKi9cbiAgcmVhZG9ubHkgb3V0ZGlyPzogc3RyaW5nO1xufVxuXG4vKipcbiAqIEVudHJ5IHBvaW50IHRvIGltcG9ydCBTZXJ2aWNlIENhdGFsb2cgcHJvZHVjdCByZXNvdXJjZS5cbiAqXG4gKiBAcmV0dXJucyBuYW1lIG9mIHRoZSBwcm9kdWN0IHZlcnNpb25cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGltcG9ydFByb2R1Y3Qob3B0aW9uczogSW1wb3J0UHJvZHVjdE9wdGlvbnMpOiBQcm9taXNlPHN0cmluZz4ge1xuICBjb25zdCBvdXRkaXIgPSBvcHRpb25zLm91dGRpciA/PyAnLic7XG5cbiAgYXdhaXQgZGVzY3JpYmVQcm9kdWN0QWdncmVnYXRlKG9wdGlvbnMpO1xuXG4gIC8vVE9ETyBDb2RlR2VuXG5cbiAgcmV0dXJuIG91dGRpcjsgLy9qdXN0IGZvciB0eXBlY2hlY2tpbmdcbn07XG5cbi8qKlxuICogRW50cnkgcG9pbnQgdG8gaW1wb3J0IGFsbCBhdmFpbGFibGUgU2VydmljZSBDYXRhbG9nIHByb2R1Y3QgcmVzb3VyY2VzIHdpdGggYERFRkFVTFRgIHBhcmFtZXRlcnMuXG4gKlxuICogQHJldHVybnMgbmFtZXMgb2YgdGhlIHByb2R1Y3QgdmVyc2lvbnNcbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGltcG9ydFByb2R1Y3RzKG9wdGlvbnM6IEltcG9ydFByb2R1Y3RPcHRpb25zKTogUHJvbWlzZTxzdHJpbmdbXT4ge1xuICBjb25zdCBvdXRkaXIgPSBvcHRpb25zLm91dGRpciA/PyAnLic7XG4gIGxldCBwcm9kdWN0VmVyc2lvbnM6IHN0cmluZ1tdID0gW107XG5cbiAgY29uc3QgYXZhaWxhYmxlUHJvZHVjdHMgPSBhd2FpdCBmZXRjaEF2YWlsYWJsZVByb2R1Y3RzKCk7XG5cbiAgYXdhaXQgUHJvbWlzZS5hbGwoYXZhaWxhYmxlUHJvZHVjdHMubWFwKGFzeW5jIChwcm9kdWN0KSA9PiB7XG4gICAgY29uc3QgcHJvZHVjdFZlcnNpb24gPSBhd2FpdCBpbXBvcnRQcm9kdWN0KCB7XG4gICAgICBvdXRkaXI6IG91dGRpcixcbiAgICAgIHByb2R1Y3RJZDogcHJvZHVjdC5JZCEsXG4gICAgfSk7XG4gICAgcHJvZHVjdFZlcnNpb25zLnB1c2gocHJvZHVjdFZlcnNpb24pO1xuICB9KSk7XG5cbiAgcmV0dXJuIHByb2R1Y3RWZXJzaW9ucztcbn07XG4iXX0=
@@ -1,32 +1,32 @@
1
1
  import * as AWS from 'aws-sdk';
2
2
  export interface IServiceCatalogClient {
3
3
  searchProducts(input: AWS.ServiceCatalog.ListPortfoliosInput): Promise<AWS.ServiceCatalog.ListPortfoliosOutput>;
4
- listProvisioningArtifacts(input: AWS.ServiceCatalog.ListProvisioningArtifactsInput): Promise<AWS.ServiceCatalog.ListProvisioningArtifactsOutput>;
5
- listLaunchPaths(input: AWS.ServiceCatalog.ListLaunchPathsInput): Promise<AWS.ServiceCatalog.ListLaunchPathsOutput>;
6
4
  describeProvisioningParameters(input: AWS.ServiceCatalog.DescribeProvisioningParametersInput): Promise<AWS.ServiceCatalog.DescribeProvisioningParametersOutput>;
5
+ describeProduct(input: AWS.ServiceCatalog.DescribeProductInput): Promise<AWS.ServiceCatalog.DescribeProductOutput>;
7
6
  }
8
7
  export declare class ServiceCatalogClient implements IServiceCatalogClient {
9
8
  private readonly sc;
10
9
  constructor();
11
10
  searchProducts(input: AWS.ServiceCatalog.SearchProductsInput): Promise<AWS.ServiceCatalog.SearchProductsOutput>;
12
- listProvisioningArtifacts(input: AWS.ServiceCatalog.ListProvisioningArtifactsInput): Promise<AWS.ServiceCatalog.ListProvisioningArtifactsOutput>;
13
- listLaunchPaths(input: AWS.ServiceCatalog.ListLaunchPathsInput): Promise<AWS.ServiceCatalog.ListLaunchPathsOutput>;
14
11
  describeProvisioningParameters(input: AWS.ServiceCatalog.DescribeProvisioningParametersInput): Promise<AWS.ServiceCatalog.DescribeProvisioningParametersOutput>;
12
+ describeProduct(input: AWS.ServiceCatalog.DescribeProductInput): Promise<AWS.ServiceCatalog.DescribeProductOutput>;
15
13
  }
16
14
  /**
17
15
  * Provide query values for a specific provisionable product.
18
- * If no specific IDs are declared for a product, we will use the set DEFAULT value for the provisioning artifact and launch path.
16
+ * If no specific IDs are declared for a product, we will use the set `DEFAULT` value for the provisioning artifact and launch path.
19
17
  */
20
- export interface DescribeProvisionedProductOptions {
18
+ export interface DescribeProductAggregateOptions {
21
19
  /**
22
20
  * A client that performs calls to AWS Service Catalog. You can provide a mock here
23
21
  * for testing.
22
+ *
23
+ * @default - A real Service Catalog client
24
24
  */
25
25
  readonly client?: IServiceCatalogClient;
26
26
  /**
27
- * The product Id..
27
+ * The product Id.
28
28
  */
29
- readonly productId?: string;
29
+ readonly productId: string;
30
30
  /**
31
31
  * The provisioning artifact Id.
32
32
  */
@@ -37,32 +37,46 @@ export interface DescribeProvisionedProductOptions {
37
37
  readonly launchPathId?: string;
38
38
  }
39
39
  /**
40
- * Fetches the all the available or queried service catalog product(s) for the caller.
40
+ * Fetches all the available service catalog product(s) for the caller.
41
41
  *
42
42
  * @returns list of product view summaries
43
43
  */
44
- export declare function fetchAvailableProducts(options?: DescribeProvisionedProductOptions): Promise<AWS.ServiceCatalog.ProductViewSummaries>;
44
+ export declare function fetchAvailableProducts(client?: IServiceCatalogClient): Promise<AWS.ServiceCatalog.ProductViewSummaries>;
45
45
  /**
46
- * Fetches the all the available or queried provisioning artifact(s) for the caller.
46
+ * Gets the information required to provision an artifact.
47
+ * Includes information on inputs and outputs of the product.
47
48
  *
48
- * @param productId the product to fetch provisioning artifacts for
49
- * @returns list of provisioning artifact details for a product
49
+ * @returns the provisoning parameters for an artifact
50
50
  */
51
- export declare function listProvisioningArtifacts(productId: string, options?: DescribeProvisionedProductOptions): Promise<AWS.ServiceCatalog.ProvisioningArtifactDetail[]>;
51
+ export declare function describeProvisioningParameters(options: DescribeProductAggregateOptions): Promise<AWS.ServiceCatalog.DescribeProvisioningParametersOutput>;
52
52
  /**
53
- * Retrieves all the availalbe or queried launch path(s) for a product.
54
- *
55
- * @param productId the product to list launch paths for
56
- * @returns list of launchPathSummaries for a product
53
+ * Holds all the information needed to generate a product artifact to provision.
57
54
  */
58
- export declare function listLaunchPaths(productId: string, options?: DescribeProvisionedProductOptions): Promise<AWS.ServiceCatalog.LaunchPathSummaries>;
55
+ export interface ProductDataAggregate {
56
+ /**
57
+ * Core product details.
58
+ */
59
+ readonly product: AWS.ServiceCatalog.ProductViewSummary;
60
+ /**
61
+ * Details on the selected provisioning artifact for the product.
62
+ * Represents the actual template that contains resources.
63
+ */
64
+ readonly provisioningArtifact: AWS.ServiceCatalog.ProvisioningArtifact;
65
+ /**
66
+ * Details on the selected launch path for the product.
67
+ * Represents the permissions/ability for end user to provision the product.
68
+ */
69
+ readonly launchPath: AWS.ServiceCatalog.LaunchPathSummary;
70
+ /**
71
+ * Details on provisioning requirements for the provisioning artifact and launch path.
72
+ * Holds information on the inputs and outputs for the downstream template.
73
+ */
74
+ readonly params: AWS.ServiceCatalog.DescribeProvisioningParametersOutput;
75
+ }
59
76
  /**
60
- * Gets the information required to provision an artifact.
61
- * Includes information on inputs and outputs of the product.
77
+ * Makes a series of calls to service catalog to get all information
78
+ * required to provision a service catalog product.
62
79
  *
63
- * @param productId the product to get provisioning parameters for
64
- * @param provisioningArtifactId the provisioning artifact to get provisioning parameters for
65
- * @param launchPathId the launch path to get provisioning parameters for
66
- * @returns the provisoning parameters for an artifact
80
+ * @returns ProductVersionData aggregate of provisioning artifact details.
67
81
  */
68
- export declare function describeProvisioningParameters(productId: string, provisioningArtifactId: string, launchPathId: string, options?: DescribeProvisionedProductOptions): Promise<AWS.ServiceCatalog.DescribeProvisioningParametersOutput>;
82
+ export declare function describeProductAggregate(options: DescribeProductAggregateOptions): Promise<ProductDataAggregate>;
@@ -23,7 +23,7 @@ var __importStar = (this && this.__importStar) || function (mod) {
23
23
  return result;
24
24
  };
25
25
  Object.defineProperty(exports, "__esModule", { value: true });
26
- exports.describeProvisioningParameters = exports.listLaunchPaths = exports.listProvisioningArtifacts = exports.fetchAvailableProducts = exports.ServiceCatalogClient = void 0;
26
+ exports.describeProductAggregate = exports.describeProvisioningParameters = exports.fetchAvailableProducts = exports.ServiceCatalogClient = void 0;
27
27
  const AWS = __importStar(require("aws-sdk"));
28
28
  const aws_1 = require("./aws");
29
29
  class ServiceCatalogClient {
@@ -33,107 +33,157 @@ class ServiceCatalogClient {
33
33
  async searchProducts(input) {
34
34
  return this.sc.searchProducts(input).promise();
35
35
  }
36
- async listProvisioningArtifacts(input) {
37
- return this.sc.listProvisioningArtifacts(input).promise();
38
- }
39
- async listLaunchPaths(input) {
40
- return this.sc.listLaunchPaths(input).promise();
41
- }
42
36
  async describeProvisioningParameters(input) {
43
37
  return this.sc.describeProvisioningParameters(input).promise();
44
38
  }
39
+ async describeProduct(input) {
40
+ return this.sc.describeProduct(input).promise();
41
+ }
45
42
  }
46
43
  exports.ServiceCatalogClient = ServiceCatalogClient;
47
44
  /**
48
- * Fetches the all the available or queried service catalog product(s) for the caller.
45
+ * Returns the provisioning artifact from list of available artifacts.
46
+ * If no query artifact Id is provided, the artifact marked `DEFAULT` will be returned.
47
+ * If no `DEFAULT` artifact exists, the most recently created artifact will be returned.
49
48
  *
50
- * @returns list of product view summaries
49
+ * @param provisioningArtifacts list of provisioning artifacts for a product
50
+ * @param provisioningArtifactId query artifact Id
51
+ * @returns provisioning artifact detail
51
52
  */
52
- async function fetchAvailableProducts(options = {}) {
53
- var _a;
54
- const sc = (_a = options.client) !== null && _a !== void 0 ? _a : new ServiceCatalogClient();
55
- const products = [];
56
- let token;
57
- do {
58
- const res = await sc.searchProducts({
59
- PageToken: token,
60
- ...(options.productId ? { SourceProductId: options.productId } : {}),
61
- });
62
- if (res.ProductViewSummaries) {
63
- products.push(...res.ProductViewSummaries);
53
+ function resolveProvisioningArtifact(provisioningArtifacts, provisioningArtifactId) {
54
+ if (provisioningArtifactId) {
55
+ const provisioningArtifact = provisioningArtifacts.filter(pa => pa.Id == provisioningArtifactId);
56
+ if (provisioningArtifact.length == 0) {
57
+ throw new Error(`Could not find specified provisioning artifact id: ${provisioningArtifactId}`);
64
58
  }
65
- token = res.NextPageToken;
66
- } while (token);
67
- return products;
59
+ else {
60
+ return provisioningArtifact.pop();
61
+ }
62
+ }
63
+ else {
64
+ try {
65
+ if (provisioningArtifacts.filter(pa => pa.Guidance == 'DEFAULT').length == 1) {
66
+ return provisioningArtifacts.filter(pa => pa.Guidance == 'DEFAULT').pop();
67
+ }
68
+ else {
69
+ return provisioningArtifacts.sort((a, b) => a.CreatedTime.valueOf() - b.CreatedTime.valueOf()).pop();
70
+ }
71
+ }
72
+ catch {
73
+ throw new Error('Unable to resolve default or latest provisioning artifact.');
74
+ }
75
+ }
68
76
  }
69
- exports.fetchAvailableProducts = fetchAvailableProducts;
70
77
  /**
71
- * Fetches the all the available or queried provisioning artifact(s) for the caller.
72
- *
73
- * @param productId the product to fetch provisioning artifacts for
74
- * @returns list of provisioning artifact details for a product
78
+ * Returns the queried launch path from list of available launch paths.
79
+ * @param launchPaths list of available launch paths for the product
80
+ * @param launchPathId the query launch path's Id
81
+ * @returns the launch path summary for the query launch path
75
82
  */
76
- async function listProvisioningArtifacts(productId, options = {}) {
77
- var _a;
78
- const sc = (_a = options.client) !== null && _a !== void 0 ? _a : new ServiceCatalogClient();
79
- const provisioningArtifacts = await sc.listProvisioningArtifacts({
80
- ProductId: productId,
81
- });
82
- if (options.provisioningArtifactId != null) {
83
- return provisioningArtifacts.ProvisioningArtifactDetails.filter(pa => pa.Id == options.provisioningArtifactId);
83
+ function resolveLaunchPath(launchPaths, launchPathId) {
84
+ if (launchPathId) {
85
+ const launchPath = launchPaths.filter(lp => lp.Id == launchPathId);
86
+ if (launchPath.length == 0) {
87
+ throw new Error(`Could not find specified launch path id: ${launchPathId}`);
88
+ }
89
+ else {
90
+ return launchPath.pop();
91
+ }
92
+ }
93
+ else if (launchPaths.length == 1) {
94
+ return launchPaths.pop();
84
95
  }
85
96
  else {
86
- return provisioningArtifacts.ProvisioningArtifactDetails;
97
+ throw new Error('Unable to resolve between multiple launch paths.');
87
98
  }
88
99
  }
89
- exports.listProvisioningArtifacts = listProvisioningArtifacts;
90
100
  /**
91
- * Retrieves all the availalbe or queried launch path(s) for a product.
101
+ * Fetches the all the available or queried service catalog product(s) for the caller.
92
102
  *
93
- * @param productId the product to list launch paths for
94
- * @returns list of launchPathSummaries for a product
103
+ * @returns list of product view summaries
95
104
  */
96
- async function listLaunchPaths(productId, options = {}) {
105
+ async function describeProduct(options) {
97
106
  var _a;
98
107
  const sc = (_a = options.client) !== null && _a !== void 0 ? _a : new ServiceCatalogClient();
99
- const launchPaths = [];
108
+ const describeProductResponse = await sc.describeProduct({
109
+ Id: options.productId,
110
+ });
111
+ validateProductData(options.productId, describeProductResponse);
112
+ const provisioningArtifact = resolveProvisioningArtifact(describeProductResponse.ProvisioningArtifacts, options.provisioningArtifactId);
113
+ const launchPath = resolveLaunchPath(describeProductResponse.LaunchPaths, options.launchPathId);
114
+ const parameters = await describeProvisioningParameters(options);
115
+ return {
116
+ product: describeProductResponse.ProductViewSummary,
117
+ provisioningArtifact: provisioningArtifact,
118
+ launchPath: launchPath,
119
+ params: parameters,
120
+ };
121
+ }
122
+ /**
123
+ * Fetches all the available service catalog product(s) for the caller.
124
+ *
125
+ * @returns list of product view summaries
126
+ */
127
+ async function fetchAvailableProducts(client) {
128
+ const sc = client !== null && client !== void 0 ? client : new ServiceCatalogClient();
129
+ const products = [];
100
130
  let token;
101
131
  do {
102
- const res = await sc.listLaunchPaths({
103
- ProductId: productId,
132
+ const res = await sc.searchProducts({
104
133
  PageToken: token,
105
134
  });
106
- if (res.LaunchPathSummaries) {
107
- launchPaths.push(...res.LaunchPathSummaries);
135
+ if (res.ProductViewSummaries) {
136
+ products.push(...res.ProductViewSummaries);
108
137
  }
109
138
  token = res.NextPageToken;
110
139
  } while (token);
111
- if (options.launchPathId != null) {
112
- return launchPaths.filter(lp => lp.Id == options.launchPathId);
113
- }
114
- else {
115
- return launchPaths;
116
- }
140
+ return products;
117
141
  }
118
- exports.listLaunchPaths = listLaunchPaths;
142
+ exports.fetchAvailableProducts = fetchAvailableProducts;
119
143
  /**
120
144
  * Gets the information required to provision an artifact.
121
145
  * Includes information on inputs and outputs of the product.
122
146
  *
123
- * @param productId the product to get provisioning parameters for
124
- * @param provisioningArtifactId the provisioning artifact to get provisioning parameters for
125
- * @param launchPathId the launch path to get provisioning parameters for
126
147
  * @returns the provisoning parameters for an artifact
127
148
  */
128
- async function describeProvisioningParameters(productId, provisioningArtifactId, launchPathId, options = {}) {
149
+ async function describeProvisioningParameters(options) {
129
150
  var _a;
130
151
  const sc = (_a = options.client) !== null && _a !== void 0 ? _a : new ServiceCatalogClient();
131
152
  const provisioningParameters = await sc.describeProvisioningParameters({
132
- ProductId: productId,
133
- ProvisioningArtifactId: provisioningArtifactId,
134
- PathId: launchPathId,
153
+ ProductId: options.productId,
154
+ ProvisioningArtifactId: options.provisioningArtifactId,
155
+ PathId: options.launchPathId,
135
156
  });
136
157
  return provisioningParameters;
137
158
  }
138
159
  exports.describeProvisioningParameters = describeProvisioningParameters;
139
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"service-catalog.js","sourceRoot":"","sources":["../src/service-catalog.ts"],"names":[],"mappings":"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","sourcesContent":["import * as AWS from 'aws-sdk';\nimport { createAwsClient } from './aws';\n\nexport interface IServiceCatalogClient {\n  searchProducts(input: AWS.ServiceCatalog.ListPortfoliosInput): Promise<AWS.ServiceCatalog.ListPortfoliosOutput>;\n  listProvisioningArtifacts(input: AWS.ServiceCatalog.ListProvisioningArtifactsInput): Promise<AWS.ServiceCatalog.ListProvisioningArtifactsOutput>;\n  listLaunchPaths(input: AWS.ServiceCatalog.ListLaunchPathsInput): Promise<AWS.ServiceCatalog.ListLaunchPathsOutput> ;\n  describeProvisioningParameters(input: AWS.ServiceCatalog.DescribeProvisioningParametersInput):\n  Promise<AWS.ServiceCatalog.DescribeProvisioningParametersOutput>;\n}\n\nexport class ServiceCatalogClient implements IServiceCatalogClient {\n  private readonly sc: AWS.ServiceCatalog;\n\n  constructor() {\n    this.sc = createAwsClient(AWS.ServiceCatalog);\n  }\n\n  public async searchProducts(input: AWS.ServiceCatalog.SearchProductsInput): Promise<AWS.ServiceCatalog.SearchProductsOutput> {\n    return this.sc.searchProducts(input).promise();\n  }\n\n  public async listProvisioningArtifacts(input: AWS.ServiceCatalog.ListProvisioningArtifactsInput):\n  Promise<AWS.ServiceCatalog.ListProvisioningArtifactsOutput> {\n    return this.sc.listProvisioningArtifacts(input).promise();\n  }\n\n  public async listLaunchPaths(input: AWS.ServiceCatalog.ListLaunchPathsInput): Promise<AWS.ServiceCatalog.ListLaunchPathsOutput> {\n    return this.sc.listLaunchPaths(input).promise();\n  }\n\n  public async describeProvisioningParameters(input: AWS.ServiceCatalog.DescribeProvisioningParametersInput):\n  Promise<AWS.ServiceCatalog.DescribeProvisioningParametersOutput> {\n    return this.sc.describeProvisioningParameters(input).promise();\n  }\n}\n\n/**\n * Provide query values for a specific provisionable product.\n * If no specific IDs are declared for a product, we will use the set DEFAULT value for the provisioning artifact and launch path.\n */\nexport interface DescribeProvisionedProductOptions {\n  /**\n   * A client that performs calls to AWS Service Catalog. You can provide a mock here\n   * for testing.\n   */\n  readonly client?: IServiceCatalogClient;\n\n  /**\n   * The product Id..\n   */\n  readonly productId?: string;\n\n  /**\n   * The provisioning artifact Id.\n   */\n  readonly provisioningArtifactId?: string;\n\n  /**\n   * The launch path Id.\n   */\n  readonly launchPathId?: string;\n}\n\n/**\n * Fetches the all the available or queried service catalog product(s) for the caller.\n *\n * @returns list of product view summaries\n */\nexport async function fetchAvailableProducts(options: DescribeProvisionedProductOptions = {}): Promise<AWS.ServiceCatalog.ProductViewSummaries> {\n  const sc = options.client ?? new ServiceCatalogClient();\n\n  const products = [];\n  let token;\n\n  do {\n    const res: AWS.ServiceCatalog.SearchProductsOutput = await sc.searchProducts({\n      PageToken: token,\n      ...(options.productId ? { SourceProductId: options.productId } : {}),\n    });\n\n    if (res.ProductViewSummaries) {\n      products.push(...res.ProductViewSummaries);\n    }\n    token = res.NextPageToken;\n  } while (token);\n\n  return products;\n}\n\n/**\n * Fetches the all the available or queried provisioning artifact(s) for the caller.\n *\n * @param productId the product to fetch provisioning artifacts for\n * @returns list of provisioning artifact details for a product\n */\nexport async function listProvisioningArtifacts(\n  productId: string,\n  options: DescribeProvisionedProductOptions = {}): Promise<AWS.ServiceCatalog.ProvisioningArtifactDetail[]> {\n  const sc = options.client ?? new ServiceCatalogClient();\n\n  const provisioningArtifacts: AWS.ServiceCatalog.ListProvisioningArtifactsOutput = await sc.listProvisioningArtifacts({\n    ProductId: productId,\n  });\n\n  if ( options.provisioningArtifactId != null ) {\n    return provisioningArtifacts.ProvisioningArtifactDetails!.filter(pa => pa.Id == options.provisioningArtifactId);\n  } else {\n    return provisioningArtifacts.ProvisioningArtifactDetails!;\n  }\n}\n\n/**\n * Retrieves all the availalbe or queried launch path(s) for a product.\n *\n * @param productId the product to list launch paths for\n * @returns list of launchPathSummaries for a product\n */\nexport async function listLaunchPaths(\n  productId: string,\n  options: DescribeProvisionedProductOptions = {}):\n  Promise<AWS.ServiceCatalog.LaunchPathSummaries> {\n  const sc = options.client ?? new ServiceCatalogClient();\n\n  const launchPaths = [];\n  let token;\n\n  do {\n    const res: AWS.ServiceCatalog.ListLaunchPathsOutput = await sc.listLaunchPaths({\n      ProductId: productId,\n      PageToken: token,\n    });\n\n    if (res.LaunchPathSummaries) {\n      launchPaths.push(...res.LaunchPathSummaries);\n    }\n    token = res.NextPageToken;\n  } while (token);\n\n  if ( options.launchPathId != null ) {\n    return launchPaths.filter(lp => lp.Id == options.launchPathId);\n  } else {\n    return launchPaths;\n  }\n}\n\n/**\n * Gets the information required to provision an artifact.\n * Includes information on inputs and outputs of the product.\n *\n * @param productId the product to get provisioning parameters for\n * @param provisioningArtifactId the provisioning artifact to get provisioning parameters for\n * @param launchPathId the launch path to get provisioning parameters for\n * @returns the provisoning parameters for an artifact\n */\nexport async function describeProvisioningParameters(productId: string, provisioningArtifactId: string, launchPathId: string,\n  options: DescribeProvisionedProductOptions = {}):\n  Promise<AWS.ServiceCatalog.DescribeProvisioningParametersOutput> {\n\n  const sc = options.client ?? new ServiceCatalogClient();\n\n  const provisioningParameters: AWS.ServiceCatalog.DescribeProvisioningParametersOutput = await sc.describeProvisioningParameters({\n    ProductId: productId,\n    ProvisioningArtifactId: provisioningArtifactId,\n    PathId: launchPathId,\n  });\n\n  return provisioningParameters;\n}"]}
160
+ /**
161
+ * Makes a series of calls to service catalog to get all information
162
+ * required to provision a service catalog product.
163
+ *
164
+ * @returns ProductVersionData aggregate of provisioning artifact details.
165
+ */
166
+ async function describeProductAggregate(options) {
167
+ var _a;
168
+ const sc = (_a = options.client) !== null && _a !== void 0 ? _a : new ServiceCatalogClient();
169
+ const productDataAggregate = await describeProduct({
170
+ productId: options.productId,
171
+ launchPathId: options.launchPathId,
172
+ provisioningArtifactId: options.provisioningArtifactId,
173
+ client: sc,
174
+ });
175
+ return productDataAggregate;
176
+ }
177
+ exports.describeProductAggregate = describeProductAggregate;
178
+ function validateProductData(productId, product) {
179
+ if (product.ProductViewSummary == undefined) {
180
+ throw new Error(`Cannot resolve product details for ${productId}`);
181
+ }
182
+ else if (product.ProvisioningArtifacts == undefined) {
183
+ throw new Error(`Cannot resolve provisioning artifacts for product: ${productId}`);
184
+ }
185
+ else if (product.LaunchPaths == undefined) {
186
+ throw new Error(`Cannot resolve launch paths for product: ${productId}`);
187
+ }
188
+ }
189
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"service-catalog.js","sourceRoot":"","sources":["../src/service-catalog.ts"],"names":[],"mappings":"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","sourcesContent":["import * as AWS from 'aws-sdk';\nimport { createAwsClient } from './aws';\n\nexport interface IServiceCatalogClient {\n  searchProducts(input: AWS.ServiceCatalog.ListPortfoliosInput): Promise<AWS.ServiceCatalog.ListPortfoliosOutput>;\n  describeProvisioningParameters(input: AWS.ServiceCatalog.DescribeProvisioningParametersInput):\n  Promise<AWS.ServiceCatalog.DescribeProvisioningParametersOutput>;\n  describeProduct(input: AWS.ServiceCatalog.DescribeProductInput): Promise<AWS.ServiceCatalog.DescribeProductOutput>;\n}\n\nexport class ServiceCatalogClient implements IServiceCatalogClient {\n  private readonly sc: AWS.ServiceCatalog;\n\n  constructor() {\n    this.sc = createAwsClient(AWS.ServiceCatalog);\n  }\n\n  public async searchProducts(input: AWS.ServiceCatalog.SearchProductsInput): Promise<AWS.ServiceCatalog.SearchProductsOutput> {\n    return this.sc.searchProducts(input).promise();\n  }\n\n  public async describeProvisioningParameters(input: AWS.ServiceCatalog.DescribeProvisioningParametersInput):\n  Promise<AWS.ServiceCatalog.DescribeProvisioningParametersOutput> {\n    return this.sc.describeProvisioningParameters(input).promise();\n  }\n\n  public async describeProduct(input: AWS.ServiceCatalog.DescribeProductInput): Promise<AWS.ServiceCatalog.DescribeProductOutput> {\n    return this.sc.describeProduct(input).promise();\n  }\n}\n\n/**\n * Provide query values for a specific provisionable product.\n * If no specific IDs are declared for a product, we will use the set `DEFAULT` value for the provisioning artifact and launch path.\n */\nexport interface DescribeProductAggregateOptions {\n  /**\n   * A client that performs calls to AWS Service Catalog. You can provide a mock here\n   * for testing.\n   *\n   * @default - A real Service Catalog client\n   */\n  readonly client?: IServiceCatalogClient;\n\n  /**\n   * The product Id.\n   */\n  readonly productId: string;\n\n  /**\n   * The provisioning artifact Id.\n   */\n  readonly provisioningArtifactId?: string;\n\n  /**\n   * The launch path Id.\n   */\n  readonly launchPathId?: string;\n}\n\n/**\n * Returns the provisioning artifact from list of available artifacts.\n * If no query artifact Id is provided, the artifact marked `DEFAULT` will be returned.\n * If no `DEFAULT` artifact exists, the most recently created artifact will be returned.\n *\n * @param provisioningArtifacts list of provisioning artifacts for a product\n * @param provisioningArtifactId query artifact Id\n * @returns provisioning artifact detail\n */\nfunction resolveProvisioningArtifact(provisioningArtifacts: AWS.ServiceCatalog.ProvisioningArtifacts, provisioningArtifactId?: string):\nAWS.ServiceCatalog.ProvisioningArtifact {\n  if (provisioningArtifactId) {\n    const provisioningArtifact = provisioningArtifacts.filter(pa => pa.Id == provisioningArtifactId);\n    if (provisioningArtifact.length == 0) {\n      throw new Error(`Could not find specified provisioning artifact id: ${provisioningArtifactId}`);\n    } else {\n      return provisioningArtifact.pop()!;\n    }\n  } else {\n    try {\n      if (provisioningArtifacts.filter(pa => pa.Guidance == 'DEFAULT').length == 1) {\n        return provisioningArtifacts.filter(pa => pa.Guidance == 'DEFAULT').pop()!;\n      } else {\n        return provisioningArtifacts.sort((a, b) => a.CreatedTime!.valueOf() - b.CreatedTime!.valueOf()).pop()!;\n      }\n    } catch {\n      throw new Error('Unable to resolve default or latest provisioning artifact.');\n    }\n  }\n}\n\n/**\n * Returns the queried launch path from list of available launch paths.\n * @param launchPaths list of available launch paths for the product\n * @param launchPathId the query launch path's Id\n * @returns the launch path summary for the query launch path\n */\nfunction resolveLaunchPath(launchPaths: AWS.ServiceCatalog.LaunchPathSummaries, launchPathId?: string): AWS.ServiceCatalog.LaunchPathSummary {\n  if (launchPathId) {\n    const launchPath = launchPaths.filter(lp => lp.Id == launchPathId);\n    if (launchPath.length == 0 ) {\n      throw new Error(`Could not find specified launch path id: ${launchPathId}`);\n    } else {\n      return launchPath.pop()!;\n    }\n\n  } else if (launchPaths.length == 1) {\n    return launchPaths.pop()!;\n  } else {\n    throw new Error('Unable to resolve between multiple launch paths.');\n  }\n}\n\n/**\n * Fetches the all the available or queried service catalog product(s) for the caller.\n *\n * @returns list of product view summaries\n */\nasync function describeProduct(options: DescribeProductAggregateOptions): Promise<ProductDataAggregate> {\n  const sc: IServiceCatalogClient = options.client ?? new ServiceCatalogClient();\n\n  const describeProductResponse: AWS.ServiceCatalog.DescribeProductOutput = await sc.describeProduct({\n    Id: options.productId,\n  });\n  validateProductData(options.productId, describeProductResponse);\n\n  const provisioningArtifact: AWS.ServiceCatalog.ProvisioningArtifact = resolveProvisioningArtifact(describeProductResponse.ProvisioningArtifacts!,\n    options.provisioningArtifactId);\n\n  const launchPath: AWS.ServiceCatalog.LaunchPathSummary = resolveLaunchPath(describeProductResponse.LaunchPaths!, options.launchPathId);\n\n  const parameters: AWS.ServiceCatalog.DescribeProvisioningParametersOutput = await describeProvisioningParameters(options);\n\n  return {\n    product: describeProductResponse.ProductViewSummary!,\n    provisioningArtifact: provisioningArtifact,\n    launchPath: launchPath,\n    params: parameters,\n  };\n}\n\n/**\n * Fetches all the available service catalog product(s) for the caller.\n *\n * @returns list of product view summaries\n */\nexport async function fetchAvailableProducts(client?: IServiceCatalogClient): Promise<AWS.ServiceCatalog.ProductViewSummaries> {\n  const sc = client ?? new ServiceCatalogClient();\n\n  const products: AWS.ServiceCatalog.ProductViewSummaries = [];\n  let token;\n\n  do {\n    const res: AWS.ServiceCatalog.SearchProductsOutput = await sc.searchProducts({\n      PageToken: token,\n    });\n\n    if (res.ProductViewSummaries) {\n      products.push(...res.ProductViewSummaries);\n    }\n    token = res.NextPageToken;\n  } while (token);\n\n  return products;\n}\n\n/**\n * Gets the information required to provision an artifact.\n * Includes information on inputs and outputs of the product.\n *\n * @returns the provisoning parameters for an artifact\n */\nexport async function describeProvisioningParameters(options: DescribeProductAggregateOptions):\nPromise<AWS.ServiceCatalog.DescribeProvisioningParametersOutput> {\n\n  const sc = options.client ?? new ServiceCatalogClient();\n\n  const provisioningParameters: AWS.ServiceCatalog.DescribeProvisioningParametersOutput = await sc.describeProvisioningParameters({\n    ProductId: options.productId,\n    ProvisioningArtifactId: options.provisioningArtifactId,\n    PathId: options.launchPathId,\n  });\n\n  return provisioningParameters;\n}\n\n/**\n * Holds all the information needed to generate a product artifact to provision.\n */\nexport interface ProductDataAggregate {\n  /**\n   * Core product details.\n   */\n  readonly product: AWS.ServiceCatalog.ProductViewSummary;\n  /**\n   * Details on the selected provisioning artifact for the product.\n   * Represents the actual template that contains resources.\n   */\n  readonly provisioningArtifact: AWS.ServiceCatalog.ProvisioningArtifact;\n  /**\n   * Details on the selected launch path for the product.\n   * Represents the permissions/ability for end user to provision the product.\n   */\n  readonly launchPath: AWS.ServiceCatalog.LaunchPathSummary;\n  /**\n   * Details on provisioning requirements for the provisioning artifact and launch path.\n   * Holds information on the inputs and outputs for the downstream template.\n   */\n  readonly params: AWS.ServiceCatalog.DescribeProvisioningParametersOutput;\n}\n\n/**\n * Makes a series of calls to service catalog to get all information\n * required to provision a service catalog product.\n *\n * @returns ProductVersionData aggregate of provisioning artifact details.\n */\nexport async function describeProductAggregate(options: DescribeProductAggregateOptions): Promise<ProductDataAggregate> {\n  const sc = options.client ?? new ServiceCatalogClient();\n\n  const productDataAggregate = await describeProduct({\n    productId: options.productId,\n    launchPathId: options.launchPathId,\n    provisioningArtifactId: options.provisioningArtifactId,\n    client: sc,\n  });\n\n  return productDataAggregate;\n}\n\nfunction validateProductData(productId: string, product: AWS.ServiceCatalog.DescribeProductOutput): void {\n  if (product.ProductViewSummary == undefined) {\n    throw new Error(`Cannot resolve product details for ${productId}`);\n  } else if (product.ProvisioningArtifacts == undefined) {\n    throw new Error(`Cannot resolve provisioning artifacts for product: ${productId}`);\n  } else if (product.LaunchPaths == undefined) {\n    throw new Error(`Cannot resolve launch paths for product: ${productId}`);\n  }\n}"]}
package/package.json CHANGED
@@ -59,7 +59,7 @@
59
59
  },
60
60
  "main": "lib/index.js",
61
61
  "license": "Apache-2.0",
62
- "version": "0.2.144",
62
+ "version": "0.2.145",
63
63
  "jest": {
64
64
  "testMatch": [
65
65
  "<rootDir>/src/**/__tests__/**/*.ts?(x)",