cdk-import 0.2.134 → 0.2.135
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/service-catalog.d.ts +68 -0
- package/lib/service-catalog.js +139 -0
- package/package.json +1 -1
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import * as AWS from 'aws-sdk';
|
|
2
|
+
export interface IServiceCatalogClient {
|
|
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
|
+
describeProvisioningParameters(input: AWS.ServiceCatalog.DescribeProvisioningParametersInput): Promise<AWS.ServiceCatalog.DescribeProvisioningParametersOutput>;
|
|
7
|
+
}
|
|
8
|
+
export declare class ServiceCatalogClient implements IServiceCatalogClient {
|
|
9
|
+
private readonly sc;
|
|
10
|
+
constructor();
|
|
11
|
+
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
|
+
describeProvisioningParameters(input: AWS.ServiceCatalog.DescribeProvisioningParametersInput): Promise<AWS.ServiceCatalog.DescribeProvisioningParametersOutput>;
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* 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.
|
|
19
|
+
*/
|
|
20
|
+
export interface DescribeProvisionedProductOptions {
|
|
21
|
+
/**
|
|
22
|
+
* A client that performs calls to AWS Service Catalog. You can provide a mock here
|
|
23
|
+
* for testing.
|
|
24
|
+
*/
|
|
25
|
+
readonly client?: IServiceCatalogClient;
|
|
26
|
+
/**
|
|
27
|
+
* The product Id..
|
|
28
|
+
*/
|
|
29
|
+
readonly productId?: string;
|
|
30
|
+
/**
|
|
31
|
+
* The provisioning artifact Id.
|
|
32
|
+
*/
|
|
33
|
+
readonly provisioningArtifactId?: string;
|
|
34
|
+
/**
|
|
35
|
+
* The launch path Id.
|
|
36
|
+
*/
|
|
37
|
+
readonly launchPathId?: string;
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Fetches the all the available or queried service catalog product(s) for the caller.
|
|
41
|
+
*
|
|
42
|
+
* @returns list of product view summaries
|
|
43
|
+
*/
|
|
44
|
+
export declare function fetchAvailableProducts(options?: DescribeProvisionedProductOptions): Promise<AWS.ServiceCatalog.ProductViewSummaries>;
|
|
45
|
+
/**
|
|
46
|
+
* Fetches the all the available or queried provisioning artifact(s) for the caller.
|
|
47
|
+
*
|
|
48
|
+
* @param productId the product to fetch provisioning artifacts for
|
|
49
|
+
* @returns list of provisioning artifact details for a product
|
|
50
|
+
*/
|
|
51
|
+
export declare function listProvisioningArtifacts(productId: string, options?: DescribeProvisionedProductOptions): Promise<AWS.ServiceCatalog.ProvisioningArtifactDetail[]>;
|
|
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
|
|
57
|
+
*/
|
|
58
|
+
export declare function listLaunchPaths(productId: string, options?: DescribeProvisionedProductOptions): Promise<AWS.ServiceCatalog.LaunchPathSummaries>;
|
|
59
|
+
/**
|
|
60
|
+
* Gets the information required to provision an artifact.
|
|
61
|
+
* Includes information on inputs and outputs of the product.
|
|
62
|
+
*
|
|
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
|
|
67
|
+
*/
|
|
68
|
+
export declare function describeProvisioningParameters(productId: string, provisioningArtifactId: string, launchPathId: string, options?: DescribeProvisionedProductOptions): Promise<AWS.ServiceCatalog.DescribeProvisioningParametersOutput>;
|
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
+
exports.describeProvisioningParameters = exports.listLaunchPaths = exports.listProvisioningArtifacts = exports.fetchAvailableProducts = exports.ServiceCatalogClient = void 0;
|
|
27
|
+
const AWS = __importStar(require("aws-sdk"));
|
|
28
|
+
const aws_1 = require("./aws");
|
|
29
|
+
class ServiceCatalogClient {
|
|
30
|
+
constructor() {
|
|
31
|
+
this.sc = (0, aws_1.createAwsClient)(AWS.ServiceCatalog);
|
|
32
|
+
}
|
|
33
|
+
async searchProducts(input) {
|
|
34
|
+
return this.sc.searchProducts(input).promise();
|
|
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
|
+
async describeProvisioningParameters(input) {
|
|
43
|
+
return this.sc.describeProvisioningParameters(input).promise();
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
exports.ServiceCatalogClient = ServiceCatalogClient;
|
|
47
|
+
/**
|
|
48
|
+
* Fetches the all the available or queried service catalog product(s) for the caller.
|
|
49
|
+
*
|
|
50
|
+
* @returns list of product view summaries
|
|
51
|
+
*/
|
|
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);
|
|
64
|
+
}
|
|
65
|
+
token = res.NextPageToken;
|
|
66
|
+
} while (token);
|
|
67
|
+
return products;
|
|
68
|
+
}
|
|
69
|
+
exports.fetchAvailableProducts = fetchAvailableProducts;
|
|
70
|
+
/**
|
|
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
|
|
75
|
+
*/
|
|
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);
|
|
84
|
+
}
|
|
85
|
+
else {
|
|
86
|
+
return provisioningArtifacts.ProvisioningArtifactDetails;
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
exports.listProvisioningArtifacts = listProvisioningArtifacts;
|
|
90
|
+
/**
|
|
91
|
+
* Retrieves all the availalbe or queried launch path(s) for a product.
|
|
92
|
+
*
|
|
93
|
+
* @param productId the product to list launch paths for
|
|
94
|
+
* @returns list of launchPathSummaries for a product
|
|
95
|
+
*/
|
|
96
|
+
async function listLaunchPaths(productId, options = {}) {
|
|
97
|
+
var _a;
|
|
98
|
+
const sc = (_a = options.client) !== null && _a !== void 0 ? _a : new ServiceCatalogClient();
|
|
99
|
+
const launchPaths = [];
|
|
100
|
+
let token;
|
|
101
|
+
do {
|
|
102
|
+
const res = await sc.listLaunchPaths({
|
|
103
|
+
ProductId: productId,
|
|
104
|
+
PageToken: token,
|
|
105
|
+
});
|
|
106
|
+
if (res.LaunchPathSummaries) {
|
|
107
|
+
launchPaths.push(...res.LaunchPathSummaries);
|
|
108
|
+
}
|
|
109
|
+
token = res.NextPageToken;
|
|
110
|
+
} while (token);
|
|
111
|
+
if (options.launchPathId != null) {
|
|
112
|
+
return launchPaths.filter(lp => lp.Id == options.launchPathId);
|
|
113
|
+
}
|
|
114
|
+
else {
|
|
115
|
+
return launchPaths;
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
exports.listLaunchPaths = listLaunchPaths;
|
|
119
|
+
/**
|
|
120
|
+
* Gets the information required to provision an artifact.
|
|
121
|
+
* Includes information on inputs and outputs of the product.
|
|
122
|
+
*
|
|
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
|
+
* @returns the provisoning parameters for an artifact
|
|
127
|
+
*/
|
|
128
|
+
async function describeProvisioningParameters(productId, provisioningArtifactId, launchPathId, options = {}) {
|
|
129
|
+
var _a;
|
|
130
|
+
const sc = (_a = options.client) !== null && _a !== void 0 ? _a : new ServiceCatalogClient();
|
|
131
|
+
const provisioningParameters = await sc.describeProvisioningParameters({
|
|
132
|
+
ProductId: productId,
|
|
133
|
+
ProvisioningArtifactId: provisioningArtifactId,
|
|
134
|
+
PathId: launchPathId,
|
|
135
|
+
});
|
|
136
|
+
return provisioningParameters;
|
|
137
|
+
}
|
|
138
|
+
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}"]}
|