UNPKG

12.4 kBJavaScriptView Raw
1"use strict";
2var _a;
3Object.defineProperty(exports, "__esModule", { value: true });
4exports.AwsApi = void 0;
5const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
6const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
7const path = require("path");
8const events = require("@aws-cdk/aws-events");
9const iam = require("@aws-cdk/aws-iam");
10const lambda = require("@aws-cdk/aws-lambda");
11const core_1 = require("@aws-cdk/core");
12const sdk_api_metadata_generated_1 = require("./sdk-api-metadata.generated");
13const util_1 = require("./util");
14const awsSdkMetadata = sdk_api_metadata_generated_1.metadata;
15/**
16 * Use an AWS Lambda function that makes API calls as an event rule target.
17 */
18class AwsApi {
19 constructor(props) {
20 this.props = props;
21 try {
22 jsiiDeprecationWarnings._aws_cdk_aws_events_targets_AwsApiProps(props);
23 }
24 catch (error) {
25 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
26 Error.captureStackTrace(error, this.constructor);
27 }
28 throw error;
29 }
30 }
31 /**
32 * Returns a RuleTarget that can be used to trigger this AwsApi as a
33 * result from an EventBridge event.
34 */
35 bind(rule, id) {
36 const handler = new lambda.SingletonFunction(rule, `${rule.node.id}${id}Handler`, {
37 code: lambda.Code.fromAsset(path.join(__dirname, 'aws-api-handler'), {
38 exclude: ['*.ts'],
39 }),
40 runtime: lambda.Runtime.NODEJS_12_X,
41 handler: 'index.handler',
42 uuid: 'b4cf1abd-4e4f-4bc6-9944-1af7ccd9ec37',
43 lambdaPurpose: 'AWS',
44 });
45 checkServiceExists(this.props.service, handler);
46 if (this.props.policyStatement) {
47 handler.addToRolePolicy(this.props.policyStatement);
48 }
49 else {
50 handler.addToRolePolicy(new iam.PolicyStatement({
51 actions: [awsSdkToIamAction(this.props.service, this.props.action)],
52 resources: ['*'],
53 }));
54 }
55 // Allow handler to be called from rule
56 util_1.addLambdaPermission(rule, handler);
57 const input = {
58 service: this.props.service,
59 action: this.props.action,
60 parameters: this.props.parameters,
61 catchErrorPattern: this.props.catchErrorPattern,
62 apiVersion: this.props.apiVersion,
63 };
64 return {
65 arn: handler.functionArn,
66 input: events.RuleTargetInput.fromObject(input),
67 targetResource: handler,
68 };
69 }
70}
71exports.AwsApi = AwsApi;
72_a = JSII_RTTI_SYMBOL_1;
73AwsApi[_a] = { fqn: "@aws-cdk/aws-events-targets.AwsApi", version: "1.156.1" };
74/**
75 * Check if the given service exists in the AWS SDK. If not, a warning will be raised.
76 * @param service Service name
77 */
78function checkServiceExists(service, handler) {
79 const sdkService = awsSdkMetadata[service.toLowerCase()];
80 if (!sdkService) {
81 core_1.Annotations.of(handler).addWarning(`Service ${service} does not exist in the AWS SDK. Check the list of available \
82services and actions from https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/index.html`);
83 }
84}
85/**
86 * Transform SDK service/action to IAM action using metadata from aws-sdk module.
87 */
88function awsSdkToIamAction(service, action) {
89 const srv = service.toLowerCase();
90 const iamService = awsSdkMetadata[srv].prefix || srv;
91 const iamAction = action.charAt(0).toUpperCase() + action.slice(1);
92 return `${iamService}:${iamAction}`;
93}
94//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aws-api.js","sourceRoot":"","sources":["aws-api.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as events from '@aws-cdk/aws-events';\nimport * as iam from '@aws-cdk/aws-iam';\nimport * as lambda from '@aws-cdk/aws-lambda';\nimport { Annotations } from '@aws-cdk/core';\nimport { metadata } from './sdk-api-metadata.generated';\nimport { addLambdaPermission } from './util';\n\n/**\n * AWS SDK service metadata.\n */\nexport type AwsSdkMetadata = {[key: string]: any};\n\nconst awsSdkMetadata: AwsSdkMetadata = metadata;\n\n/**\n * Rule target input for an AwsApi target.\n */\nexport interface AwsApiInput {\n  /**\n   * The service to call\n   *\n   * @see https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/index.html\n   */\n  readonly service: string;\n\n  /**\n   * The service action to call\n   *\n   * @see https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/index.html\n   */\n  readonly action: string;\n\n  /**\n   * The parameters for the service action\n   *\n   * @see https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/index.html\n   *\n   * @default - no parameters\n   */\n  readonly parameters?: any;\n\n  /**\n   * The regex pattern to use to catch API errors. The `code` property of the\n   * `Error` object will be tested against this pattern. If there is a match an\n   * error will not be thrown.\n   *\n   * @default - do not catch errors\n   */\n  readonly catchErrorPattern?: string;\n\n  /**\n   * API version to use for the service\n   *\n   * @see https://docs.aws.amazon.com/sdk-for-javascript/v2/developer-guide/locking-api-versions.html\n   * @default - use latest available API version\n   */\n  readonly apiVersion?: string;\n}\n\n/**\n * Properties for an AwsApi target.\n */\nexport interface AwsApiProps extends AwsApiInput {\n  /**\n   * The IAM policy statement to allow the API call. Use only if\n   * resource restriction is needed.\n   *\n   * @default - extract the permission from the API call\n   */\n  readonly policyStatement?: iam.PolicyStatement;\n}\n\n/**\n * Use an AWS Lambda function that makes API calls as an event rule target.\n */\nexport class AwsApi implements events.IRuleTarget {\n  constructor(private readonly props: AwsApiProps) {}\n\n  /**\n   * Returns a RuleTarget that can be used to trigger this AwsApi as a\n   * result from an EventBridge event.\n   */\n  public bind(rule: events.IRule, id?: string): events.RuleTargetConfig {\n    const handler = new lambda.SingletonFunction(rule as events.Rule, `${rule.node.id}${id}Handler`, {\n      code: lambda.Code.fromAsset(path.join(__dirname, 'aws-api-handler'), {\n        exclude: ['*.ts'],\n      }),\n      runtime: lambda.Runtime.NODEJS_12_X,\n      handler: 'index.handler',\n      uuid: 'b4cf1abd-4e4f-4bc6-9944-1af7ccd9ec37',\n      lambdaPurpose: 'AWS',\n    });\n\n    checkServiceExists(this.props.service, handler);\n\n    if (this.props.policyStatement) {\n      handler.addToRolePolicy(this.props.policyStatement);\n    } else {\n      handler.addToRolePolicy(new iam.PolicyStatement({\n        actions: [awsSdkToIamAction(this.props.service, this.props.action)],\n        resources: ['*'],\n      }));\n    }\n\n    // Allow handler to be called from rule\n    addLambdaPermission(rule, handler);\n\n    const input: AwsApiInput = {\n      service: this.props.service,\n      action: this.props.action,\n      parameters: this.props.parameters,\n      catchErrorPattern: this.props.catchErrorPattern,\n      apiVersion: this.props.apiVersion,\n    };\n\n    return {\n      arn: handler.functionArn,\n      input: events.RuleTargetInput.fromObject(input),\n      targetResource: handler,\n    };\n  }\n}\n\n/**\n * Check if the given service exists in the AWS SDK. If not, a warning will be raised.\n * @param service Service name\n */\nfunction checkServiceExists(service: string, handler: lambda.SingletonFunction) {\n  const sdkService = awsSdkMetadata[service.toLowerCase()];\n  if (!sdkService) {\n    Annotations.of(handler).addWarning(`Service ${service} does not exist in the AWS SDK. Check the list of available \\\nservices and actions from https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/index.html`);\n  }\n}\n\n/**\n * Transform SDK service/action to IAM action using metadata from aws-sdk module.\n */\nfunction awsSdkToIamAction(service: string, action: string): string {\n  const srv = service.toLowerCase();\n  const iamService = awsSdkMetadata[srv].prefix || srv;\n  const iamAction = action.charAt(0).toUpperCase() + action.slice(1);\n  return `${iamService}:${iamAction}`;\n}\n"]}
\No newline at end of file