UNPKG

17.4 kBJavaScriptView Raw
1"use strict";
2var _a;
3Object.defineProperty(exports, "__esModule", { value: true });
4exports.FunctionUrl = exports.HttpMethod = exports.FunctionUrlAuthType = void 0;
5const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
6const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
7const iam = require("@aws-cdk/aws-iam");
8const core_1 = require("@aws-cdk/core");
9const lambda_generated_1 = require("./lambda.generated");
10/**
11 * The auth types for a function url
12 */
13var FunctionUrlAuthType;
14(function (FunctionUrlAuthType) {
15 /**
16 * Restrict access to authenticated IAM users only
17 */
18 FunctionUrlAuthType["AWS_IAM"] = "AWS_IAM";
19 /**
20 * Bypass IAM authentication to create a public endpoint
21 */
22 FunctionUrlAuthType["NONE"] = "NONE";
23})(FunctionUrlAuthType = exports.FunctionUrlAuthType || (exports.FunctionUrlAuthType = {}));
24/**
25 * All http request methods
26 */
27var HttpMethod;
28(function (HttpMethod) {
29 /**
30 * The GET method requests a representation of the specified resource.
31 */
32 HttpMethod["GET"] = "GET";
33 /**
34 * The PUT method replaces all current representations of the target resource with the request payload.
35 */
36 HttpMethod["PUT"] = "PUT";
37 /**
38 * The HEAD method asks for a response identical to that of a GET request, but without the response body.
39 */
40 HttpMethod["HEAD"] = "HEAD";
41 /**
42 * The POST method is used to submit an entity to the specified resource, often causing a change in state or side effects on the server.
43 */
44 HttpMethod["POST"] = "POST";
45 /**
46 * The DELETE method deletes the specified resource.
47 */
48 HttpMethod["DELETE"] = "DELETE";
49 /**
50 * The PATCH method applies partial modifications to a resource.
51 */
52 HttpMethod["PATCH"] = "PATCH";
53 /**
54 * The OPTIONS method describes the communication options for the target resource.
55 */
56 HttpMethod["OPTIONS"] = "OPTIONS";
57 /**
58 * The wildcard entry to allow all methods.
59 */
60 HttpMethod["ALL"] = "*";
61})(HttpMethod = exports.HttpMethod || (exports.HttpMethod = {}));
62/**
63 * Defines a Lambda function url
64 *
65 * @resource AWS::Lambda::Url
66 */
67class FunctionUrl extends core_1.Resource {
68 constructor(scope, id, props) {
69 super(scope, id);
70 try {
71 jsiiDeprecationWarnings._aws_cdk_aws_lambda_FunctionUrlProps(props);
72 }
73 catch (error) {
74 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
75 Error.captureStackTrace(error, FunctionUrl);
76 }
77 throw error;
78 }
79 if (this.instanceOfVersion(props.function)) {
80 throw new Error('FunctionUrl cannot be used with a Version');
81 }
82 // If the target function is an alias, then it must be configured using the underlying function
83 // ARN, and the alias name as a qualifier.
84 const { targetFunction, alias } = this.instanceOfAlias(props.function)
85 ? { targetFunction: props.function.version.lambda, alias: props.function }
86 : { targetFunction: props.function, alias: undefined };
87 const resource = new lambda_generated_1.CfnUrl(this, 'Resource', {
88 authType: props.authType ?? FunctionUrlAuthType.AWS_IAM,
89 cors: props.cors ? this.renderCors(props.cors) : undefined,
90 targetFunctionArn: targetFunction.functionArn,
91 qualifier: alias?.aliasName,
92 });
93 // The aliasName is a required physical name, so using it does not imply a dependency, so we
94 // must "manually" register the dependency, or else CFN may attempt to use before it exists.
95 if (alias?.node.defaultChild != null) {
96 resource.node.addDependency(alias.node.defaultChild);
97 }
98 this.url = resource.attrFunctionUrl;
99 this.functionArn = resource.attrFunctionArn;
100 this.function = props.function;
101 if (props.authType === FunctionUrlAuthType.NONE) {
102 props.function.addPermission('invoke-function-url', {
103 principal: new iam.AnyPrincipal(),
104 action: 'lambda:InvokeFunctionUrl',
105 functionUrlAuthType: props.authType,
106 });
107 }
108 }
109 grantInvokeUrl(grantee) {
110 return this.function.grantInvokeUrl(grantee);
111 }
112 instanceOfVersion(fn) {
113 return 'version' in fn && !this.instanceOfAlias(fn);
114 }
115 instanceOfAlias(fn) {
116 return 'aliasName' in fn;
117 }
118 renderCors(cors) {
119 return {
120 allowCredentials: cors.allowCredentials,
121 allowHeaders: cors.allowedHeaders,
122 allowMethods: cors.allowedMethods ?? [HttpMethod.ALL],
123 allowOrigins: cors.allowedOrigins,
124 exposeHeaders: cors.exposedHeaders,
125 maxAge: cors.maxAge?.toSeconds(),
126 };
127 }
128}
129exports.FunctionUrl = FunctionUrl;
130_a = JSII_RTTI_SYMBOL_1;
131FunctionUrl[_a] = { fqn: "@aws-cdk/aws-lambda.FunctionUrl", version: "1.190.0" };
132//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"function-url.js","sourceRoot":"","sources":["function-url.ts"],"names":[],"mappings":"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","sourcesContent":["import * as iam from '@aws-cdk/aws-iam';\nimport { Duration, IResource, Resource } from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport { IAlias } from './alias';\nimport { IFunction } from './function-base';\nimport { IVersion } from './lambda-version';\nimport { CfnUrl } from './lambda.generated';\n\n/**\n * The auth types for a function url\n */\nexport enum FunctionUrlAuthType {\n  /**\n   * Restrict access to authenticated IAM users only\n   */\n  AWS_IAM = 'AWS_IAM',\n\n  /**\n   * Bypass IAM authentication to create a public endpoint\n   */\n  NONE = 'NONE',\n}\n\n/**\n * All http request methods\n */\nexport enum HttpMethod {\n  /**\n   * The GET method requests a representation of the specified resource.\n   */\n  GET = 'GET',\n  /**\n   * The PUT method replaces all current representations of the target resource with the request payload.\n   */\n  PUT = 'PUT',\n  /**\n   * The HEAD method asks for a response identical to that of a GET request, but without the response body.\n   */\n  HEAD = 'HEAD',\n  /**\n   * The POST method is used to submit an entity to the specified resource, often causing a change in state or side effects on the server.\n   */\n  POST = 'POST',\n  /**\n   * The DELETE method deletes the specified resource.\n   */\n  DELETE = 'DELETE',\n  /**\n   * The PATCH method applies partial modifications to a resource.\n   */\n  PATCH = 'PATCH',\n  /**\n   * The OPTIONS method describes the communication options for the target resource.\n   */\n  OPTIONS = 'OPTIONS',\n  /**\n   * The wildcard entry to allow all methods.\n   */\n  ALL = '*',\n}\n\n/**\n * Specifies a cross-origin access property for a function URL\n */\nexport interface FunctionUrlCorsOptions {\n  /**\n   * Whether to allow cookies or other credentials in requests to your function URL.\n   *\n   * @default false\n   */\n  readonly allowCredentials?: boolean;\n\n  /**\n   * Headers that are specified in the Access-Control-Request-Headers header.\n   *\n   * @default - No headers allowed.\n   */\n  readonly allowedHeaders?: string[];\n\n  /**\n   * An HTTP method that you allow the origin to execute.\n   *\n   * @default - [HttpMethod.ALL]\n   */\n  readonly allowedMethods?: HttpMethod[];\n\n  /**\n   * One or more origins you want customers to be able to access the bucket from.\n   *\n   * @default - No origins allowed.\n   */\n  readonly allowedOrigins?: string[];\n\n  /**\n   * One or more headers in the response that you want customers to be able to access from their applications.\n   *\n   * @default - No headers exposed.\n   */\n  readonly exposedHeaders?: string[];\n\n  /**\n   * The time in seconds that your browser is to cache the preflight response for the specified resource.\n   *\n   * @default - Browser default of 5 seconds.\n   */\n  readonly maxAge?: Duration;\n}\n\n/**\n * A Lambda function Url\n */\nexport interface IFunctionUrl extends IResource {\n  /**\n   * The url of the Lambda function.\n   *\n   * @attribute FunctionUrl\n   */\n  readonly url: string;\n\n  /**\n   * The ARN of the function this URL refers to\n   *\n   * @attribute FunctionArn\n   */\n  readonly functionArn: string;\n\n  /**\n   * Grant the given identity permissions to invoke this Lambda Function URL\n   */\n  grantInvokeUrl(identity: iam.IGrantable): iam.Grant;\n}\n\n/**\n * Options to add a url to a Lambda function\n */\nexport interface FunctionUrlOptions {\n  /**\n   * The type of authentication that your function URL uses.\n   *\n   * @default FunctionUrlAuthType.AWS_IAM\n   */\n  readonly authType?: FunctionUrlAuthType;\n\n  /**\n   * The cross-origin resource sharing (CORS) settings for your function URL.\n   *\n   * @default - No CORS configuration.\n   */\n  readonly cors?: FunctionUrlCorsOptions;\n}\n\n/**\n * Properties for a FunctionUrl\n */\nexport interface FunctionUrlProps extends FunctionUrlOptions {\n  /**\n   * The function to which this url refers.\n   * It can also be an `Alias` but not a `Version`.\n   */\n  readonly function: IFunction;\n}\n\n/**\n * Defines a Lambda function url\n *\n * @resource AWS::Lambda::Url\n */\nexport class FunctionUrl extends Resource implements IFunctionUrl {\n  /**\n   * The url of the Lambda function.\n   */\n  public readonly url: string;\n\n  /**\n   * The ARN of the function this URL refers to\n   */\n  public readonly functionArn: string;\n\n  private readonly function: IFunction;\n\n  constructor(scope: Construct, id: string, props: FunctionUrlProps) {\n    super(scope, id);\n\n    if (this.instanceOfVersion(props.function)) {\n      throw new Error('FunctionUrl cannot be used with a Version');\n    }\n\n    // If the target function is an alias, then it must be configured using the underlying function\n    // ARN, and the alias name as a qualifier.\n    const { targetFunction, alias } = this.instanceOfAlias(props.function)\n      ? { targetFunction: props.function.version.lambda, alias: props.function }\n      : { targetFunction: props.function, alias: undefined };\n\n    const resource: CfnUrl = new CfnUrl(this, 'Resource', {\n      authType: props.authType ?? FunctionUrlAuthType.AWS_IAM,\n      cors: props.cors ? this.renderCors(props.cors) : undefined,\n      targetFunctionArn: targetFunction.functionArn,\n      qualifier: alias?.aliasName,\n    });\n    // The aliasName is a required physical name, so using it does not imply a dependency, so we\n    // must \"manually\" register the dependency, or else CFN may attempt to use before it exists.\n    if (alias?.node.defaultChild != null) {\n      resource.node.addDependency(alias.node.defaultChild);\n    }\n\n    this.url = resource.attrFunctionUrl;\n    this.functionArn = resource.attrFunctionArn;\n    this.function = props.function;\n\n    if (props.authType === FunctionUrlAuthType.NONE) {\n      props.function.addPermission('invoke-function-url', {\n        principal: new iam.AnyPrincipal(),\n        action: 'lambda:InvokeFunctionUrl',\n        functionUrlAuthType: props.authType,\n      });\n    }\n  }\n\n  public grantInvokeUrl(grantee: iam.IGrantable): iam.Grant {\n    return this.function.grantInvokeUrl(grantee);\n  }\n\n  private instanceOfVersion(fn: IFunction): fn is IVersion {\n    return 'version' in fn && !this.instanceOfAlias(fn);\n  }\n\n  private instanceOfAlias(fn: IFunction): fn is IAlias {\n    return 'aliasName' in fn;\n  }\n\n  private renderCors(cors: FunctionUrlCorsOptions): CfnUrl.CorsProperty {\n    return {\n      allowCredentials: cors.allowCredentials,\n      allowHeaders: cors.allowedHeaders,\n      allowMethods: cors.allowedMethods ?? [HttpMethod.ALL],\n      allowOrigins: cors.allowedOrigins,\n      exposeHeaders: cors.exposedHeaders,\n      maxAge: cors.maxAge?.toSeconds(),\n    };\n  }\n}\n"]}
\No newline at end of file