1 | ;
|
2 | var _a;
|
3 | Object.defineProperty(exports, "__esModule", { value: true });
|
4 | exports.FunctionUrl = exports.HttpMethod = exports.FunctionUrlAuthType = void 0;
|
5 | const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
|
6 | const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
7 | const iam = require("@aws-cdk/aws-iam");
|
8 | const core_1 = require("@aws-cdk/core");
|
9 | const lambda_generated_1 = require("./lambda.generated");
|
10 | /**
|
11 | * The auth types for a function url
|
12 | */
|
13 | var 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 | */
|
27 | var 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 | */
|
67 | class 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 | }
|
129 | exports.FunctionUrl = FunctionUrl;
|
130 | _a = JSII_RTTI_SYMBOL_1;
|
131 | FunctionUrl[_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 |