eoapi-cdk 8.3.2 → 9.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.jsii +546 -194
- package/lib/bastion-host/index.js +1 -1
- package/lib/database/index.js +1 -1
- package/lib/ingestor-api/index.js +1 -1
- package/lib/lambda-api-gateway/index.d.ts +23 -0
- package/lib/lambda-api-gateway/index.js +24 -0
- package/lib/stac-api/index.d.ts +35 -10
- package/lib/stac-api/index.js +32 -21
- package/lib/stac-browser/index.js +1 -1
- package/lib/stac-loader/index.js +2 -2
- package/lib/stactools-item-generator/index.js +1 -1
- package/lib/stactools-item-generator/runtime/Dockerfile +2 -1
- package/lib/stactools-item-generator/runtime/src/stactools_item_generator/item.py +1 -1
- package/lib/tipg-api/index.d.ts +34 -11
- package/lib/tipg-api/index.js +34 -24
- package/lib/titiler-pgstac-api/index.d.ts +34 -11
- package/lib/titiler-pgstac-api/index.js +54 -39
- package/package.json +1 -1
package/lib/tipg-api/index.d.ts
CHANGED
|
@@ -1,12 +1,11 @@
|
|
|
1
1
|
import { aws_apigatewayv2 as apigatewayv2, aws_ec2 as ec2, aws_lambda as lambda, aws_rds as rds, aws_secretsmanager as secretsmanager } from "aws-cdk-lib";
|
|
2
2
|
import { Construct } from "constructs";
|
|
3
3
|
import { CustomLambdaFunctionProps } from "../utils";
|
|
4
|
-
export declare class
|
|
5
|
-
readonly
|
|
6
|
-
|
|
7
|
-
constructor(scope: Construct, id: string, props: TiPgApiLambdaProps);
|
|
4
|
+
export declare class TiPgApiLambdaRuntime extends Construct {
|
|
5
|
+
readonly lambdaFunction: lambda.Function;
|
|
6
|
+
constructor(scope: Construct, id: string, props: TiPgApiLambdaRuntimeProps);
|
|
8
7
|
}
|
|
9
|
-
export interface
|
|
8
|
+
export interface TiPgApiLambdaRuntimeProps {
|
|
10
9
|
/**
|
|
11
10
|
* VPC into which the lambda should be deployed.
|
|
12
11
|
*/
|
|
@@ -28,16 +27,40 @@ export interface TiPgApiLambdaProps {
|
|
|
28
27
|
*/
|
|
29
28
|
readonly apiEnv?: Record<string, string>;
|
|
30
29
|
/**
|
|
31
|
-
*
|
|
32
|
-
*
|
|
30
|
+
* Can be used to override the default lambda function properties.
|
|
31
|
+
*
|
|
32
|
+
* @default - defined in the construct.
|
|
33
|
+
*/
|
|
34
|
+
readonly lambdaFunctionOptions?: CustomLambdaFunctionProps;
|
|
35
|
+
}
|
|
36
|
+
export declare class TiPgApiLambda extends Construct {
|
|
37
|
+
/**
|
|
38
|
+
* URL for the TiPg API.
|
|
39
|
+
*/
|
|
40
|
+
readonly url: string;
|
|
41
|
+
/**
|
|
42
|
+
* Lambda function for the TiPg API.
|
|
43
|
+
*/
|
|
44
|
+
readonly lambdaFunction: lambda.Function;
|
|
45
|
+
/**
|
|
46
|
+
* @deprecated - use lambdaFunction instead
|
|
47
|
+
*/
|
|
48
|
+
tiPgLambdaFunction: lambda.Function;
|
|
49
|
+
constructor(scope: Construct, id: string, props: TiPgApiLambdaProps);
|
|
50
|
+
}
|
|
51
|
+
export interface TiPgApiLambdaProps extends TiPgApiLambdaRuntimeProps {
|
|
52
|
+
/**
|
|
53
|
+
* Domain Name for the TiPg API. If defined, will create the domain name and integrate it with the TiPg API.
|
|
33
54
|
*
|
|
34
55
|
* @default - undefined
|
|
35
56
|
*/
|
|
36
|
-
readonly
|
|
57
|
+
readonly domainName?: apigatewayv2.IDomainName;
|
|
37
58
|
/**
|
|
38
|
-
*
|
|
59
|
+
* Custom Domain Name for tipg API. If defined, will create the
|
|
60
|
+
* domain name and integrate it with the tipg API.
|
|
39
61
|
*
|
|
40
|
-
* @
|
|
62
|
+
* @deprecated Use 'domainName' instead.
|
|
63
|
+
* @default - undefined
|
|
41
64
|
*/
|
|
42
|
-
readonly
|
|
65
|
+
readonly tipgApiDomainName?: apigatewayv2.IDomainName;
|
|
43
66
|
}
|
package/lib/tipg-api/index.js
CHANGED
|
@@ -1,24 +1,25 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var _a;
|
|
2
|
+
var _a, _b;
|
|
3
3
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
-
exports.TiPgApiLambda = void 0;
|
|
4
|
+
exports.TiPgApiLambda = exports.TiPgApiLambdaRuntime = void 0;
|
|
5
5
|
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
6
|
const aws_cdk_lib_1 = require("aws-cdk-lib");
|
|
7
7
|
const constructs_1 = require("constructs");
|
|
8
|
+
const lambda_api_gateway_1 = require("../lambda-api-gateway");
|
|
8
9
|
const path = require("path");
|
|
9
|
-
class
|
|
10
|
+
class TiPgApiLambdaRuntime extends constructs_1.Construct {
|
|
10
11
|
constructor(scope, id, props) {
|
|
11
12
|
super(scope, id);
|
|
12
|
-
this.
|
|
13
|
+
this.lambdaFunction = new aws_cdk_lib_1.aws_lambda.Function(this, "lambda", {
|
|
13
14
|
// defaults
|
|
14
15
|
runtime: aws_cdk_lib_1.aws_lambda.Runtime.PYTHON_3_11,
|
|
15
16
|
handler: "handler.handler",
|
|
16
17
|
memorySize: 1024,
|
|
17
18
|
logRetention: aws_cdk_lib_1.aws_logs.RetentionDays.ONE_WEEK,
|
|
18
19
|
timeout: aws_cdk_lib_1.Duration.seconds(30),
|
|
19
|
-
code: aws_cdk_lib_1.aws_lambda.Code.fromDockerBuild(path.join(__dirname,
|
|
20
|
+
code: aws_cdk_lib_1.aws_lambda.Code.fromDockerBuild(path.join(__dirname, ".."), {
|
|
20
21
|
file: "tipg-api/runtime/Dockerfile",
|
|
21
|
-
buildArgs: { PYTHON_VERSION:
|
|
22
|
+
buildArgs: { PYTHON_VERSION: "3.11" },
|
|
22
23
|
}),
|
|
23
24
|
vpc: props.vpc,
|
|
24
25
|
vpcSubnets: props.subnetSelection,
|
|
@@ -30,25 +31,34 @@ class TiPgApiLambda extends constructs_1.Construct {
|
|
|
30
31
|
...props.apiEnv,
|
|
31
32
|
},
|
|
32
33
|
// overwrites defaults with user-provided configurable properties
|
|
33
|
-
...props.lambdaFunctionOptions
|
|
34
|
+
...props.lambdaFunctionOptions,
|
|
34
35
|
});
|
|
35
|
-
props.dbSecret.grantRead(this.
|
|
36
|
+
props.dbSecret.grantRead(this.lambdaFunction);
|
|
36
37
|
if (props.vpc) {
|
|
37
|
-
this.
|
|
38
|
+
this.lambdaFunction.connections.allowTo(props.db, aws_cdk_lib_1.aws_ec2.Port.tcp(5432), "allow connections from tipg");
|
|
38
39
|
}
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
exports.TiPgApiLambdaRuntime = TiPgApiLambdaRuntime;
|
|
43
|
+
_a = JSII_RTTI_SYMBOL_1;
|
|
44
|
+
TiPgApiLambdaRuntime[_a] = { fqn: "eoapi-cdk.TiPgApiLambdaRuntime", version: "9.0.0" };
|
|
45
|
+
class TiPgApiLambda extends constructs_1.Construct {
|
|
46
|
+
constructor(scope, id, props) {
|
|
47
|
+
super(scope, id);
|
|
48
|
+
const runtime = new TiPgApiLambdaRuntime(this, "runtime", {
|
|
49
|
+
vpc: props.vpc,
|
|
50
|
+
subnetSelection: props.subnetSelection,
|
|
51
|
+
db: props.db,
|
|
52
|
+
dbSecret: props.dbSecret,
|
|
53
|
+
apiEnv: props.apiEnv,
|
|
54
|
+
lambdaFunctionOptions: props.lambdaFunctionOptions,
|
|
50
55
|
});
|
|
51
|
-
this.
|
|
56
|
+
this.tiPgLambdaFunction = this.lambdaFunction = runtime.lambdaFunction;
|
|
57
|
+
const { api } = new lambda_api_gateway_1.LambdaApiGateway(this, "api", {
|
|
58
|
+
lambdaFunction: runtime.lambdaFunction,
|
|
59
|
+
domainName: props.domainName ?? props.tipgApiDomainName,
|
|
60
|
+
});
|
|
61
|
+
this.url = api.url;
|
|
52
62
|
new aws_cdk_lib_1.CfnOutput(this, "tipg-api-output", {
|
|
53
63
|
exportName: `${aws_cdk_lib_1.Stack.of(this).stackName}-tip-url`,
|
|
54
64
|
value: this.url,
|
|
@@ -56,6 +66,6 @@ class TiPgApiLambda extends constructs_1.Construct {
|
|
|
56
66
|
}
|
|
57
67
|
}
|
|
58
68
|
exports.TiPgApiLambda = TiPgApiLambda;
|
|
59
|
-
|
|
60
|
-
TiPgApiLambda[
|
|
61
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
69
|
+
_b = JSII_RTTI_SYMBOL_1;
|
|
70
|
+
TiPgApiLambda[_b] = { fqn: "eoapi-cdk.TiPgApiLambda", version: "9.0.0" };
|
|
71
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":";;;;;AAAA,6CAUqB;AACrB,2CAAuC;AAEvC,8DAAyD;AACzD,6BAA6B;AAE7B,MAAa,oBAAqB,SAAQ,sBAAS;IAGjD,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAgC;QACxE,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,IAAI,CAAC,cAAc,GAAG,IAAI,wBAAM,CAAC,QAAQ,CAAC,IAAI,EAAE,QAAQ,EAAE;YACxD,WAAW;YACX,OAAO,EAAE,wBAAM,CAAC,OAAO,CAAC,WAAW;YACnC,OAAO,EAAE,iBAAiB;YAC1B,UAAU,EAAE,IAAI;YAChB,YAAY,EAAE,sBAAI,CAAC,aAAa,CAAC,QAAQ;YACzC,OAAO,EAAE,sBAAQ,CAAC,OAAO,CAAC,EAAE,CAAC;YAC7B,IAAI,EAAE,wBAAM,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,EAAE;gBAC5D,IAAI,EAAE,6BAA6B;gBACnC,SAAS,EAAE,EAAE,cAAc,EAAE,MAAM,EAAE;aACtC,CAAC;YACF,GAAG,EAAE,KAAK,CAAC,GAAG;YACd,UAAU,EAAE,KAAK,CAAC,eAAe;YACjC,iBAAiB,EAAE,IAAI;YACvB,WAAW,EAAE;gBACX,iBAAiB,EAAE,KAAK,CAAC,QAAQ,CAAC,SAAS;gBAC3C,gBAAgB,EAAE,GAAG;gBACrB,gBAAgB,EAAE,GAAG;gBACrB,GAAG,KAAK,CAAC,MAAM;aAChB;YACD,iEAAiE;YACjE,GAAG,KAAK,CAAC,qBAAqB;SAC/B,CAAC,CAAC;QAEH,KAAK,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QAE9C,IAAI,KAAK,CAAC,GAAG,EAAE,CAAC;YACd,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,OAAO,CACrC,KAAK,CAAC,EAAE,EACR,qBAAG,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,EAClB,6BAA6B,CAC9B,CAAC;QACJ,CAAC;IACH,CAAC;;AAvCH,oDAwCC;;;AAoCD,MAAa,aAAc,SAAQ,sBAAS;IAgB1C,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAyB;QACjE,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,MAAM,OAAO,GAAG,IAAI,oBAAoB,CAAC,IAAI,EAAE,SAAS,EAAE;YACxD,GAAG,EAAE,KAAK,CAAC,GAAG;YACd,eAAe,EAAE,KAAK,CAAC,eAAe;YACtC,EAAE,EAAE,KAAK,CAAC,EAAE;YACZ,QAAQ,EAAE,KAAK,CAAC,QAAQ;YACxB,MAAM,EAAE,KAAK,CAAC,MAAM;YACpB,qBAAqB,EAAE,KAAK,CAAC,qBAAqB;SACnD,CAAC,CAAC;QACH,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,cAAc,GAAG,OAAO,CAAC,cAAc,CAAC;QAEvE,MAAM,EAAE,GAAG,EAAE,GAAG,IAAI,qCAAgB,CAAC,IAAI,EAAE,KAAK,EAAE;YAChD,cAAc,EAAE,OAAO,CAAC,cAAc;YACtC,UAAU,EAAE,KAAK,CAAC,UAAU,IAAI,KAAK,CAAC,iBAAiB;SACxD,CAAC,CAAC;QAEH,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC,GAAI,CAAC;QAEpB,IAAI,uBAAS,CAAC,IAAI,EAAE,iBAAiB,EAAE;YACrC,UAAU,EAAE,GAAG,mBAAK,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,SAAS,UAAU;YACjD,KAAK,EAAE,IAAI,CAAC,GAAG;SAChB,CAAC,CAAC;IACL,CAAC;;AAxCH,sCAyCC","sourcesContent":["import {\n  aws_apigatewayv2 as apigatewayv2,\n  aws_ec2 as ec2,\n  aws_lambda as lambda,\n  aws_logs as logs,\n  aws_rds as rds,\n  aws_secretsmanager as secretsmanager,\n  Duration,\n  Stack,\n  CfnOutput,\n} from \"aws-cdk-lib\";\nimport { Construct } from \"constructs\";\nimport { CustomLambdaFunctionProps } from \"../utils\";\nimport { LambdaApiGateway } from \"../lambda-api-gateway\";\nimport * as path from \"path\";\n\nexport class TiPgApiLambdaRuntime extends Construct {\n  public readonly lambdaFunction: lambda.Function;\n\n  constructor(scope: Construct, id: string, props: TiPgApiLambdaRuntimeProps) {\n    super(scope, id);\n\n    this.lambdaFunction = new lambda.Function(this, \"lambda\", {\n      // defaults\n      runtime: lambda.Runtime.PYTHON_3_11,\n      handler: \"handler.handler\",\n      memorySize: 1024,\n      logRetention: logs.RetentionDays.ONE_WEEK,\n      timeout: Duration.seconds(30),\n      code: lambda.Code.fromDockerBuild(path.join(__dirname, \"..\"), {\n        file: \"tipg-api/runtime/Dockerfile\",\n        buildArgs: { PYTHON_VERSION: \"3.11\" },\n      }),\n      vpc: props.vpc,\n      vpcSubnets: props.subnetSelection,\n      allowPublicSubnet: true,\n      environment: {\n        PGSTAC_SECRET_ARN: props.dbSecret.secretArn,\n        DB_MIN_CONN_SIZE: \"1\",\n        DB_MAX_CONN_SIZE: \"1\",\n        ...props.apiEnv,\n      },\n      // overwrites defaults with user-provided configurable properties\n      ...props.lambdaFunctionOptions,\n    });\n\n    props.dbSecret.grantRead(this.lambdaFunction);\n\n    if (props.vpc) {\n      this.lambdaFunction.connections.allowTo(\n        props.db,\n        ec2.Port.tcp(5432),\n        \"allow connections from tipg\"\n      );\n    }\n  }\n}\n\nexport interface TiPgApiLambdaRuntimeProps {\n  /**\n   * VPC into which the lambda should be deployed.\n   */\n  readonly vpc?: ec2.IVpc;\n\n  /**\n   * RDS Instance with installed pgSTAC or pgbouncer server.\n   */\n  readonly db: rds.IDatabaseInstance | ec2.IInstance;\n\n  /**\n   * Subnet into which the lambda should be deployed.\n   */\n  readonly subnetSelection?: ec2.SubnetSelection;\n\n  /**\n   * Secret containing connection information for pgSTAC database.\n   */\n  readonly dbSecret: secretsmanager.ISecret;\n\n  /**\n   * Customized environment variables to send to titiler-pgstac runtime.\n   */\n  readonly apiEnv?: Record<string, string>;\n\n  /**\n   * Can be used to override the default lambda function properties.\n   *\n   * @default - defined in the construct.\n   */\n  readonly lambdaFunctionOptions?: CustomLambdaFunctionProps;\n}\n\nexport class TiPgApiLambda extends Construct {\n  /**\n   * URL for the TiPg API.\n   */\n  readonly url: string;\n\n  /**\n   * Lambda function for the TiPg API.\n   */\n  readonly lambdaFunction: lambda.Function;\n\n  /**\n   * @deprecated - use lambdaFunction instead\n   */\n  public tiPgLambdaFunction: lambda.Function;\n\n  constructor(scope: Construct, id: string, props: TiPgApiLambdaProps) {\n    super(scope, id);\n\n    const runtime = new TiPgApiLambdaRuntime(this, \"runtime\", {\n      vpc: props.vpc,\n      subnetSelection: props.subnetSelection,\n      db: props.db,\n      dbSecret: props.dbSecret,\n      apiEnv: props.apiEnv,\n      lambdaFunctionOptions: props.lambdaFunctionOptions,\n    });\n    this.tiPgLambdaFunction = this.lambdaFunction = runtime.lambdaFunction;\n\n    const { api } = new LambdaApiGateway(this, \"api\", {\n      lambdaFunction: runtime.lambdaFunction,\n      domainName: props.domainName ?? props.tipgApiDomainName,\n    });\n\n    this.url = api.url!;\n\n    new CfnOutput(this, \"tipg-api-output\", {\n      exportName: `${Stack.of(this).stackName}-tip-url`,\n      value: this.url,\n    });\n  }\n}\n\nexport interface TiPgApiLambdaProps extends TiPgApiLambdaRuntimeProps {\n  /**\n   * Domain Name for the TiPg API. If defined, will create the domain name and integrate it with the TiPg API.\n   *\n   * @default - undefined\n   */\n  readonly domainName?: apigatewayv2.IDomainName;\n\n  /**\n   * Custom Domain Name for tipg API. If defined, will create the\n   * domain name and integrate it with the tipg API.\n   *\n   * @deprecated Use 'domainName' instead.\n   * @default - undefined\n   */\n  readonly tipgApiDomainName?: apigatewayv2.IDomainName;\n}\n"]}
|
|
@@ -1,12 +1,11 @@
|
|
|
1
1
|
import { aws_apigatewayv2 as apigatewayv2, aws_ec2 as ec2, aws_rds as rds, aws_lambda as lambda, aws_secretsmanager as secretsmanager } from "aws-cdk-lib";
|
|
2
2
|
import { Construct } from "constructs";
|
|
3
3
|
import { CustomLambdaFunctionProps } from "../utils";
|
|
4
|
-
export declare class
|
|
5
|
-
readonly
|
|
6
|
-
|
|
7
|
-
constructor(scope: Construct, id: string, props: TitilerPgStacApiLambdaProps);
|
|
4
|
+
export declare class TitilerPgstacApiLambdaRuntime extends Construct {
|
|
5
|
+
readonly lambdaFunction: lambda.Function;
|
|
6
|
+
constructor(scope: Construct, id: string, props: TitilerPgstacApiLambdaRuntimeProps);
|
|
8
7
|
}
|
|
9
|
-
export interface
|
|
8
|
+
export interface TitilerPgstacApiLambdaRuntimeProps {
|
|
10
9
|
/**
|
|
11
10
|
* VPC into which the lambda should be deployed.
|
|
12
11
|
*/
|
|
@@ -26,22 +25,46 @@ export interface TitilerPgStacApiLambdaProps {
|
|
|
26
25
|
/**
|
|
27
26
|
* Customized environment variables to send to titiler-pgstac runtime. These will be merged with `defaultTitilerPgstacEnv`.
|
|
28
27
|
* The database secret arn is automatically added to the environment variables at deployment.
|
|
29
|
-
|
|
28
|
+
*/
|
|
30
29
|
readonly apiEnv?: Record<string, string>;
|
|
31
30
|
/**
|
|
32
31
|
* list of buckets the lambda will be granted access to.
|
|
33
32
|
*/
|
|
34
33
|
readonly buckets?: string[];
|
|
35
34
|
/**
|
|
36
|
-
*
|
|
35
|
+
* Can be used to override the default lambda function properties.
|
|
36
|
+
*
|
|
37
|
+
* @default - defined in the construct.
|
|
38
|
+
*/
|
|
39
|
+
readonly lambdaFunctionOptions?: CustomLambdaFunctionProps;
|
|
40
|
+
}
|
|
41
|
+
export declare class TitilerPgstacApiLambda extends Construct {
|
|
42
|
+
/**
|
|
43
|
+
* URL for the Titiler Pgstac API.
|
|
44
|
+
*/
|
|
45
|
+
readonly url: string;
|
|
46
|
+
/**
|
|
47
|
+
* Lambda function for the Titiler Pgstac API.
|
|
48
|
+
*/
|
|
49
|
+
readonly lambdaFunction: lambda.Function;
|
|
50
|
+
/**
|
|
51
|
+
* @deprecated - use lambdaFunction instead
|
|
52
|
+
*/
|
|
53
|
+
titilerPgstacLambdaFunction: lambda.Function;
|
|
54
|
+
constructor(scope: Construct, id: string, props: TitilerPgstacApiLambdaProps);
|
|
55
|
+
}
|
|
56
|
+
export interface TitilerPgstacApiLambdaProps extends TitilerPgstacApiLambdaRuntimeProps {
|
|
57
|
+
/**
|
|
58
|
+
* Domain Name for the Titiler Pgstac API. If defined, will create the domain name and integrate it with the Titiler Pgstac API.
|
|
37
59
|
*
|
|
38
60
|
* @default - undefined.
|
|
39
61
|
*/
|
|
40
|
-
readonly
|
|
62
|
+
readonly domainName?: apigatewayv2.IDomainName;
|
|
41
63
|
/**
|
|
42
|
-
*
|
|
64
|
+
* Custom Domain Name Options for Titiler Pgstac API,
|
|
43
65
|
*
|
|
44
|
-
* @
|
|
66
|
+
* @deprecated Use 'domainName' instead.
|
|
67
|
+
* @default - undefined.
|
|
45
68
|
*/
|
|
46
|
-
readonly
|
|
69
|
+
readonly titilerPgstacApiDomainName?: apigatewayv2.IDomainName;
|
|
47
70
|
}
|
|
@@ -1,74 +1,89 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var _a;
|
|
2
|
+
var _a, _b;
|
|
3
3
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
-
exports.TitilerPgstacApiLambda = void 0;
|
|
4
|
+
exports.TitilerPgstacApiLambda = exports.TitilerPgstacApiLambdaRuntime = void 0;
|
|
5
5
|
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
6
|
const aws_cdk_lib_1 = require("aws-cdk-lib");
|
|
7
7
|
const constructs_1 = require("constructs");
|
|
8
|
+
const lambda_api_gateway_1 = require("../lambda-api-gateway");
|
|
8
9
|
const path = require("path");
|
|
9
10
|
// default settings that can be overridden by the user-provided environment.
|
|
10
11
|
let defaultTitilerPgstacEnv = {
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
12
|
+
CPL_VSIL_CURL_ALLOWED_EXTENSIONS: ".tif,.TIF,.tiff",
|
|
13
|
+
GDAL_CACHEMAX: "200",
|
|
14
|
+
GDAL_DISABLE_READDIR_ON_OPEN: "EMPTY_DIR",
|
|
15
|
+
GDAL_INGESTED_BYTES_AT_OPEN: "32768",
|
|
16
|
+
GDAL_HTTP_MERGE_CONSECUTIVE_RANGES: "YES",
|
|
17
|
+
GDAL_HTTP_MULTIPLEX: "YES",
|
|
18
|
+
GDAL_HTTP_VERSION: "2",
|
|
19
|
+
PYTHONWARNINGS: "ignore",
|
|
20
|
+
VSI_CACHE: "TRUE",
|
|
21
|
+
VSI_CACHE_SIZE: "5000000",
|
|
22
|
+
DB_MIN_CONN_SIZE: "1",
|
|
23
|
+
DB_MAX_CONN_SIZE: "1",
|
|
23
24
|
};
|
|
24
|
-
class
|
|
25
|
+
class TitilerPgstacApiLambdaRuntime extends constructs_1.Construct {
|
|
25
26
|
constructor(scope, id, props) {
|
|
26
27
|
super(scope, id);
|
|
27
|
-
this.
|
|
28
|
+
this.lambdaFunction = new aws_cdk_lib_1.aws_lambda.Function(this, "lambda", {
|
|
28
29
|
// defaults
|
|
29
30
|
runtime: aws_cdk_lib_1.aws_lambda.Runtime.PYTHON_3_11,
|
|
30
31
|
handler: "handler.handler",
|
|
31
32
|
memorySize: 3008,
|
|
32
33
|
logRetention: aws_cdk_lib_1.aws_logs.RetentionDays.ONE_WEEK,
|
|
33
34
|
timeout: aws_cdk_lib_1.Duration.seconds(30),
|
|
34
|
-
code: aws_cdk_lib_1.aws_lambda.Code.fromDockerBuild(path.join(__dirname,
|
|
35
|
+
code: aws_cdk_lib_1.aws_lambda.Code.fromDockerBuild(path.join(__dirname, ".."), {
|
|
35
36
|
file: "titiler-pgstac-api/runtime/Dockerfile",
|
|
36
|
-
buildArgs: { PYTHON_VERSION:
|
|
37
|
+
buildArgs: { PYTHON_VERSION: "3.11" },
|
|
37
38
|
}),
|
|
38
39
|
vpc: props.vpc,
|
|
39
40
|
vpcSubnets: props.subnetSelection,
|
|
40
41
|
allowPublicSubnet: true,
|
|
41
|
-
|
|
42
|
-
|
|
42
|
+
environment: {
|
|
43
|
+
...defaultTitilerPgstacEnv,
|
|
44
|
+
...props.apiEnv, // if user provided environment variables, merge them with the defaults.
|
|
45
|
+
PGSTAC_SECRET_ARN: props.dbSecret.secretArn,
|
|
46
|
+
},
|
|
43
47
|
// overwrites defaults with user-provided configurable properties
|
|
44
48
|
...props.lambdaFunctionOptions,
|
|
45
49
|
});
|
|
46
50
|
// grant access to buckets using addToRolePolicy
|
|
47
51
|
if (props.buckets) {
|
|
48
|
-
props.buckets.forEach(bucket => {
|
|
49
|
-
this.
|
|
52
|
+
props.buckets.forEach((bucket) => {
|
|
53
|
+
this.lambdaFunction.addToRolePolicy(new aws_cdk_lib_1.aws_iam.PolicyStatement({
|
|
50
54
|
actions: ["s3:GetObject"],
|
|
51
55
|
resources: [`arn:aws:s3:::${bucket}/*`],
|
|
52
56
|
}));
|
|
53
57
|
});
|
|
54
58
|
}
|
|
55
|
-
props.dbSecret.grantRead(this.
|
|
59
|
+
props.dbSecret.grantRead(this.lambdaFunction);
|
|
56
60
|
if (props.vpc) {
|
|
57
|
-
this.
|
|
61
|
+
this.lambdaFunction.connections.allowTo(props.db, aws_cdk_lib_1.aws_ec2.Port.tcp(5432), "allow connections from titiler");
|
|
58
62
|
}
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
exports.TitilerPgstacApiLambdaRuntime = TitilerPgstacApiLambdaRuntime;
|
|
66
|
+
_a = JSII_RTTI_SYMBOL_1;
|
|
67
|
+
TitilerPgstacApiLambdaRuntime[_a] = { fqn: "eoapi-cdk.TitilerPgstacApiLambdaRuntime", version: "9.0.0" };
|
|
68
|
+
class TitilerPgstacApiLambda extends constructs_1.Construct {
|
|
69
|
+
constructor(scope, id, props) {
|
|
70
|
+
super(scope, id);
|
|
71
|
+
const runtime = new TitilerPgstacApiLambdaRuntime(this, "runtime", {
|
|
72
|
+
vpc: props.vpc,
|
|
73
|
+
subnetSelection: props.subnetSelection,
|
|
74
|
+
db: props.db,
|
|
75
|
+
dbSecret: props.dbSecret,
|
|
76
|
+
apiEnv: props.apiEnv,
|
|
77
|
+
buckets: props.buckets,
|
|
78
|
+
lambdaFunctionOptions: props.lambdaFunctionOptions,
|
|
70
79
|
});
|
|
71
|
-
this.
|
|
80
|
+
this.titilerPgstacLambdaFunction = this.lambdaFunction =
|
|
81
|
+
runtime.lambdaFunction;
|
|
82
|
+
const { api } = new lambda_api_gateway_1.LambdaApiGateway(this, "titlier-pgstac-api", {
|
|
83
|
+
lambdaFunction: runtime.lambdaFunction,
|
|
84
|
+
domainName: props.domainName ?? props.titilerPgstacApiDomainName,
|
|
85
|
+
});
|
|
86
|
+
this.url = api.url;
|
|
72
87
|
new aws_cdk_lib_1.CfnOutput(this, "titiler-pgstac-api-output", {
|
|
73
88
|
exportName: `${aws_cdk_lib_1.Stack.of(this).stackName}-titiler-pgstac-url`,
|
|
74
89
|
value: this.url,
|
|
@@ -76,6 +91,6 @@ class TitilerPgstacApiLambda extends constructs_1.Construct {
|
|
|
76
91
|
}
|
|
77
92
|
}
|
|
78
93
|
exports.TitilerPgstacApiLambda = TitilerPgstacApiLambda;
|
|
79
|
-
|
|
80
|
-
TitilerPgstacApiLambda[
|
|
81
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Stack,\n  aws_apigatewayv2 as apigatewayv2,\n  aws_apigatewayv2_integrations as apigatewayv2_integrations,\n  aws_iam as iam,\n  aws_ec2 as ec2,\n  aws_rds as rds,\n  aws_lambda as lambda,\n  aws_secretsmanager as secretsmanager,\n  CfnOutput,\n  Duration,\n  aws_logs,\n} from \"aws-cdk-lib\";\nimport { Construct } from \"constructs\";\nimport { CustomLambdaFunctionProps } from \"../utils\";\nimport * as path from 'path';\n\n  // default settings that can be overridden by the user-provided environment.\n  let defaultTitilerPgstacEnv :{ [key: string]: any } = {\n    \"CPL_VSIL_CURL_ALLOWED_EXTENSIONS\": \".tif,.TIF,.tiff\",\n    \"GDAL_CACHEMAX\": \"200\",\n    \"GDAL_DISABLE_READDIR_ON_OPEN\": \"EMPTY_DIR\",\n    \"GDAL_INGESTED_BYTES_AT_OPEN\": \"32768\",\n    \"GDAL_HTTP_MERGE_CONSECUTIVE_RANGES\": \"YES\",\n    \"GDAL_HTTP_MULTIPLEX\": \"YES\",\n    \"GDAL_HTTP_VERSION\": \"2\",\n    \"PYTHONWARNINGS\": \"ignore\",\n    \"VSI_CACHE\": \"TRUE\",\n    \"VSI_CACHE_SIZE\": \"5000000\",\n    \"DB_MIN_CONN_SIZE\": \"1\",\n    \"DB_MAX_CONN_SIZE\": \"1\"\n  }\n\n  export class TitilerPgstacApiLambda extends Construct {\n    readonly url: string;\n    public titilerPgstacLambdaFunction: lambda.Function;\n\n    constructor(scope: Construct, id: string, props: TitilerPgStacApiLambdaProps) {\n      super(scope, id);\n\n      this.titilerPgstacLambdaFunction = new lambda.Function(this, \"lambda\", {\n        // defaults\n        runtime: lambda.Runtime.PYTHON_3_11,\n        handler: \"handler.handler\",\n        memorySize: 3008,\n        logRetention: aws_logs.RetentionDays.ONE_WEEK,\n        timeout: Duration.seconds(30),\n        code: lambda.Code.fromDockerBuild(path.join(__dirname, '..'), {\n          file: \"titiler-pgstac-api/runtime/Dockerfile\",\n          buildArgs: { PYTHON_VERSION: '3.11' }\n        }),\n        vpc: props.vpc,\n        vpcSubnets: props.subnetSelection,\n        allowPublicSubnet: true,\n        // if user provided environment variables, merge them with the defaults.\n        environment: props.apiEnv ? { ...defaultTitilerPgstacEnv, ...props.apiEnv, \"PGSTAC_SECRET_ARN\": props.dbSecret.secretArn } : defaultTitilerPgstacEnv,\n        // overwrites defaults with user-provided configurable properties\n        ...props.lambdaFunctionOptions,\n      });\n\n      // grant access to buckets using addToRolePolicy\n      if (props.buckets) {\n        props.buckets.forEach(bucket => {\n          this.titilerPgstacLambdaFunction.addToRolePolicy(new iam.PolicyStatement({\n            actions: [\"s3:GetObject\"],\n            resources: [`arn:aws:s3:::${bucket}/*`],\n          }));\n        });\n      }\n\n      props.dbSecret.grantRead(this.titilerPgstacLambdaFunction);\n\n      if (props.vpc) {\n        this.titilerPgstacLambdaFunction.connections.allowTo(props.db, ec2.Port.tcp(5432), \"allow connections from titiler\");\n      }\n\n      const stacApi = new apigatewayv2.HttpApi(\n        this,\n        `${Stack.of(this).stackName}-titiler-pgstac-api`,\n        {\n          defaultDomainMapping: props.titilerPgstacApiDomainName\n            ? {\n                domainName: props.titilerPgstacApiDomainName,\n              }\n            : undefined,\n          defaultIntegration:\n            new apigatewayv2_integrations.HttpLambdaIntegration(\n              \"integration\",\n              this.titilerPgstacLambdaFunction,\n              props.titilerPgstacApiDomainName\n                ? {\n                    parameterMapping:\n                      new apigatewayv2.ParameterMapping().overwriteHeader(\n                        \"host\",\n                        apigatewayv2.MappingValue.custom(\n                          props.titilerPgstacApiDomainName.name\n                        )\n                      ),\n                  }\n                : undefined\n            ),\n        }\n      );\n\n      this.url = stacApi.url!;\n\n      new CfnOutput(this, \"titiler-pgstac-api-output\", {\n        exportName: `${Stack.of(this).stackName}-titiler-pgstac-url`,\n        value: this.url,\n      });\n    }\n  }\n\n  export interface TitilerPgStacApiLambdaProps {\n    /**\n     * VPC into which the lambda should be deployed.\n     */\n    readonly vpc?: ec2.IVpc;\n\n    /**\n     * RDS Instance with installed pgSTAC or pgbouncer server.\n     */\n    readonly db: rds.IDatabaseInstance | ec2.IInstance;\n\n    /**\n     * Subnet into which the lambda should be deployed.\n     */\n    readonly subnetSelection?: ec2.SubnetSelection;\n\n    /**\n     * Secret containing connection information for pgSTAC database.\n     */\n    readonly dbSecret: secretsmanager.ISecret;\n\n    /**\n     * Customized environment variables to send to titiler-pgstac runtime. These will be merged with `defaultTitilerPgstacEnv`.\n     * The database secret arn is automatically added to the environment variables at deployment.\n    /*/\n    readonly apiEnv?: Record<string, string>;\n\n    /**\n     * list of buckets the lambda will be granted access to.\n     */\n    readonly buckets?: string[];\n\n    /**\n     * Custom Domain Name Options for Titiler Pgstac API,\n     *\n     * @default - undefined.\n     */\n    readonly titilerPgstacApiDomainName?: apigatewayv2.IDomainName;\n\n    /**\n     * Can be used to override the default lambda function properties.\n     *\n     * @default - defined in the construct.\n     */\n    readonly lambdaFunctionOptions?: CustomLambdaFunctionProps;\n  }\n"]}
|
|
94
|
+
_b = JSII_RTTI_SYMBOL_1;
|
|
95
|
+
TitilerPgstacApiLambda[_b] = { fqn: "eoapi-cdk.TitilerPgstacApiLambda", version: "9.0.0" };
|
|
96
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  aws_apigatewayv2 as apigatewayv2,\n  aws_iam as iam,\n  aws_ec2 as ec2,\n  aws_rds as rds,\n  aws_lambda as lambda,\n  aws_secretsmanager as secretsmanager,\n  Duration,\n  aws_logs,\n  CfnOutput,\n  Stack,\n} from \"aws-cdk-lib\";\nimport { Construct } from \"constructs\";\nimport { CustomLambdaFunctionProps } from \"../utils\";\nimport { LambdaApiGateway } from \"../lambda-api-gateway\";\nimport * as path from \"path\";\n\n// default settings that can be overridden by the user-provided environment.\nlet defaultTitilerPgstacEnv: Record<string, string> = {\n  CPL_VSIL_CURL_ALLOWED_EXTENSIONS: \".tif,.TIF,.tiff\",\n  GDAL_CACHEMAX: \"200\",\n  GDAL_DISABLE_READDIR_ON_OPEN: \"EMPTY_DIR\",\n  GDAL_INGESTED_BYTES_AT_OPEN: \"32768\",\n  GDAL_HTTP_MERGE_CONSECUTIVE_RANGES: \"YES\",\n  GDAL_HTTP_MULTIPLEX: \"YES\",\n  GDAL_HTTP_VERSION: \"2\",\n  PYTHONWARNINGS: \"ignore\",\n  VSI_CACHE: \"TRUE\",\n  VSI_CACHE_SIZE: \"5000000\",\n  DB_MIN_CONN_SIZE: \"1\",\n  DB_MAX_CONN_SIZE: \"1\",\n};\n\nexport class TitilerPgstacApiLambdaRuntime extends Construct {\n  public readonly lambdaFunction: lambda.Function;\n\n  constructor(\n    scope: Construct,\n    id: string,\n    props: TitilerPgstacApiLambdaRuntimeProps\n  ) {\n    super(scope, id);\n\n    this.lambdaFunction = new lambda.Function(this, \"lambda\", {\n      // defaults\n      runtime: lambda.Runtime.PYTHON_3_11,\n      handler: \"handler.handler\",\n      memorySize: 3008,\n      logRetention: aws_logs.RetentionDays.ONE_WEEK,\n      timeout: Duration.seconds(30),\n      code: lambda.Code.fromDockerBuild(path.join(__dirname, \"..\"), {\n        file: \"titiler-pgstac-api/runtime/Dockerfile\",\n        buildArgs: { PYTHON_VERSION: \"3.11\" },\n      }),\n      vpc: props.vpc,\n      vpcSubnets: props.subnetSelection,\n      allowPublicSubnet: true,\n      environment: {\n        ...defaultTitilerPgstacEnv,\n        ...props.apiEnv, // if user provided environment variables, merge them with the defaults.\n        PGSTAC_SECRET_ARN: props.dbSecret.secretArn,\n      },\n      // overwrites defaults with user-provided configurable properties\n      ...props.lambdaFunctionOptions,\n    });\n\n    // grant access to buckets using addToRolePolicy\n    if (props.buckets) {\n      props.buckets.forEach((bucket) => {\n        this.lambdaFunction.addToRolePolicy(\n          new iam.PolicyStatement({\n            actions: [\"s3:GetObject\"],\n            resources: [`arn:aws:s3:::${bucket}/*`],\n          })\n        );\n      });\n    }\n\n    props.dbSecret.grantRead(this.lambdaFunction);\n\n    if (props.vpc) {\n      this.lambdaFunction.connections.allowTo(\n        props.db,\n        ec2.Port.tcp(5432),\n        \"allow connections from titiler\"\n      );\n    }\n  }\n}\n\nexport interface TitilerPgstacApiLambdaRuntimeProps {\n  /**\n   * VPC into which the lambda should be deployed.\n   */\n  readonly vpc?: ec2.IVpc;\n\n  /**\n   * RDS Instance with installed pgSTAC or pgbouncer server.\n   */\n  readonly db: rds.IDatabaseInstance | ec2.IInstance;\n\n  /**\n   * Subnet into which the lambda should be deployed.\n   */\n  readonly subnetSelection?: ec2.SubnetSelection;\n\n  /**\n   * Secret containing connection information for pgSTAC database.\n   */\n  readonly dbSecret: secretsmanager.ISecret;\n\n  /**\n   * Customized environment variables to send to titiler-pgstac runtime. These will be merged with `defaultTitilerPgstacEnv`.\n   * The database secret arn is automatically added to the environment variables at deployment.\n   */\n  readonly apiEnv?: Record<string, string>;\n\n  /**\n   * list of buckets the lambda will be granted access to.\n   */\n  readonly buckets?: string[];\n\n  /**\n   * Can be used to override the default lambda function properties.\n   *\n   * @default - defined in the construct.\n   */\n  readonly lambdaFunctionOptions?: CustomLambdaFunctionProps;\n}\n\nexport class TitilerPgstacApiLambda extends Construct {\n  /**\n   * URL for the Titiler Pgstac API.\n   */\n  readonly url: string;\n\n  /**\n   * Lambda function for the Titiler Pgstac API.\n   */\n  readonly lambdaFunction: lambda.Function;\n\n  /**\n   * @deprecated - use lambdaFunction instead\n   */\n  public titilerPgstacLambdaFunction: lambda.Function;\n\n  constructor(\n    scope: Construct,\n    id: string,\n    props: TitilerPgstacApiLambdaProps\n  ) {\n    super(scope, id);\n\n    const runtime = new TitilerPgstacApiLambdaRuntime(this, \"runtime\", {\n      vpc: props.vpc,\n      subnetSelection: props.subnetSelection,\n      db: props.db,\n      dbSecret: props.dbSecret,\n      apiEnv: props.apiEnv,\n      buckets: props.buckets,\n      lambdaFunctionOptions: props.lambdaFunctionOptions,\n    });\n    this.titilerPgstacLambdaFunction = this.lambdaFunction =\n      runtime.lambdaFunction;\n\n    const { api } = new LambdaApiGateway(this, \"titlier-pgstac-api\", {\n      lambdaFunction: runtime.lambdaFunction,\n      domainName: props.domainName ?? props.titilerPgstacApiDomainName,\n    });\n\n    this.url = api.url!;\n\n    new CfnOutput(this, \"titiler-pgstac-api-output\", {\n      exportName: `${Stack.of(this).stackName}-titiler-pgstac-url`,\n      value: this.url,\n    });\n  }\n}\n\nexport interface TitilerPgstacApiLambdaProps\n  extends TitilerPgstacApiLambdaRuntimeProps {\n  /**\n   * Domain Name for the Titiler Pgstac API. If defined, will create the domain name and integrate it with the Titiler Pgstac API.\n   *\n   * @default - undefined.\n   */\n  readonly domainName?: apigatewayv2.IDomainName;\n\n  /**\n   * Custom Domain Name Options for Titiler Pgstac API,\n   *\n   * @deprecated Use 'domainName' instead.\n   * @default - undefined.\n   */\n  readonly titilerPgstacApiDomainName?: apigatewayv2.IDomainName;\n}\n"]}
|