UNPKG

15.2 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 var _b;
70 super(scope, id);
71 try {
72 jsiiDeprecationWarnings._aws_cdk_aws_lambda_FunctionUrlProps(props);
73 }
74 catch (error) {
75 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
76 Error.captureStackTrace(error, this.constructor);
77 }
78 throw error;
79 }
80 if (this.instanceOfVersion(props.function)) {
81 throw new Error('FunctionUrl cannot be used with a Version');
82 }
83 const resource = new lambda_generated_1.CfnUrl(this, 'Resource', {
84 authType: (_b = props.authType) !== null && _b !== void 0 ? _b : FunctionUrlAuthType.AWS_IAM,
85 targetFunctionArn: props.function.functionArn,
86 cors: props.cors ? this.renderCors(props.cors) : undefined,
87 });
88 this.url = resource.attrFunctionUrl;
89 this.functionArn = resource.attrFunctionArn;
90 this.function = props.function;
91 if (props.authType === FunctionUrlAuthType.NONE) {
92 props.function.addPermission('invoke-function-url', {
93 principal: new iam.AnyPrincipal(),
94 action: 'lambda:InvokeFunctionUrl',
95 functionUrlAuthType: props.authType,
96 });
97 }
98 }
99 grantInvokeUrl(grantee) {
100 return this.function.grantInvokeUrl(grantee);
101 }
102 instanceOfVersion(fn) {
103 return 'version' in fn && !this.instanceOfAlias(fn);
104 }
105 instanceOfAlias(fn) {
106 return 'aliasName' in fn;
107 }
108 renderCors(cors) {
109 var _b, _c;
110 return {
111 allowCredentials: cors.allowCredentials,
112 allowHeaders: cors.allowedHeaders,
113 allowMethods: (_b = cors.allowedMethods) !== null && _b !== void 0 ? _b : [HttpMethod.ALL],
114 allowOrigins: cors.allowedOrigins,
115 exposeHeaders: cors.exposedHeaders,
116 maxAge: (_c = cors.maxAge) === null || _c === void 0 ? void 0 : _c.toSeconds(),
117 };
118 }
119}
120exports.FunctionUrl = FunctionUrl;
121_a = JSII_RTTI_SYMBOL_1;
122FunctionUrl[_a] = { fqn: "@aws-cdk/aws-lambda.FunctionUrl", version: "1.154.0" };
123//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"function-url.js","sourceRoot":"","sources":["function-url.ts"],"names":[],"mappings":";;;;;;AAAA,wCAAwC;AACxC,wCAA8D;AAK9D,yDAA4C;AAE5C;;GAEG;AACH,IAAY,mBAUX;AAVD,WAAY,mBAAmB;IAC7B;;OAEG;IACH,0CAAmB,CAAA;IAEnB;;OAEG;IACH,oCAAa,CAAA;AACf,CAAC,EAVW,mBAAmB,GAAnB,2BAAmB,KAAnB,2BAAmB,QAU9B;AAED;;GAEG;AACH,IAAY,UAiCX;AAjCD,WAAY,UAAU;IACpB;;OAEG;IACH,yBAAW,CAAA;IACX;;OAEG;IACH,yBAAW,CAAA;IACX;;OAEG;IACH,2BAAa,CAAA;IACb;;OAEG;IACH,2BAAa,CAAA;IACb;;OAEG;IACH,+BAAiB,CAAA;IACjB;;OAEG;IACH,6BAAe,CAAA;IACf;;OAEG;IACH,iCAAmB,CAAA;IACnB;;OAEG;IACH,uBAAS,CAAA;AACX,CAAC,EAjCW,UAAU,GAAV,kBAAU,KAAV,kBAAU,QAiCrB;AAuGD;;;;GAIG;AACH,MAAa,WAAY,SAAQ,eAAQ;IAavC,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAuB;;QAC/D,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;;;;;;;;;;QAEjB,IAAI,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE;YAC1C,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAC;SAC9D;QAED,MAAM,QAAQ,GAAW,IAAI,yBAAM,CAAC,IAAI,EAAE,UAAU,EAAE;YACpD,QAAQ,QAAE,KAAK,CAAC,QAAQ,mCAAI,mBAAmB,CAAC,OAAO;YACvD,iBAAiB,EAAE,KAAK,CAAC,QAAQ,CAAC,WAAW;YAC7C,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,SAAS;SAC3D,CAAC,CAAC;QAEH,IAAI,CAAC,GAAG,GAAG,QAAQ,CAAC,eAAe,CAAC;QACpC,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC,eAAe,CAAC;QAC5C,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC;QAE/B,IAAI,KAAK,CAAC,QAAQ,KAAK,mBAAmB,CAAC,IAAI,EAAE;YAC/C,KAAK,CAAC,QAAQ,CAAC,aAAa,CAAC,qBAAqB,EAAE;gBAClD,SAAS,EAAE,IAAI,GAAG,CAAC,YAAY,EAAE;gBACjC,MAAM,EAAE,0BAA0B;gBAClC,mBAAmB,EAAE,KAAK,CAAC,QAAQ;aACpC,CAAC,CAAC;SACJ;KACF;IAEM,cAAc,CAAC,OAAuB;QAC3C,OAAO,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;KAC9C;IAEO,iBAAiB,CAAC,EAAa;QACrC,OAAO,SAAS,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,EAAE,CAAC,CAAC;KACrD;IAEO,eAAe,CAAC,EAAa;QACnC,OAAO,WAAW,IAAI,EAAE,CAAC;KAC1B;IAEO,UAAU,CAAC,IAA4B;;QAC7C,OAAO;YACL,gBAAgB,EAAE,IAAI,CAAC,gBAAgB;YACvC,YAAY,EAAE,IAAI,CAAC,cAAc;YACjC,YAAY,QAAE,IAAI,CAAC,cAAc,mCAAI,CAAC,UAAU,CAAC,GAAG,CAAC;YACrD,YAAY,EAAE,IAAI,CAAC,cAAc;YACjC,aAAa,EAAE,IAAI,CAAC,cAAc;YAClC,MAAM,QAAE,IAAI,CAAC,MAAM,0CAAE,SAAS,EAAE;SACjC,CAAC;KACH;;AA5DH,kCA6DC","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    const resource: CfnUrl = new CfnUrl(this, 'Resource', {\n      authType: props.authType ?? FunctionUrlAuthType.AWS_IAM,\n      targetFunctionArn: props.function.functionArn,\n      cors: props.cors ? this.renderCors(props.cors) : undefined,\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