cdk-import 0.2.144 → 0.2.147
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 +23 -0
- package/lib/index.js +38 -2
- package/lib/service-catalog.d.ts +40 -26
- package/lib/service-catalog.js +113 -63
- package/package.json +5 -5
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
|
-
|
|
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=
|
package/lib/service-catalog.d.ts
CHANGED
|
@@ -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
|
|
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
|
|
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
|
|
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(
|
|
44
|
+
export declare function fetchAvailableProducts(client?: IServiceCatalogClient): Promise<AWS.ServiceCatalog.ProductViewSummaries>;
|
|
45
45
|
/**
|
|
46
|
-
*
|
|
46
|
+
* Gets the information required to provision an artifact.
|
|
47
|
+
* Includes information on inputs and outputs of the product.
|
|
47
48
|
*
|
|
48
|
-
* @
|
|
49
|
-
* @returns list of provisioning artifact details for a product
|
|
49
|
+
* @returns the provisoning parameters for an artifact
|
|
50
50
|
*/
|
|
51
|
-
export declare function
|
|
51
|
+
export declare function describeProvisioningParameters(options: DescribeProductAggregateOptions): Promise<AWS.ServiceCatalog.DescribeProvisioningParametersOutput>;
|
|
52
52
|
/**
|
|
53
|
-
*
|
|
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
|
|
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
|
-
*
|
|
61
|
-
*
|
|
77
|
+
* Makes a series of calls to service catalog to get all information
|
|
78
|
+
* required to provision a service catalog product.
|
|
62
79
|
*
|
|
63
|
-
* @
|
|
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
|
|
82
|
+
export declare function describeProductAggregate(options: DescribeProductAggregateOptions): Promise<ProductDataAggregate>;
|
package/lib/service-catalog.js
CHANGED
|
@@ -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.
|
|
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
|
-
*
|
|
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
|
-
* @
|
|
49
|
+
* @param provisioningArtifacts list of provisioning artifacts for a product
|
|
50
|
+
* @param provisioningArtifactId query artifact Id
|
|
51
|
+
* @returns provisioning artifact detail
|
|
51
52
|
*/
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
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
|
-
|
|
66
|
-
|
|
67
|
-
|
|
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
|
-
*
|
|
72
|
-
*
|
|
73
|
-
* @param
|
|
74
|
-
* @returns
|
|
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
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
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
|
-
|
|
97
|
+
throw new Error('Unable to resolve between multiple launch paths.');
|
|
87
98
|
}
|
|
88
99
|
}
|
|
89
|
-
exports.listProvisioningArtifacts = listProvisioningArtifacts;
|
|
90
100
|
/**
|
|
91
|
-
*
|
|
101
|
+
* Fetches the all the available or queried service catalog product(s) for the caller.
|
|
92
102
|
*
|
|
93
|
-
* @
|
|
94
|
-
* @returns list of launchPathSummaries for a product
|
|
103
|
+
* @returns list of product view summaries
|
|
95
104
|
*/
|
|
96
|
-
async function
|
|
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
|
|
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.
|
|
103
|
-
ProductId: productId,
|
|
132
|
+
const res = await sc.searchProducts({
|
|
104
133
|
PageToken: token,
|
|
105
134
|
});
|
|
106
|
-
if (res.
|
|
107
|
-
|
|
135
|
+
if (res.ProductViewSummaries) {
|
|
136
|
+
products.push(...res.ProductViewSummaries);
|
|
108
137
|
}
|
|
109
138
|
token = res.NextPageToken;
|
|
110
139
|
} while (token);
|
|
111
|
-
|
|
112
|
-
return launchPaths.filter(lp => lp.Id == options.launchPathId);
|
|
113
|
-
}
|
|
114
|
-
else {
|
|
115
|
-
return launchPaths;
|
|
116
|
-
}
|
|
140
|
+
return products;
|
|
117
141
|
}
|
|
118
|
-
exports.
|
|
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(
|
|
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
|
@@ -40,17 +40,17 @@
|
|
|
40
40
|
"jest-junit": "^13",
|
|
41
41
|
"json-schema": "^0.4.0",
|
|
42
42
|
"npm-check-updates": "^12",
|
|
43
|
-
"projen": "^0.54.
|
|
43
|
+
"projen": "^0.54.39",
|
|
44
44
|
"standard-version": "^9",
|
|
45
45
|
"ts-jest": "^27.1.4",
|
|
46
46
|
"ts-node": "^10.7.0",
|
|
47
47
|
"typescript": "^4.6.3"
|
|
48
48
|
},
|
|
49
49
|
"dependencies": {
|
|
50
|
-
"aws-sdk": "^2.
|
|
50
|
+
"aws-sdk": "^2.1119.0",
|
|
51
51
|
"case": "^1.6.3",
|
|
52
|
-
"jsii-srcmak": "^0.1.
|
|
53
|
-
"json2jsii": "^0.2.
|
|
52
|
+
"jsii-srcmak": "^0.1.538",
|
|
53
|
+
"json2jsii": "^0.2.198",
|
|
54
54
|
"minimist": "^1.2.6",
|
|
55
55
|
"proxy-agent": "^5.0.0"
|
|
56
56
|
},
|
|
@@ -59,7 +59,7 @@
|
|
|
59
59
|
},
|
|
60
60
|
"main": "lib/index.js",
|
|
61
61
|
"license": "Apache-2.0",
|
|
62
|
-
"version": "0.2.
|
|
62
|
+
"version": "0.2.147",
|
|
63
63
|
"jest": {
|
|
64
64
|
"testMatch": [
|
|
65
65
|
"<rootDir>/src/**/__tests__/**/*.ts?(x)",
|