eoapi-cdk 9.2.1 → 10.1.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 +5 -5
- package/README.md +8 -1
- package/lib/bastion-host/index.js +1 -1
- package/lib/database/index.d.ts +1 -1
- package/lib/database/index.js +4 -4
- package/lib/ingestor-api/index.js +6 -6
- package/lib/ingestor-api/runtime/Dockerfile +1 -1
- package/lib/lambda-api-gateway/index.js +1 -1
- package/lib/lambda-api-gateway-private/index.js +1 -1
- package/lib/stac-api/index.d.ts +1 -1
- package/lib/stac-api/index.js +6 -6
- package/lib/stac-api/runtime/requirements.txt +1 -1
- package/lib/stac-auth-proxy/index.js +2 -2
- package/lib/stac-browser/index.js +1 -1
- package/lib/stac-loader/index.d.ts +2 -2
- package/lib/stac-loader/index.js +4 -4
- package/lib/stac-loader/runtime/Dockerfile +1 -1
- package/lib/stac-loader/runtime/pyproject.toml +3 -9
- package/lib/stactools-item-generator/index.d.ts +2 -2
- package/lib/stactools-item-generator/index.js +4 -4
- package/lib/stactools-item-generator/runtime/Dockerfile +2 -2
- package/lib/stactools-item-generator/runtime/pyproject.toml +3 -8
- package/lib/tipg-api/index.js +6 -6
- package/lib/tipg-api/runtime/Dockerfile +3 -0
- package/lib/titiler-pgstac-api/index.d.ts +1 -1
- package/lib/titiler-pgstac-api/index.js +6 -6
- package/lib/titiler-pgstac-api/runtime/Dockerfile +2 -2
- package/package.json +1 -1
- package/pyproject.toml +2 -5
- package/uv.lock +166 -220
|
@@ -5,8 +5,8 @@ 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");
|
|
9
8
|
const path = require("path");
|
|
9
|
+
const lambda_api_gateway_1 = require("../lambda-api-gateway");
|
|
10
10
|
// default settings that can be overridden by the user-provided environment.
|
|
11
11
|
let defaultTitilerPgstacEnv = {
|
|
12
12
|
CPL_VSIL_CURL_ALLOWED_EXTENSIONS: ".tif,.TIF,.tiff",
|
|
@@ -27,14 +27,14 @@ class TitilerPgstacApiLambdaRuntime extends constructs_1.Construct {
|
|
|
27
27
|
super(scope, id);
|
|
28
28
|
this.lambdaFunction = new aws_cdk_lib_1.aws_lambda.Function(this, "lambda", {
|
|
29
29
|
// defaults
|
|
30
|
-
runtime: aws_cdk_lib_1.aws_lambda.Runtime.
|
|
30
|
+
runtime: aws_cdk_lib_1.aws_lambda.Runtime.PYTHON_3_12,
|
|
31
31
|
handler: "handler.handler",
|
|
32
32
|
memorySize: 3008,
|
|
33
33
|
logRetention: aws_cdk_lib_1.aws_logs.RetentionDays.ONE_WEEK,
|
|
34
34
|
timeout: aws_cdk_lib_1.Duration.seconds(30),
|
|
35
35
|
code: aws_cdk_lib_1.aws_lambda.Code.fromDockerBuild(path.join(__dirname, ".."), {
|
|
36
36
|
file: "titiler-pgstac-api/runtime/Dockerfile",
|
|
37
|
-
buildArgs: { PYTHON_VERSION: "3.
|
|
37
|
+
buildArgs: { PYTHON_VERSION: "3.12" },
|
|
38
38
|
}),
|
|
39
39
|
vpc: props.vpc,
|
|
40
40
|
vpcSubnets: props.subnetSelection,
|
|
@@ -64,7 +64,7 @@ class TitilerPgstacApiLambdaRuntime extends constructs_1.Construct {
|
|
|
64
64
|
}
|
|
65
65
|
exports.TitilerPgstacApiLambdaRuntime = TitilerPgstacApiLambdaRuntime;
|
|
66
66
|
_a = JSII_RTTI_SYMBOL_1;
|
|
67
|
-
TitilerPgstacApiLambdaRuntime[_a] = { fqn: "eoapi-cdk.TitilerPgstacApiLambdaRuntime", version: "
|
|
67
|
+
TitilerPgstacApiLambdaRuntime[_a] = { fqn: "eoapi-cdk.TitilerPgstacApiLambdaRuntime", version: "10.1.0" };
|
|
68
68
|
class TitilerPgstacApiLambda extends constructs_1.Construct {
|
|
69
69
|
constructor(scope, id, props) {
|
|
70
70
|
super(scope, id);
|
|
@@ -92,5 +92,5 @@ class TitilerPgstacApiLambda extends constructs_1.Construct {
|
|
|
92
92
|
}
|
|
93
93
|
exports.TitilerPgstacApiLambda = TitilerPgstacApiLambda;
|
|
94
94
|
_b = JSII_RTTI_SYMBOL_1;
|
|
95
|
-
TitilerPgstacApiLambda[_b] = { fqn: "eoapi-cdk.TitilerPgstacApiLambda", version: "
|
|
96
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":";;;;;AAAA,6CAWqB;AACrB,2CAAuC;AAEvC,8DAAyD;AACzD,6BAA6B;AAE7B,4EAA4E;AAC5E,IAAI,uBAAuB,GAA2B;IACpD,gCAAgC,EAAE,iBAAiB;IACnD,aAAa,EAAE,KAAK;IACpB,4BAA4B,EAAE,WAAW;IACzC,2BAA2B,EAAE,OAAO;IACpC,kCAAkC,EAAE,KAAK;IACzC,mBAAmB,EAAE,KAAK;IAC1B,iBAAiB,EAAE,GAAG;IACtB,cAAc,EAAE,QAAQ;IACxB,SAAS,EAAE,MAAM;IACjB,cAAc,EAAE,SAAS;IACzB,gBAAgB,EAAE,GAAG;IACrB,gBAAgB,EAAE,GAAG;CACtB,CAAC;AAEF,MAAa,6BAA8B,SAAQ,sBAAS;IAG1D,YACE,KAAgB,EAChB,EAAU,EACV,KAAyC;QAEzC,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,sBAAQ,CAAC,aAAa,CAAC,QAAQ;YAC7C,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,uCAAuC;gBAC7C,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,GAAG,uBAAuB;gBAC1B,GAAG,KAAK,CAAC,MAAM,EAAE,wEAAwE;gBACzF,iBAAiB,EAAE,KAAK,CAAC,QAAQ,CAAC,SAAS;aAC5C;YACD,iEAAiE;YACjE,GAAG,KAAK,CAAC,qBAAqB;SAC/B,CAAC,CAAC;QAEH,gDAAgD;QAChD,IAAI,KAAK,CAAC,OAAO,EAAE,CAAC;YAClB,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;gBAC/B,IAAI,CAAC,cAAc,CAAC,eAAe,CACjC,IAAI,qBAAG,CAAC,eAAe,CAAC;oBACtB,OAAO,EAAE,CAAC,cAAc,CAAC;oBACzB,SAAS,EAAE,CAAC,gBAAgB,MAAM,IAAI,CAAC;iBACxC,CAAC,CACH,CAAC;YACJ,CAAC,CAAC,CAAC;QACL,CAAC;QAED,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,gCAAgC,CACjC,CAAC;QACJ,CAAC;IACH,CAAC;;AAtDH,sEAuDC;;;AA0CD,MAAa,sBAAuB,SAAQ,sBAAS;IAgBnD,YACE,KAAgB,EAChB,EAAU,EACV,KAAkC;QAElC,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,MAAM,OAAO,GAAG,IAAI,6BAA6B,CAAC,IAAI,EAAE,SAAS,EAAE;YACjE,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,OAAO,EAAE,KAAK,CAAC,OAAO;YACtB,qBAAqB,EAAE,KAAK,CAAC,qBAAqB;SACnD,CAAC,CAAC;QACH,IAAI,CAAC,2BAA2B,GAAG,IAAI,CAAC,cAAc;YACpD,OAAO,CAAC,cAAc,CAAC;QAEzB,MAAM,EAAE,GAAG,EAAE,GAAG,IAAI,qCAAgB,CAAC,IAAI,EAAE,oBAAoB,EAAE;YAC/D,cAAc,EAAE,OAAO,CAAC,cAAc;YACtC,UAAU,EAAE,KAAK,CAAC,UAAU,IAAI,KAAK,CAAC,0BAA0B;SACjE,CAAC,CAAC;QAEH,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC,GAAI,CAAC;QAEpB,IAAI,uBAAS,CAAC,IAAI,EAAE,2BAA2B,EAAE;YAC/C,UAAU,EAAE,GAAG,mBAAK,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,SAAS,qBAAqB;YAC5D,KAAK,EAAE,IAAI,CAAC,GAAG;SAChB,CAAC,CAAC;IACL,CAAC;;AA9CH,wDA+CC","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"]}
|
|
95
|
+
TitilerPgstacApiLambda[_b] = { fqn: "eoapi-cdk.TitilerPgstacApiLambda", version: "10.1.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_logs,\n  CfnOutput,\n  Duration,\n  aws_ec2 as ec2,\n  aws_iam as iam,\n  aws_lambda as lambda,\n  aws_rds as rds,\n  aws_secretsmanager as secretsmanager,\n  Stack,\n} from \"aws-cdk-lib\";\nimport { Construct } from \"constructs\";\nimport * as path from \"path\";\nimport { LambdaApiGateway } from \"../lambda-api-gateway\";\nimport { CustomLambdaFunctionProps } from \"../utils\";\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_12,\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.12\" },\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"]}
|
|
@@ -5,13 +5,13 @@ WORKDIR /tmp
|
|
|
5
5
|
RUN python -m pip install pip -U
|
|
6
6
|
|
|
7
7
|
# Install system dependencies to compile (numexpr)
|
|
8
|
-
RUN
|
|
8
|
+
RUN dnf install -y gcc-c++ findutils
|
|
9
9
|
|
|
10
10
|
COPY titiler-pgstac-api/runtime/requirements.txt requirements.txt
|
|
11
11
|
RUN python -m pip install -r requirements.txt "mangum>=0.14,<0.15" -t /asset
|
|
12
12
|
|
|
13
13
|
# Remove system dependencies
|
|
14
|
-
RUN
|
|
14
|
+
RUN dnf remove -y gcc-c++
|
|
15
15
|
|
|
16
16
|
# Reduce package size and remove useless files
|
|
17
17
|
RUN find /asset -type f -name '*.pyc' | while read f; do n=$(echo $f | sed 's/__pycache__\///' | sed 's/.cpython-[0-9]*//'); cp $f $n; done;
|
package/package.json
CHANGED
package/pyproject.toml
CHANGED
|
@@ -1,11 +1,8 @@
|
|
|
1
1
|
[project]
|
|
2
2
|
name = "eoapi-cdk"
|
|
3
3
|
version = "0.0"
|
|
4
|
-
requires-python = ">=3.
|
|
5
|
-
dependencies = [
|
|
6
|
-
"stactools-item-generator",
|
|
7
|
-
"stac-loader",
|
|
8
|
-
]
|
|
4
|
+
requires-python = ">=3.12"
|
|
5
|
+
dependencies = ["stactools-item-generator", "stac-loader"]
|
|
9
6
|
|
|
10
7
|
[tool.uv.sources]
|
|
11
8
|
stactools-item-generator = { workspace = true }
|