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 | 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 | }
|
120 | exports.FunctionUrl = FunctionUrl;
|
121 | _a = JSII_RTTI_SYMBOL_1;
|
122 | FunctionUrl[_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 |