UNPKG

30.5 kBJavaScriptView Raw
1"use strict";
2var _a, _b, _c;
3Object.defineProperty(exports, "__esModule", { value: true });
4exports.HttpMethod = exports.Connection = exports.HttpParameter = exports.Authorization = void 0;
5const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
6const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
7const core_1 = require("@aws-cdk/core");
8const events_generated_1 = require("./events.generated");
9/**
10 * Authorization type for an API Destination Connection
11 */
12class Authorization {
13 /**
14 * Use API key authorization
15 *
16 * API key authorization has two components: an API key name and an API key value.
17 * What these are depends on the target of your connection.
18 */
19 static apiKey(apiKeyName, apiKeyValue) {
20 return new class extends Authorization {
21 _bind() {
22 return {
23 authorizationType: AuthorizationType.API_KEY,
24 authParameters: {
25 apiKeyAuthParameters: {
26 apiKeyName: apiKeyName,
27 apiKeyValue: apiKeyValue.unsafeUnwrap(),
28 },
29 },
30 };
31 }
32 }();
33 }
34 /**
35 * Use username and password authorization
36 */
37 static basic(username, password) {
38 return new class extends Authorization {
39 _bind() {
40 return {
41 authorizationType: AuthorizationType.BASIC,
42 authParameters: {
43 basicAuthParameters: {
44 username: username,
45 password: password.unsafeUnwrap(),
46 },
47 },
48 };
49 }
50 }();
51 }
52 /**
53 * Use OAuth authorization
54 */
55 static oauth(props) {
56 try {
57 jsiiDeprecationWarnings._aws_cdk_aws_events_OAuthAuthorizationProps(props);
58 }
59 catch (error) {
60 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
61 Error.captureStackTrace(error, this.oauth);
62 }
63 throw error;
64 }
65 if (![HttpMethod.POST, HttpMethod.GET, HttpMethod.PUT].includes(props.httpMethod)) {
66 throw new Error('httpMethod must be one of GET, POST, PUT');
67 }
68 return new class extends Authorization {
69 _bind() {
70 return {
71 authorizationType: AuthorizationType.OAUTH_CLIENT_CREDENTIALS,
72 authParameters: {
73 oAuthParameters: {
74 authorizationEndpoint: props.authorizationEndpoint,
75 clientParameters: {
76 clientId: props.clientId,
77 clientSecret: props.clientSecret.unsafeUnwrap(),
78 },
79 httpMethod: props.httpMethod,
80 oAuthHttpParameters: {
81 bodyParameters: renderHttpParameters(props.bodyParameters),
82 headerParameters: renderHttpParameters(props.headerParameters),
83 queryStringParameters: renderHttpParameters(props.queryStringParameters),
84 },
85 },
86 },
87 };
88 }
89 }();
90 }
91}
92exports.Authorization = Authorization;
93_a = JSII_RTTI_SYMBOL_1;
94Authorization[_a] = { fqn: "@aws-cdk/aws-events.Authorization", version: "1.191.0" };
95/**
96 * An additional HTTP parameter to send along with the OAuth request
97 */
98class HttpParameter {
99 /**
100 * Make an OAuthParameter from a string value
101 *
102 * The value is not treated as a secret.
103 */
104 static fromString(value) {
105 return new class extends HttpParameter {
106 _render(name) {
107 return {
108 key: name,
109 value,
110 };
111 }
112 }();
113 }
114 /**
115 * Make an OAuthParameter from a secret
116 */
117 static fromSecret(value) {
118 return new class extends HttpParameter {
119 _render(name) {
120 return {
121 key: name,
122 value: value.unsafeUnwrap(),
123 isValueSecret: true,
124 };
125 }
126 }();
127 }
128}
129exports.HttpParameter = HttpParameter;
130_b = JSII_RTTI_SYMBOL_1;
131HttpParameter[_b] = { fqn: "@aws-cdk/aws-events.HttpParameter", version: "1.191.0" };
132/**
133 * Define an EventBridge Connection
134 *
135 * @resource AWS::Events::Connection
136 */
137class Connection extends core_1.Resource {
138 constructor(scope, id, props) {
139 super(scope, id, {
140 physicalName: props.connectionName,
141 });
142 try {
143 jsiiDeprecationWarnings._aws_cdk_aws_events_ConnectionProps(props);
144 }
145 catch (error) {
146 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
147 Error.captureStackTrace(error, Connection);
148 }
149 throw error;
150 }
151 const authBind = props.authorization._bind();
152 const invocationHttpParameters = !!props.headerParameters || !!props.queryStringParameters || !!props.bodyParameters ? {
153 bodyParameters: renderHttpParameters(props.bodyParameters),
154 headerParameters: renderHttpParameters(props.headerParameters),
155 queryStringParameters: renderHttpParameters(props.queryStringParameters),
156 } : undefined;
157 let connection = new events_generated_1.CfnConnection(this, 'Connection', {
158 authorizationType: authBind.authorizationType,
159 authParameters: {
160 ...authBind.authParameters,
161 invocationHttpParameters: invocationHttpParameters,
162 },
163 description: props.description,
164 name: this.physicalName,
165 });
166 this.connectionName = this.getResourceNameAttribute(connection.ref);
167 this.connectionArn = connection.attrArn;
168 this.connectionSecretArn = connection.attrSecretArn;
169 }
170 /**
171 * Import an existing connection resource
172 * @param scope Parent construct
173 * @param id Construct ID
174 * @param connectionArn ARN of imported connection
175 */
176 static fromEventBusArn(scope, id, connectionArn, connectionSecretArn) {
177 const parts = core_1.Stack.of(scope).parseArn(connectionArn);
178 return new ImportedConnection(scope, id, {
179 connectionArn: connectionArn,
180 connectionName: parts.resourceName || '',
181 connectionSecretArn: connectionSecretArn,
182 });
183 }
184 /**
185 * Import an existing connection resource
186 * @param scope Parent construct
187 * @param id Construct ID
188 * @param attrs Imported connection properties
189 */
190 static fromConnectionAttributes(scope, id, attrs) {
191 try {
192 jsiiDeprecationWarnings._aws_cdk_aws_events_ConnectionAttributes(attrs);
193 }
194 catch (error) {
195 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
196 Error.captureStackTrace(error, this.fromConnectionAttributes);
197 }
198 throw error;
199 }
200 return new ImportedConnection(scope, id, attrs);
201 }
202}
203exports.Connection = Connection;
204_c = JSII_RTTI_SYMBOL_1;
205Connection[_c] = { fqn: "@aws-cdk/aws-events.Connection", version: "1.191.0" };
206class ImportedConnection extends core_1.Resource {
207 constructor(scope, id, attrs) {
208 const arnParts = core_1.Stack.of(scope).parseArn(attrs.connectionArn);
209 super(scope, id, {
210 account: arnParts.account,
211 region: arnParts.region,
212 });
213 this.connectionArn = attrs.connectionArn;
214 this.connectionName = attrs.connectionName;
215 this.connectionSecretArn = attrs.connectionSecretArn;
216 }
217}
218/**
219 * Supported HTTP operations.
220 */
221var HttpMethod;
222(function (HttpMethod) {
223 /** POST */
224 HttpMethod["POST"] = "POST";
225 /** GET */
226 HttpMethod["GET"] = "GET";
227 /** HEAD */
228 HttpMethod["HEAD"] = "HEAD";
229 /** OPTIONS */
230 HttpMethod["OPTIONS"] = "OPTIONS";
231 /** PUT */
232 HttpMethod["PUT"] = "PUT";
233 /** PATCH */
234 HttpMethod["PATCH"] = "PATCH";
235 /** DELETE */
236 HttpMethod["DELETE"] = "DELETE";
237})(HttpMethod = exports.HttpMethod || (exports.HttpMethod = {}));
238/**
239 * Supported Authorization Types.
240 */
241var AuthorizationType;
242(function (AuthorizationType) {
243 /** API_KEY */
244 AuthorizationType["API_KEY"] = "API_KEY";
245 /** BASIC */
246 AuthorizationType["BASIC"] = "BASIC";
247 /** OAUTH_CLIENT_CREDENTIALS */
248 AuthorizationType["OAUTH_CLIENT_CREDENTIALS"] = "OAUTH_CLIENT_CREDENTIALS";
249})(AuthorizationType || (AuthorizationType = {}));
250function renderHttpParameters(ps) {
251 if (!ps || Object.keys(ps).length === 0) {
252 return undefined;
253 }
254 return Object.entries(ps).map(([name, p]) => p._render(name));
255}
256//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"connection.js","sourceRoot":"","sources":["connection.ts"],"names":[],"mappings":"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","sourcesContent":["import { IResource, Resource, Stack, SecretValue } from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport { CfnConnection } from './events.generated';\n\n/**\n * An API Destination Connection\n *\n * A connection defines the authorization type and credentials to use for authorization with an API destination HTTP endpoint.\n */\nexport interface ConnectionProps {\n  /**\n   * The name of the connection.\n   *\n   * @default - A name is automatically generated\n   */\n  readonly connectionName?: string;\n\n  /**\n   * The name of the connection.\n   *\n   * @default - none\n   */\n  readonly description?: string;\n\n  /**\n   * The authorization type for the connection.\n   */\n  readonly authorization: Authorization;\n\n  /**\n   * Additional string parameters to add to the invocation bodies\n   *\n   * @default - No additional parameters\n   */\n  readonly bodyParameters?: Record<string, HttpParameter>;\n\n  /**\n   * Additional string parameters to add to the invocation headers\n   *\n   * @default - No additional parameters\n   */\n  readonly headerParameters?: Record<string, HttpParameter>;\n\n  /**\n   * Additional string parameters to add to the invocation query strings\n   *\n   * @default - No additional parameters\n   */\n  readonly queryStringParameters?: Record<string, HttpParameter>;\n}\n\n/**\n * Authorization type for an API Destination Connection\n */\nexport abstract class Authorization {\n  /**\n   * Use API key authorization\n   *\n   * API key authorization has two components: an API key name and an API key value.\n   * What these are depends on the target of your connection.\n   */\n  public static apiKey(apiKeyName: string, apiKeyValue: SecretValue): Authorization {\n    return new class extends Authorization {\n      public _bind() {\n        return {\n          authorizationType: AuthorizationType.API_KEY,\n          authParameters: {\n            apiKeyAuthParameters: {\n              apiKeyName: apiKeyName,\n              apiKeyValue: apiKeyValue.unsafeUnwrap(), // Safe usage\n            },\n          } as CfnConnection.AuthParametersProperty,\n        };\n      }\n    }();\n  }\n\n  /**\n   * Use username and password authorization\n   */\n  public static basic(username: string, password: SecretValue): Authorization {\n    return new class extends Authorization {\n      public _bind() {\n        return {\n          authorizationType: AuthorizationType.BASIC,\n          authParameters: {\n            basicAuthParameters: {\n              username: username,\n              password: password.unsafeUnwrap(), // Safe usage\n            },\n          } as CfnConnection.AuthParametersProperty,\n        };\n      }\n    }();\n  }\n\n  /**\n   * Use OAuth authorization\n   */\n  public static oauth(props: OAuthAuthorizationProps): Authorization {\n    if (![HttpMethod.POST, HttpMethod.GET, HttpMethod.PUT].includes(props.httpMethod)) {\n      throw new Error('httpMethod must be one of GET, POST, PUT');\n    }\n\n    return new class extends Authorization {\n      public _bind() {\n        return {\n          authorizationType: AuthorizationType.OAUTH_CLIENT_CREDENTIALS,\n          authParameters: {\n            oAuthParameters: {\n              authorizationEndpoint: props.authorizationEndpoint,\n              clientParameters: {\n                clientId: props.clientId,\n                clientSecret: props.clientSecret.unsafeUnwrap(), // Safe usage\n              },\n              httpMethod: props.httpMethod,\n              oAuthHttpParameters: {\n                bodyParameters: renderHttpParameters(props.bodyParameters),\n                headerParameters: renderHttpParameters(props.headerParameters),\n                queryStringParameters: renderHttpParameters(props.queryStringParameters),\n              },\n            },\n          } as CfnConnection.AuthParametersProperty,\n        };\n      }\n    }();\n\n  }\n\n  /**\n   * Bind the authorization to the construct and return the authorization properties\n   *\n   * @internal\n   */\n  public abstract _bind(): AuthorizationBindResult;\n}\n\n/**\n * Properties for `Authorization.oauth()`\n */\nexport interface OAuthAuthorizationProps {\n\n  /**\n   * The URL to the authorization endpoint\n   */\n  readonly authorizationEndpoint: string;\n\n  /**\n   * The method to use for the authorization request.\n   *\n   * (Can only choose POST, GET or PUT).\n   */\n  readonly httpMethod: HttpMethod;\n\n  /**\n   * The client ID to use for OAuth authorization for the connection.\n   */\n  readonly clientId: string;\n\n  /**\n   * The client secret associated with the client ID to use for OAuth authorization for the connection.\n   */\n  readonly clientSecret: SecretValue;\n\n  /**\n   * Additional string parameters to add to the OAuth request body\n   *\n   * @default - No additional parameters\n   */\n  readonly bodyParameters?: Record<string, HttpParameter>;\n\n  /**\n   * Additional string parameters to add to the OAuth request header\n   *\n   * @default - No additional parameters\n   */\n  readonly headerParameters?: Record<string, HttpParameter>;\n\n  /**\n   * Additional string parameters to add to the OAuth request query string\n   *\n   * @default - No additional parameters\n   */\n  readonly queryStringParameters?: Record<string, HttpParameter>;\n}\n\n/**\n * An additional HTTP parameter to send along with the OAuth request\n */\nexport abstract class HttpParameter {\n  /**\n   * Make an OAuthParameter from a string value\n   *\n   * The value is not treated as a secret.\n   */\n  public static fromString(value: string): HttpParameter {\n    return new class extends HttpParameter {\n      public _render(name: string) {\n        return {\n          key: name,\n          value,\n        } as CfnConnection.ParameterProperty;\n      }\n    }();\n  }\n\n  /**\n   * Make an OAuthParameter from a secret\n   */\n  public static fromSecret(value: SecretValue): HttpParameter {\n    return new class extends HttpParameter {\n      public _render(name: string) {\n        return {\n          key: name,\n          value: value.unsafeUnwrap(), // Safe usage\n          isValueSecret: true,\n        } as CfnConnection.ParameterProperty;\n      }\n    }();\n  }\n\n  /**\n   * Render the paramter value\n   *\n   * @internal\n   */\n  public abstract _render(name: string): any;\n}\n\n/**\n * Result of the 'bind' operation of the 'Authorization' class\n *\n * @internal\n */\nexport interface AuthorizationBindResult {\n  /**\n   * The authorization type\n   */\n  readonly authorizationType: AuthorizationType;\n\n  /**\n   * The authorization parameters (depends on the type)\n   */\n  readonly authParameters: any;\n}\n\n/**\n * Interface for EventBus Connections\n */\nexport interface IConnection extends IResource {\n  /**\n   * The Name for the connection.\n   * @attribute\n   */\n  readonly connectionName: string;\n\n  /**\n   * The ARN of the connection created.\n   * @attribute\n   */\n  readonly connectionArn: string;\n\n  /**\n   * The ARN for the secret created for the connection.\n   * @attribute\n   */\n  readonly connectionSecretArn: string;\n}\n\n/**\n * Interface with properties necessary to import a reusable Connection\n */\nexport interface ConnectionAttributes {\n  /**\n   * The Name for the connection.\n   */\n  readonly connectionName: string;\n\n  /**\n   * The ARN of the connection created.\n   */\n  readonly connectionArn: string;\n\n  /**\n   * The ARN for the secret created for the connection.\n   */\n  readonly connectionSecretArn: string;\n}\n\n/**\n * Define an EventBridge Connection\n *\n * @resource AWS::Events::Connection\n */\nexport class Connection extends Resource implements IConnection {\n  /**\n   * Import an existing connection resource\n   * @param scope Parent construct\n   * @param id Construct ID\n   * @param connectionArn ARN of imported connection\n   */\n  public static fromEventBusArn(scope: Construct, id: string, connectionArn: string, connectionSecretArn: string): IConnection {\n    const parts = Stack.of(scope).parseArn(connectionArn);\n\n    return new ImportedConnection(scope, id, {\n      connectionArn: connectionArn,\n      connectionName: parts.resourceName || '',\n      connectionSecretArn: connectionSecretArn,\n    });\n  }\n\n  /**\n   * Import an existing connection resource\n   * @param scope Parent construct\n   * @param id Construct ID\n   * @param attrs Imported connection properties\n   */\n  public static fromConnectionAttributes(scope: Construct, id: string, attrs: ConnectionAttributes): IConnection {\n    return new ImportedConnection(scope, id, attrs);\n  }\n\n  /**\n   * The Name for the connection.\n   * @attribute\n   */\n  public readonly connectionName: string;\n\n  /**\n   * The ARN of the connection created.\n   * @attribute\n   */\n  public readonly connectionArn: string;\n\n  /**\n   * The ARN for the secret created for the connection.\n   * @attribute\n   */\n  public readonly connectionSecretArn: string;\n\n  constructor(scope: Construct, id: string, props: ConnectionProps) {\n    super(scope, id, {\n      physicalName: props.connectionName,\n    });\n\n    const authBind = props.authorization._bind();\n\n    const invocationHttpParameters = !!props.headerParameters || !!props.queryStringParameters || !!props.bodyParameters ? {\n      bodyParameters: renderHttpParameters(props.bodyParameters),\n      headerParameters: renderHttpParameters(props.headerParameters),\n      queryStringParameters: renderHttpParameters(props.queryStringParameters),\n    } : undefined;\n\n    let connection = new CfnConnection(this, 'Connection', {\n      authorizationType: authBind.authorizationType,\n      authParameters: {\n        ...authBind.authParameters,\n        invocationHttpParameters: invocationHttpParameters,\n      },\n      description: props.description,\n      name: this.physicalName,\n    });\n\n    this.connectionName = this.getResourceNameAttribute(connection.ref);\n    this.connectionArn = connection.attrArn;\n    this.connectionSecretArn = connection.attrSecretArn;\n  }\n}\n\nclass ImportedConnection extends Resource {\n  public readonly connectionArn: string;\n  public readonly connectionName: string;\n  public readonly connectionSecretArn: string;\n  constructor(scope: Construct, id: string, attrs: ConnectionAttributes) {\n    const arnParts = Stack.of(scope).parseArn(attrs.connectionArn);\n    super(scope, id, {\n      account: arnParts.account,\n      region: arnParts.region,\n    });\n\n    this.connectionArn = attrs.connectionArn;\n    this.connectionName = attrs.connectionName;\n    this.connectionSecretArn = attrs.connectionSecretArn;\n  }\n}\n\n/**\n * Supported HTTP operations.\n */\nexport enum HttpMethod {\n  /** POST */\n  POST = 'POST',\n  /** GET */\n  GET = 'GET',\n  /** HEAD */\n  HEAD = 'HEAD',\n  /** OPTIONS */\n  OPTIONS = 'OPTIONS',\n  /** PUT */\n  PUT = 'PUT',\n  /** PATCH */\n  PATCH = 'PATCH',\n  /** DELETE */\n  DELETE = 'DELETE',\n}\n\n/**\n * Supported Authorization Types.\n */\nenum AuthorizationType {\n  /** API_KEY */\n  API_KEY = 'API_KEY',\n  /** BASIC */\n  BASIC = 'BASIC',\n  /** OAUTH_CLIENT_CREDENTIALS */\n  OAUTH_CLIENT_CREDENTIALS = 'OAUTH_CLIENT_CREDENTIALS',\n}\n\nfunction renderHttpParameters(ps?: Record<string, HttpParameter>): CfnConnection.ParameterProperty[] | undefined {\n  if (!ps || Object.keys(ps).length === 0) { return undefined; }\n\n  return Object.entries(ps).map(([name, p]) => p._render(name));\n}"]}
\No newline at end of file