eoapi-cdk 5.1.0 → 5.3.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 +478 -3
- package/CHANGELOG.md +14 -0
- package/README.md +6 -0
- package/lib/bastion-host/index.js +1 -1
- package/lib/bootstrapper/index.js +1 -1
- package/lib/database/index.js +1 -1
- package/lib/index.d.ts +2 -0
- package/lib/index.js +3 -1
- package/lib/ingestor-api/index.js +1 -1
- package/lib/stac-api/index.js +1 -1
- package/lib/stac-browser/index.d.ts +45 -0
- package/lib/stac-browser/index.js +86 -0
- package/lib/tipg-api/index.d.ts +58 -0
- package/lib/tipg-api/index.js +53 -0
- package/lib/tipg-api/runtime/requirements.txt +2 -0
- package/lib/tipg-api/runtime/src/__init__.py +3 -0
- package/lib/tipg-api/runtime/src/handler.py +54 -0
- package/lib/tipg-api/runtime/src/utils.py +41 -0
- package/lib/titiler-pgstac-api/index.js +1 -1
- package/package.json +1 -1
- package/tox.ini +1 -1
- package/tsconfig.tsbuildinfo +27 -1
package/.jsii
CHANGED
|
@@ -3572,7 +3572,7 @@
|
|
|
3572
3572
|
},
|
|
3573
3573
|
"name": "eoapi-cdk",
|
|
3574
3574
|
"readme": {
|
|
3575
|
-
"markdown": "# eoAPI CDK Constructs\n\neoapi-cdk is a package of [AWS CDK constructs](https://docs.aws.amazon.com/prescriptive-guidance/latest/best-practices-cdk-typescript-iac/constructs-best-practices.html) designed to encapsulate eoAPI services and best practices as simple reusable components.\n\n\nFor more background on the included services see [The Earth Observation API](https://eoapi.dev/)\n\n## Included constructs\nDetailed API docs for the constructs can be found [here](https://developmentseed.org/eoapi-cdk/).\n\n### [pgSTAC Database](https://developmentseed.org/eoapi-cdk/#pgstacdatabase-)\nAn [RDS](https://aws.amazon.com/rds/) instance with [pgSTAC](https://github.com/stac-utils/pgstac) installed and the Postgres parameters optimized for the selected instance type.\n\n### [STAC API](https://developmentseed.org/eoapi-cdk/#pgstacapilambda-)\nA STAC API implementation using [stac-fastapi](https://github.com/stac-utils/stac-fastapi) with a [pgSTAC backend](https://github.com/stac-utils/stac-fastapi-pgstac). Packaged as a complete runtime for deployment with API Gateway and Lambda.\n\n### [pgSTAC Titiler API](https://developmentseed.org/eoapi-cdk/#titilerpgstacapilambda-)\nA complete dynamic tiling API using [titiler-pgstac](https://github.com/stac-utils/titiler-pgstac) to create dynamic mosaics of assets based on [STAC Search queries](https://github.com/radiantearth/stac-api-spec/tree/master/item-search). Packaged as a complete runtime for deployment with API Gateway and Lambda and fully integrated with the pgSTAC Database construct.\n\n### [STAC Ingestor](https://developmentseed.org/eoapi-cdk/#stacingestor-)\nAn API for large scale STAC data ingestion and validation into a pgSTAC instance.\n\n\n\nAuthentication for the STAC Ingestor API can be configured with JWTs authenticated by JWKS. To learn more about securing FastAPI applications with this approach see [Securing FastAPI with JWKS (AWS Cognito, Auth0)](https://alukach.com/posts/fastapi-rs256-jwt/).\n\nA sample Cognito-based authentication system is available at [aws-asdi-auth](https://github.com/developmentseed/aws-asdi-auth).\n\n### [Bastion Host](https://developmentseed.org/eoapi-cdk/#bastionhost-)\nA bastion host is a secure gateway that provides access to resources in a private subnet. In this case it provides the ability to make administrative connections to eoAPI's pgSTAC instance.\n\n\n\nFor more background on bastion hosts in AWS see [this article](https://dev.to/aws-builders/bastion-host-in-aws-vpc-2i63).\n\nAnd for configuration instructions for this construct see [the docs](https://developmentseed.org/eoapi-cdk/#bastionhost-).\n\n\n## Published Packages\n\n- https://pypi.org/project/eoapi-cdk/\n- https://www.npmjs.com/package/eoapi-cdk/\n\n## Release\n\nVersioning is automatically handled via [Conventional Commits](https://www.conventionalcommits.org/en/v1.0.0/) and [Semantic Release](https://semantic-release.gitbook.io/semantic-release/).\n\n_Warning_: If you rebase `main`, you must ensure that the commits referenced by tags point to commits that are within the `main` branch. If a commit references a commit that is no longer on the `main` branch, Semantic Release will fail to detect the correct version of the project. [More information](https://github.com/semantic-release/semantic-release/issues/1121#issuecomment-517945233).\n\n\n"
|
|
3575
|
+
"markdown": "# eoAPI CDK Constructs\n\neoapi-cdk is a package of [AWS CDK constructs](https://docs.aws.amazon.com/prescriptive-guidance/latest/best-practices-cdk-typescript-iac/constructs-best-practices.html) designed to encapsulate eoAPI services and best practices as simple reusable components.\n\n\nFor more background on the included services see [The Earth Observation API](https://eoapi.dev/)\n\n## Included constructs\nDetailed API docs for the constructs can be found [here](https://developmentseed.org/eoapi-cdk/).\n\n### [pgSTAC Database](https://developmentseed.org/eoapi-cdk/#pgstacdatabase-)\nAn [RDS](https://aws.amazon.com/rds/) instance with [pgSTAC](https://github.com/stac-utils/pgstac) installed and the Postgres parameters optimized for the selected instance type.\n\n### [STAC API](https://developmentseed.org/eoapi-cdk/#pgstacapilambda-)\nA STAC API implementation using [stac-fastapi](https://github.com/stac-utils/stac-fastapi) with a [pgSTAC backend](https://github.com/stac-utils/stac-fastapi-pgstac). Packaged as a complete runtime for deployment with API Gateway and Lambda.\n\n### [pgSTAC Titiler API](https://developmentseed.org/eoapi-cdk/#titilerpgstacapilambda-)\nA complete dynamic tiling API using [titiler-pgstac](https://github.com/stac-utils/titiler-pgstac) to create dynamic mosaics of assets based on [STAC Search queries](https://github.com/radiantearth/stac-api-spec/tree/master/item-search). Packaged as a complete runtime for deployment with API Gateway and Lambda and fully integrated with the pgSTAC Database construct.\n\n### [STAC browser](https://developmentseed.org/eoapi-cdk/#stacbrowser-)\nA CDK construct to host a static [Radiant Earth STAC browser](https://github.com/radiantearth/stac-browser) on S3.\n\n### [OGC Features/Tiles API](https://developmentseed.org/eoapi-cdk/#titilerpgstacapilambda-)\nA complete OGC Features/Tiles API using [tipg](https://github.com/developmentseed/tipg). Packaged as a complete runtime for deployment with API Gateway and Lambda. By default the API will be connected to the Database's `public` schema.\n\n### [STAC Ingestor](https://developmentseed.org/eoapi-cdk/#stacingestor-)\nAn API for large scale STAC data ingestion and validation into a pgSTAC instance.\n\n\n\nAuthentication for the STAC Ingestor API can be configured with JWTs authenticated by JWKS. To learn more about securing FastAPI applications with this approach see [Securing FastAPI with JWKS (AWS Cognito, Auth0)](https://alukach.com/posts/fastapi-rs256-jwt/).\n\nA sample Cognito-based authentication system is available at [aws-asdi-auth](https://github.com/developmentseed/aws-asdi-auth).\n\n### [Bastion Host](https://developmentseed.org/eoapi-cdk/#bastionhost-)\nA bastion host is a secure gateway that provides access to resources in a private subnet. In this case it provides the ability to make administrative connections to eoAPI's pgSTAC instance.\n\n\n\nFor more background on bastion hosts in AWS see [this article](https://dev.to/aws-builders/bastion-host-in-aws-vpc-2i63).\n\nAnd for configuration instructions for this construct see [the docs](https://developmentseed.org/eoapi-cdk/#bastionhost-).\n\n\n## Published Packages\n\n- https://pypi.org/project/eoapi-cdk/\n- https://www.npmjs.com/package/eoapi-cdk/\n\n## Release\n\nVersioning is automatically handled via [Conventional Commits](https://www.conventionalcommits.org/en/v1.0.0/) and [Semantic Release](https://semantic-release.gitbook.io/semantic-release/).\n\n_Warning_: If you rebase `main`, you must ensure that the commits referenced by tags point to commits that are within the `main` branch. If a commit references a commit that is no longer on the `main` branch, Semantic Release will fail to detect the correct version of the project. [More information](https://github.com/semantic-release/semantic-release/issues/1121#issuecomment-517945233).\n\n\n"
|
|
3576
3576
|
},
|
|
3577
3577
|
"repository": {
|
|
3578
3578
|
"type": "git",
|
|
@@ -4614,6 +4614,201 @@
|
|
|
4614
4614
|
],
|
|
4615
4615
|
"symbolId": "lib/database/index:PgStacDatabaseProps"
|
|
4616
4616
|
},
|
|
4617
|
+
"eoapi-cdk.StacBrowser": {
|
|
4618
|
+
"assembly": "eoapi-cdk",
|
|
4619
|
+
"base": "constructs.Construct",
|
|
4620
|
+
"docs": {
|
|
4621
|
+
"stability": "experimental"
|
|
4622
|
+
},
|
|
4623
|
+
"fqn": "eoapi-cdk.StacBrowser",
|
|
4624
|
+
"initializer": {
|
|
4625
|
+
"docs": {
|
|
4626
|
+
"stability": "experimental"
|
|
4627
|
+
},
|
|
4628
|
+
"locationInModule": {
|
|
4629
|
+
"filename": "lib/stac-browser/index.ts",
|
|
4630
|
+
"line": 16
|
|
4631
|
+
},
|
|
4632
|
+
"parameters": [
|
|
4633
|
+
{
|
|
4634
|
+
"name": "scope",
|
|
4635
|
+
"type": {
|
|
4636
|
+
"fqn": "constructs.Construct"
|
|
4637
|
+
}
|
|
4638
|
+
},
|
|
4639
|
+
{
|
|
4640
|
+
"name": "id",
|
|
4641
|
+
"type": {
|
|
4642
|
+
"primitive": "string"
|
|
4643
|
+
}
|
|
4644
|
+
},
|
|
4645
|
+
{
|
|
4646
|
+
"name": "props",
|
|
4647
|
+
"type": {
|
|
4648
|
+
"fqn": "eoapi-cdk.StacBrowserProps"
|
|
4649
|
+
}
|
|
4650
|
+
}
|
|
4651
|
+
]
|
|
4652
|
+
},
|
|
4653
|
+
"kind": "class",
|
|
4654
|
+
"locationInModule": {
|
|
4655
|
+
"filename": "lib/stac-browser/index.ts",
|
|
4656
|
+
"line": 11
|
|
4657
|
+
},
|
|
4658
|
+
"name": "StacBrowser",
|
|
4659
|
+
"properties": [
|
|
4660
|
+
{
|
|
4661
|
+
"docs": {
|
|
4662
|
+
"stability": "experimental"
|
|
4663
|
+
},
|
|
4664
|
+
"locationInModule": {
|
|
4665
|
+
"filename": "lib/stac-browser/index.ts",
|
|
4666
|
+
"line": 13
|
|
4667
|
+
},
|
|
4668
|
+
"name": "bucket",
|
|
4669
|
+
"type": {
|
|
4670
|
+
"fqn": "aws-cdk-lib.aws_s3.IBucket"
|
|
4671
|
+
}
|
|
4672
|
+
},
|
|
4673
|
+
{
|
|
4674
|
+
"docs": {
|
|
4675
|
+
"stability": "experimental"
|
|
4676
|
+
},
|
|
4677
|
+
"locationInModule": {
|
|
4678
|
+
"filename": "lib/stac-browser/index.ts",
|
|
4679
|
+
"line": 14
|
|
4680
|
+
},
|
|
4681
|
+
"name": "bucketDeployment",
|
|
4682
|
+
"type": {
|
|
4683
|
+
"fqn": "aws-cdk-lib.aws_s3_deployment.BucketDeployment"
|
|
4684
|
+
}
|
|
4685
|
+
}
|
|
4686
|
+
],
|
|
4687
|
+
"symbolId": "lib/stac-browser/index:StacBrowser"
|
|
4688
|
+
},
|
|
4689
|
+
"eoapi-cdk.StacBrowserProps": {
|
|
4690
|
+
"assembly": "eoapi-cdk",
|
|
4691
|
+
"datatype": true,
|
|
4692
|
+
"docs": {
|
|
4693
|
+
"stability": "experimental"
|
|
4694
|
+
},
|
|
4695
|
+
"fqn": "eoapi-cdk.StacBrowserProps",
|
|
4696
|
+
"kind": "interface",
|
|
4697
|
+
"locationInModule": {
|
|
4698
|
+
"filename": "lib/stac-browser/index.ts",
|
|
4699
|
+
"line": 106
|
|
4700
|
+
},
|
|
4701
|
+
"name": "StacBrowserProps",
|
|
4702
|
+
"properties": [
|
|
4703
|
+
{
|
|
4704
|
+
"abstract": true,
|
|
4705
|
+
"docs": {
|
|
4706
|
+
"stability": "experimental",
|
|
4707
|
+
"summary": "Tag of the radiant earth stac-browser repo to use to build the app."
|
|
4708
|
+
},
|
|
4709
|
+
"immutable": true,
|
|
4710
|
+
"locationInModule": {
|
|
4711
|
+
"filename": "lib/stac-browser/index.ts",
|
|
4712
|
+
"line": 125
|
|
4713
|
+
},
|
|
4714
|
+
"name": "githubRepoTag",
|
|
4715
|
+
"type": {
|
|
4716
|
+
"primitive": "string"
|
|
4717
|
+
}
|
|
4718
|
+
},
|
|
4719
|
+
{
|
|
4720
|
+
"abstract": true,
|
|
4721
|
+
"docs": {
|
|
4722
|
+
"stability": "experimental",
|
|
4723
|
+
"summary": "STAC catalog URL."
|
|
4724
|
+
},
|
|
4725
|
+
"immutable": true,
|
|
4726
|
+
"locationInModule": {
|
|
4727
|
+
"filename": "lib/stac-browser/index.ts",
|
|
4728
|
+
"line": 120
|
|
4729
|
+
},
|
|
4730
|
+
"name": "stacCatalogUrl",
|
|
4731
|
+
"type": {
|
|
4732
|
+
"primitive": "string"
|
|
4733
|
+
}
|
|
4734
|
+
},
|
|
4735
|
+
{
|
|
4736
|
+
"abstract": true,
|
|
4737
|
+
"docs": {
|
|
4738
|
+
"default": "- No bucket ARN. A new bucket will be created.",
|
|
4739
|
+
"remarks": "If specified, the identity used to deploy the stack must have the appropriate permissions to create a deployment for this bucket. \nIn addition, if specified, `cloudFrontDistributionArn` is ignored since the policy of an imported resource can't be modified.",
|
|
4740
|
+
"stability": "experimental",
|
|
4741
|
+
"summary": "Bucket ARN."
|
|
4742
|
+
},
|
|
4743
|
+
"immutable": true,
|
|
4744
|
+
"locationInModule": {
|
|
4745
|
+
"filename": "lib/stac-browser/index.ts",
|
|
4746
|
+
"line": 115
|
|
4747
|
+
},
|
|
4748
|
+
"name": "bucketArn",
|
|
4749
|
+
"optional": true,
|
|
4750
|
+
"type": {
|
|
4751
|
+
"primitive": "string"
|
|
4752
|
+
}
|
|
4753
|
+
},
|
|
4754
|
+
{
|
|
4755
|
+
"abstract": true,
|
|
4756
|
+
"docs": {
|
|
4757
|
+
"default": "- DEFAULT_CLONE_DIRECTORY",
|
|
4758
|
+
"stability": "experimental",
|
|
4759
|
+
"summary": "Location in the filesystem where to compile the browser code."
|
|
4760
|
+
},
|
|
4761
|
+
"immutable": true,
|
|
4762
|
+
"locationInModule": {
|
|
4763
|
+
"filename": "lib/stac-browser/index.ts",
|
|
4764
|
+
"line": 149
|
|
4765
|
+
},
|
|
4766
|
+
"name": "cloneDirectory",
|
|
4767
|
+
"optional": true,
|
|
4768
|
+
"type": {
|
|
4769
|
+
"primitive": "string"
|
|
4770
|
+
}
|
|
4771
|
+
},
|
|
4772
|
+
{
|
|
4773
|
+
"abstract": true,
|
|
4774
|
+
"docs": {
|
|
4775
|
+
"default": "- No cloudfront distribution ARN. The bucket policy will not be modified.",
|
|
4776
|
+
"remarks": "If `bucketArn` is specified, this parameter is ignored since the policy of an imported bucket can't be modified.",
|
|
4777
|
+
"stability": "experimental",
|
|
4778
|
+
"summary": "The ARN of the cloudfront distribution that will be added to the bucket policy with read access."
|
|
4779
|
+
},
|
|
4780
|
+
"immutable": true,
|
|
4781
|
+
"locationInModule": {
|
|
4782
|
+
"filename": "lib/stac-browser/index.ts",
|
|
4783
|
+
"line": 134
|
|
4784
|
+
},
|
|
4785
|
+
"name": "cloudFrontDistributionArn",
|
|
4786
|
+
"optional": true,
|
|
4787
|
+
"type": {
|
|
4788
|
+
"primitive": "string"
|
|
4789
|
+
}
|
|
4790
|
+
},
|
|
4791
|
+
{
|
|
4792
|
+
"abstract": true,
|
|
4793
|
+
"docs": {
|
|
4794
|
+
"default": "- No index document.",
|
|
4795
|
+
"stability": "experimental",
|
|
4796
|
+
"summary": "The name of the index document (e.g. \"index.html\") for the website. Enables static website hosting for this bucket."
|
|
4797
|
+
},
|
|
4798
|
+
"immutable": true,
|
|
4799
|
+
"locationInModule": {
|
|
4800
|
+
"filename": "lib/stac-browser/index.ts",
|
|
4801
|
+
"line": 142
|
|
4802
|
+
},
|
|
4803
|
+
"name": "websiteIndexDocument",
|
|
4804
|
+
"optional": true,
|
|
4805
|
+
"type": {
|
|
4806
|
+
"primitive": "string"
|
|
4807
|
+
}
|
|
4808
|
+
}
|
|
4809
|
+
],
|
|
4810
|
+
"symbolId": "lib/stac-browser/index:StacBrowserProps"
|
|
4811
|
+
},
|
|
4617
4812
|
"eoapi-cdk.StacIngestor": {
|
|
4618
4813
|
"assembly": "eoapi-cdk",
|
|
4619
4814
|
"base": "constructs.Construct",
|
|
@@ -4888,6 +5083,286 @@
|
|
|
4888
5083
|
],
|
|
4889
5084
|
"symbolId": "lib/ingestor-api/index:StacIngestorProps"
|
|
4890
5085
|
},
|
|
5086
|
+
"eoapi-cdk.TiPgApiEntrypoint": {
|
|
5087
|
+
"assembly": "eoapi-cdk",
|
|
5088
|
+
"datatype": true,
|
|
5089
|
+
"docs": {
|
|
5090
|
+
"stability": "experimental"
|
|
5091
|
+
},
|
|
5092
|
+
"fqn": "eoapi-cdk.TiPgApiEntrypoint",
|
|
5093
|
+
"kind": "interface",
|
|
5094
|
+
"locationInModule": {
|
|
5095
|
+
"filename": "lib/tipg-api/index.ts",
|
|
5096
|
+
"line": 110
|
|
5097
|
+
},
|
|
5098
|
+
"name": "TiPgApiEntrypoint",
|
|
5099
|
+
"properties": [
|
|
5100
|
+
{
|
|
5101
|
+
"abstract": true,
|
|
5102
|
+
"docs": {
|
|
5103
|
+
"stability": "experimental",
|
|
5104
|
+
"summary": "Path to the source of the function or the location for dependencies."
|
|
5105
|
+
},
|
|
5106
|
+
"immutable": true,
|
|
5107
|
+
"locationInModule": {
|
|
5108
|
+
"filename": "lib/tipg-api/index.ts",
|
|
5109
|
+
"line": 114
|
|
5110
|
+
},
|
|
5111
|
+
"name": "entry",
|
|
5112
|
+
"type": {
|
|
5113
|
+
"primitive": "string"
|
|
5114
|
+
}
|
|
5115
|
+
},
|
|
5116
|
+
{
|
|
5117
|
+
"abstract": true,
|
|
5118
|
+
"docs": {
|
|
5119
|
+
"stability": "experimental",
|
|
5120
|
+
"summary": "The name of the exported handler in the index file."
|
|
5121
|
+
},
|
|
5122
|
+
"immutable": true,
|
|
5123
|
+
"locationInModule": {
|
|
5124
|
+
"filename": "lib/tipg-api/index.ts",
|
|
5125
|
+
"line": 122
|
|
5126
|
+
},
|
|
5127
|
+
"name": "handler",
|
|
5128
|
+
"optional": true,
|
|
5129
|
+
"type": {
|
|
5130
|
+
"primitive": "string"
|
|
5131
|
+
}
|
|
5132
|
+
},
|
|
5133
|
+
{
|
|
5134
|
+
"abstract": true,
|
|
5135
|
+
"docs": {
|
|
5136
|
+
"stability": "experimental",
|
|
5137
|
+
"summary": "The path (relative to entry) to the index file containing the exported handler."
|
|
5138
|
+
},
|
|
5139
|
+
"immutable": true,
|
|
5140
|
+
"locationInModule": {
|
|
5141
|
+
"filename": "lib/tipg-api/index.ts",
|
|
5142
|
+
"line": 118
|
|
5143
|
+
},
|
|
5144
|
+
"name": "index",
|
|
5145
|
+
"optional": true,
|
|
5146
|
+
"type": {
|
|
5147
|
+
"primitive": "string"
|
|
5148
|
+
}
|
|
5149
|
+
}
|
|
5150
|
+
],
|
|
5151
|
+
"symbolId": "lib/tipg-api/index:TiPgApiEntrypoint"
|
|
5152
|
+
},
|
|
5153
|
+
"eoapi-cdk.TiPgApiLambda": {
|
|
5154
|
+
"assembly": "eoapi-cdk",
|
|
5155
|
+
"base": "constructs.Construct",
|
|
5156
|
+
"docs": {
|
|
5157
|
+
"stability": "experimental"
|
|
5158
|
+
},
|
|
5159
|
+
"fqn": "eoapi-cdk.TiPgApiLambda",
|
|
5160
|
+
"initializer": {
|
|
5161
|
+
"docs": {
|
|
5162
|
+
"stability": "experimental"
|
|
5163
|
+
},
|
|
5164
|
+
"locationInModule": {
|
|
5165
|
+
"filename": "lib/tipg-api/index.ts",
|
|
5166
|
+
"line": 22
|
|
5167
|
+
},
|
|
5168
|
+
"parameters": [
|
|
5169
|
+
{
|
|
5170
|
+
"name": "scope",
|
|
5171
|
+
"type": {
|
|
5172
|
+
"fqn": "constructs.Construct"
|
|
5173
|
+
}
|
|
5174
|
+
},
|
|
5175
|
+
{
|
|
5176
|
+
"name": "id",
|
|
5177
|
+
"type": {
|
|
5178
|
+
"primitive": "string"
|
|
5179
|
+
}
|
|
5180
|
+
},
|
|
5181
|
+
{
|
|
5182
|
+
"name": "props",
|
|
5183
|
+
"type": {
|
|
5184
|
+
"fqn": "eoapi-cdk.TiPgApiLambdaProps"
|
|
5185
|
+
}
|
|
5186
|
+
}
|
|
5187
|
+
]
|
|
5188
|
+
},
|
|
5189
|
+
"kind": "class",
|
|
5190
|
+
"locationInModule": {
|
|
5191
|
+
"filename": "lib/tipg-api/index.ts",
|
|
5192
|
+
"line": 18
|
|
5193
|
+
},
|
|
5194
|
+
"name": "TiPgApiLambda",
|
|
5195
|
+
"properties": [
|
|
5196
|
+
{
|
|
5197
|
+
"docs": {
|
|
5198
|
+
"stability": "experimental"
|
|
5199
|
+
},
|
|
5200
|
+
"immutable": true,
|
|
5201
|
+
"locationInModule": {
|
|
5202
|
+
"filename": "lib/tipg-api/index.ts",
|
|
5203
|
+
"line": 19
|
|
5204
|
+
},
|
|
5205
|
+
"name": "url",
|
|
5206
|
+
"type": {
|
|
5207
|
+
"primitive": "string"
|
|
5208
|
+
}
|
|
5209
|
+
},
|
|
5210
|
+
{
|
|
5211
|
+
"docs": {
|
|
5212
|
+
"stability": "experimental"
|
|
5213
|
+
},
|
|
5214
|
+
"locationInModule": {
|
|
5215
|
+
"filename": "lib/tipg-api/index.ts",
|
|
5216
|
+
"line": 20
|
|
5217
|
+
},
|
|
5218
|
+
"name": "tiPgLambdaFunction",
|
|
5219
|
+
"type": {
|
|
5220
|
+
"fqn": "@aws-cdk/aws-lambda-python-alpha.PythonFunction"
|
|
5221
|
+
}
|
|
5222
|
+
}
|
|
5223
|
+
],
|
|
5224
|
+
"symbolId": "lib/tipg-api/index:TiPgApiLambda"
|
|
5225
|
+
},
|
|
5226
|
+
"eoapi-cdk.TiPgApiLambdaProps": {
|
|
5227
|
+
"assembly": "eoapi-cdk",
|
|
5228
|
+
"datatype": true,
|
|
5229
|
+
"docs": {
|
|
5230
|
+
"stability": "experimental"
|
|
5231
|
+
},
|
|
5232
|
+
"fqn": "eoapi-cdk.TiPgApiLambdaProps",
|
|
5233
|
+
"kind": "interface",
|
|
5234
|
+
"locationInModule": {
|
|
5235
|
+
"filename": "lib/tipg-api/index.ts",
|
|
5236
|
+
"line": 67
|
|
5237
|
+
},
|
|
5238
|
+
"name": "TiPgApiLambdaProps",
|
|
5239
|
+
"properties": [
|
|
5240
|
+
{
|
|
5241
|
+
"abstract": true,
|
|
5242
|
+
"docs": {
|
|
5243
|
+
"stability": "experimental",
|
|
5244
|
+
"summary": "RDS Instance with installed pgSTAC."
|
|
5245
|
+
},
|
|
5246
|
+
"immutable": true,
|
|
5247
|
+
"locationInModule": {
|
|
5248
|
+
"filename": "lib/tipg-api/index.ts",
|
|
5249
|
+
"line": 77
|
|
5250
|
+
},
|
|
5251
|
+
"name": "db",
|
|
5252
|
+
"type": {
|
|
5253
|
+
"fqn": "aws-cdk-lib.aws_rds.IDatabaseInstance"
|
|
5254
|
+
}
|
|
5255
|
+
},
|
|
5256
|
+
{
|
|
5257
|
+
"abstract": true,
|
|
5258
|
+
"docs": {
|
|
5259
|
+
"stability": "experimental",
|
|
5260
|
+
"summary": "Secret containing connection information for pgSTAC database."
|
|
5261
|
+
},
|
|
5262
|
+
"immutable": true,
|
|
5263
|
+
"locationInModule": {
|
|
5264
|
+
"filename": "lib/tipg-api/index.ts",
|
|
5265
|
+
"line": 87
|
|
5266
|
+
},
|
|
5267
|
+
"name": "dbSecret",
|
|
5268
|
+
"type": {
|
|
5269
|
+
"fqn": "aws-cdk-lib.aws_secretsmanager.ISecret"
|
|
5270
|
+
}
|
|
5271
|
+
},
|
|
5272
|
+
{
|
|
5273
|
+
"abstract": true,
|
|
5274
|
+
"docs": {
|
|
5275
|
+
"stability": "experimental",
|
|
5276
|
+
"summary": "Subnet into which the lambda should be deployed."
|
|
5277
|
+
},
|
|
5278
|
+
"immutable": true,
|
|
5279
|
+
"locationInModule": {
|
|
5280
|
+
"filename": "lib/tipg-api/index.ts",
|
|
5281
|
+
"line": 82
|
|
5282
|
+
},
|
|
5283
|
+
"name": "subnetSelection",
|
|
5284
|
+
"type": {
|
|
5285
|
+
"fqn": "aws-cdk-lib.aws_ec2.SubnetSelection"
|
|
5286
|
+
}
|
|
5287
|
+
},
|
|
5288
|
+
{
|
|
5289
|
+
"abstract": true,
|
|
5290
|
+
"docs": {
|
|
5291
|
+
"stability": "experimental",
|
|
5292
|
+
"summary": "VPC into which the lambda should be deployed."
|
|
5293
|
+
},
|
|
5294
|
+
"immutable": true,
|
|
5295
|
+
"locationInModule": {
|
|
5296
|
+
"filename": "lib/tipg-api/index.ts",
|
|
5297
|
+
"line": 72
|
|
5298
|
+
},
|
|
5299
|
+
"name": "vpc",
|
|
5300
|
+
"type": {
|
|
5301
|
+
"fqn": "aws-cdk-lib.aws_ec2.IVpc"
|
|
5302
|
+
}
|
|
5303
|
+
},
|
|
5304
|
+
{
|
|
5305
|
+
"abstract": true,
|
|
5306
|
+
"docs": {
|
|
5307
|
+
"default": "- simplified version of fastapi-pgstac",
|
|
5308
|
+
"stability": "experimental",
|
|
5309
|
+
"summary": "Custom code to run for fastapi-pgstac."
|
|
5310
|
+
},
|
|
5311
|
+
"immutable": true,
|
|
5312
|
+
"locationInModule": {
|
|
5313
|
+
"filename": "lib/tipg-api/index.ts",
|
|
5314
|
+
"line": 94
|
|
5315
|
+
},
|
|
5316
|
+
"name": "apiCode",
|
|
5317
|
+
"optional": true,
|
|
5318
|
+
"type": {
|
|
5319
|
+
"fqn": "eoapi-cdk.TiPgApiEntrypoint"
|
|
5320
|
+
}
|
|
5321
|
+
},
|
|
5322
|
+
{
|
|
5323
|
+
"abstract": true,
|
|
5324
|
+
"docs": {
|
|
5325
|
+
"stability": "experimental",
|
|
5326
|
+
"summary": "Customized environment variables to send to titiler-pgstac runtime."
|
|
5327
|
+
},
|
|
5328
|
+
"immutable": true,
|
|
5329
|
+
"locationInModule": {
|
|
5330
|
+
"filename": "lib/tipg-api/index.ts",
|
|
5331
|
+
"line": 99
|
|
5332
|
+
},
|
|
5333
|
+
"name": "apiEnv",
|
|
5334
|
+
"optional": true,
|
|
5335
|
+
"type": {
|
|
5336
|
+
"collection": {
|
|
5337
|
+
"elementtype": {
|
|
5338
|
+
"primitive": "string"
|
|
5339
|
+
},
|
|
5340
|
+
"kind": "map"
|
|
5341
|
+
}
|
|
5342
|
+
}
|
|
5343
|
+
},
|
|
5344
|
+
{
|
|
5345
|
+
"abstract": true,
|
|
5346
|
+
"docs": {
|
|
5347
|
+
"default": "- undefined",
|
|
5348
|
+
"remarks": "If defined, will create the \ndomain name and integrate it with the tipg API.",
|
|
5349
|
+
"stability": "experimental",
|
|
5350
|
+
"summary": "Custom Domain Name for tipg API."
|
|
5351
|
+
},
|
|
5352
|
+
"immutable": true,
|
|
5353
|
+
"locationInModule": {
|
|
5354
|
+
"filename": "lib/tipg-api/index.ts",
|
|
5355
|
+
"line": 107
|
|
5356
|
+
},
|
|
5357
|
+
"name": "tipgApiDomainName",
|
|
5358
|
+
"optional": true,
|
|
5359
|
+
"type": {
|
|
5360
|
+
"fqn": "@aws-cdk/aws-apigatewayv2-alpha.IDomainName"
|
|
5361
|
+
}
|
|
5362
|
+
}
|
|
5363
|
+
],
|
|
5364
|
+
"symbolId": "lib/tipg-api/index:TiPgApiLambdaProps"
|
|
5365
|
+
},
|
|
4891
5366
|
"eoapi-cdk.TitilerPgStacApiLambdaProps": {
|
|
4892
5367
|
"assembly": "eoapi-cdk",
|
|
4893
5368
|
"datatype": true,
|
|
@@ -5104,6 +5579,6 @@
|
|
|
5104
5579
|
"symbolId": "lib/titiler-pgstac-api/index:TitilerPgstacApiLambda"
|
|
5105
5580
|
}
|
|
5106
5581
|
},
|
|
5107
|
-
"version": "5.
|
|
5108
|
-
"fingerprint": "
|
|
5582
|
+
"version": "5.3.0",
|
|
5583
|
+
"fingerprint": "xaJ5JxX0D7rKagYaYvOlg9jlky8AnyKw+GXghxm0MzI="
|
|
5109
5584
|
}
|
package/CHANGELOG.md
CHANGED
|
@@ -1,3 +1,17 @@
|
|
|
1
|
+
# [5.3.0](https://github.com/developmentseed/eoapi-cdk/compare/v5.2.0...v5.3.0) (2023-09-01)
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
### Features
|
|
5
|
+
|
|
6
|
+
* add STAC browser option ([#64](https://github.com/developmentseed/eoapi-cdk/issues/64)) ([36499d2](https://github.com/developmentseed/eoapi-cdk/commit/36499d21be710edde5bc9d625acff17edf7a81d6))
|
|
7
|
+
|
|
8
|
+
# [5.2.0](https://github.com/developmentseed/eoapi-cdk/compare/v5.1.0...v5.2.0) (2023-08-30)
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
### Features
|
|
12
|
+
|
|
13
|
+
* tipg-api ([#62](https://github.com/developmentseed/eoapi-cdk/issues/62)) ([24faa85](https://github.com/developmentseed/eoapi-cdk/commit/24faa85fc4f1ccb6406768b9f43a4cb095dac0cf))
|
|
14
|
+
|
|
1
15
|
# [5.1.0](https://github.com/developmentseed/eoapi-cdk/compare/v5.0.0...v5.1.0) (2023-08-21)
|
|
2
16
|
|
|
3
17
|
|
package/README.md
CHANGED
|
@@ -17,6 +17,12 @@ A STAC API implementation using [stac-fastapi](https://github.com/stac-utils/sta
|
|
|
17
17
|
### [pgSTAC Titiler API](https://developmentseed.org/eoapi-cdk/#titilerpgstacapilambda-)
|
|
18
18
|
A complete dynamic tiling API using [titiler-pgstac](https://github.com/stac-utils/titiler-pgstac) to create dynamic mosaics of assets based on [STAC Search queries](https://github.com/radiantearth/stac-api-spec/tree/master/item-search). Packaged as a complete runtime for deployment with API Gateway and Lambda and fully integrated with the pgSTAC Database construct.
|
|
19
19
|
|
|
20
|
+
### [STAC browser](https://developmentseed.org/eoapi-cdk/#stacbrowser-)
|
|
21
|
+
A CDK construct to host a static [Radiant Earth STAC browser](https://github.com/radiantearth/stac-browser) on S3.
|
|
22
|
+
|
|
23
|
+
### [OGC Features/Tiles API](https://developmentseed.org/eoapi-cdk/#titilerpgstacapilambda-)
|
|
24
|
+
A complete OGC Features/Tiles API using [tipg](https://github.com/developmentseed/tipg). Packaged as a complete runtime for deployment with API Gateway and Lambda. By default the API will be connected to the Database's `public` schema.
|
|
25
|
+
|
|
20
26
|
### [STAC Ingestor](https://developmentseed.org/eoapi-cdk/#stacingestor-)
|
|
21
27
|
An API for large scale STAC data ingestion and validation into a pgSTAC instance.
|
|
22
28
|
|
|
@@ -158,5 +158,5 @@ class BastionHost extends constructs_1.Construct {
|
|
|
158
158
|
}
|
|
159
159
|
exports.BastionHost = BastionHost;
|
|
160
160
|
_a = JSII_RTTI_SYMBOL_1;
|
|
161
|
-
BastionHost[_a] = { fqn: "eoapi-cdk.BastionHost", version: "5.
|
|
161
|
+
BastionHost[_a] = { fqn: "eoapi-cdk.BastionHost", version: "5.3.0" };
|
|
162
162
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":";;;;;AAAA,6CAMqB;AACrB,2CAAuC;AAEvC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAiGG;AACH,MAAa,WAAY,SAAQ,sBAAS;IAGxC,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAuB;QAC/D,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,MAAM,EAAE,SAAS,EAAE,GAAG,mBAAK,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC;QAErC,qBAAqB;QACrB,IAAI,CAAC,QAAQ,GAAG,IAAI,qBAAG,CAAC,QAAQ,CAAC,IAAI,EAAE,cAAc,EAAE;YACrD,GAAG,EAAE,KAAK,CAAC,GAAG;YACd,UAAU,EAAE,EAAE,UAAU,EAAE,qBAAG,CAAC,UAAU,CAAC,MAAM,EAAE;YACjD,YAAY,EAAE,GAAG,SAAS,eAAe;YACzC,YAAY,EAAE,qBAAG,CAAC,YAAY,CAAC,EAAE,CAC/B,qBAAG,CAAC,aAAa,CAAC,mBAAmB,EACrC,qBAAG,CAAC,YAAY,CAAC,IAAI,CACtB;YACD,YAAY,EAAE,qBAAG,CAAC,YAAY,CAAC,iBAAiB,CAAC;gBAC/C,UAAU,EAAE,qBAAG,CAAC,qBAAqB,CAAC,cAAc;gBACpD,OAAO,EAAE,qBAAG,CAAC,kBAAkB,CAAC,MAAM;aACvC,CAAC;YACF,QAAQ,EAAE,KAAK,CAAC,QAAQ;YACxB,yBAAyB,EAAE,IAAI;SAChC,CAAC,CAAC;QAEH,oBAAoB;QACpB,IAAI,KAAK,CAAC,eAAe,IAAI,IAAI,EAAE;YACjC,IAAI,qBAAG,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,EAAE;gBACzB,UAAU,EAAE,IAAI,CAAC,QAAQ,CAAC,UAAU;gBACpC,IAAI,EAAE,CAAC,EAAE,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;aAC1C,CAAC,CAAC;SACJ;QAED,sCAAsC;QACtC,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,OAAO,CAC/B,KAAK,CAAC,EAAE,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC,CAAC,EACtC,qBAAG,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,EAClB,oCAAoC,CACrC,CAAC;QAEF,kCAAkC;QAClC,KAAK,MAAM,IAAI,IAAI,KAAK,CAAC,aAAa,EAAE;YACtC,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,SAAS,CACjC,qBAAG,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,EACnB,qBAAG,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,OAAO,IAAI,EAAE,CAAC,EACjC,YAAY,CACb,CAAC;SACH;QAED,qBAAqB;QACrB,IAAI,CAAC,QAAQ,CAAC,eAAe,CAC3B,IAAI,qBAAG,CAAC,eAAe,CAAC;YACtB,OAAO,EAAE;gBACP,eAAe;gBACf,+BAA+B;gBAC/B,eAAe;aAChB;YACD,SAAS,EAAE,CAAC,GAAG,CAAC;SACjB,CAAC,CACH,CAAC;QAEF,IAAI,uBAAS,CAAC,IAAI,EAAE,oBAAoB,EAAE;YACxC,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,UAAU;YAC/B,UAAU,EAAE,GAAG,SAAS,cAAc;SACvC,CAAC,CAAC;QACH,IAAI,uBAAS,CAAC,IAAI,EAAE,2BAA2B,EAAE;YAC/C,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,gBAAgB;YACrC,UAAU,EAAE,GAAG,SAAS,qBAAqB;SAC9C,CAAC,CAAC;QACH,IAAI,uBAAS,CAAC,IAAI,EAAE,iCAAiC,EAAE;YACrD,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,qBAAqB;YAC1C,UAAU,EAAE,GAAG,SAAS,kBAAkB;SAC3C,CAAC,CAAC;IACL,CAAC;;AAzEH,kCA0EC","sourcesContent":["import {\n  Stack,\n  aws_ec2 as ec2,\n  aws_iam as iam,\n  aws_rds as rds,\n  CfnOutput,\n} from \"aws-cdk-lib\";\nimport { Construct } from \"constructs\";\n\n/**\n * The database is located in an isolated subnet, meaning that it is not accessible from the public internet. As such, to interact with the database directly, a user must tunnel through a bastion host.\n *\n * ### Configuring\n *\n * This codebase controls _who_ is allowed to connect to the bastion host. This requires two steps:\n *\n * 1. Adding the IP address from which you are connecting to the `ipv4Allowlist` array\n * 1. Creating a bastion host system user by adding the user's configuration inform to `userdata.yaml`\n *\n * #### Adding an IP address to the `ipv4Allowlist` array\n *\n * The `BastionHost` construct takes in an `ipv4Allowlist` array as an argument. Find your IP address (eg `curl api.ipify.org`) and add that to the array along with the trailing CIDR block (likely `/32` to indicate that you are adding a single IP address).\n *\n * #### Creating a user via `userdata.yaml`\n *\n * Add an entry to the `users` array with a username (likely matching your local systems username, which you can get by running the `whoami` command in your terminal) and a public key (likely your default public key, which you can get by running `cat ~/.ssh/id_*.pub` in your terminal).\n *\n * #### Tips & Tricks when using the Bastion Host\n *\n * **Connecting to RDS Instance via SSM**\n *\n * ```sh\n * aws ssm start-session --target $INSTANCE_ID \\\n * --document-name AWS-StartPortForwardingSessionToRemoteHost \\\n * --parameters '{\n * \"host\": [\n * \"example-db.c5abcdefghij.us-west-2.rds.amazonaws.com\"\n * ],\n * \"portNumber\": [\n * \"5432\"\n * ],\n * \"localPortNumber\": [\n * \"9999\"\n * ]\n * }' \\\n * --profile $AWS_PROFILE\n * ```\n *\n * ```sh\n * psql -h localhost -p 9999 # continue adding username (-U) and db (-d) here...\n * ```\n *\n * Connect directly to Bastion Host:\n *\n * ```sh\n * aws ssm start-session --target $INSTANCE_ID --profile $AWS_PROFILE\n * ```\n *\n * **Setting up an SSH tunnel**\n *\n * In your `~/.ssh/config` file, add an entry like:\n *\n * ```\n * Host db-tunnel\n * Hostname {the-bastion-host-address}\n * LocalForward 9999 {the-db-hostname}:5432\n * ```\n *\n * Then a tunnel can be opened via:\n *\n * ```\n * ssh -N db-tunnel\n * ```\n *\n * And a connection to the DB can be made via:\n *\n * ```\n * psql -h 127.0.0.1 -p 9999 -U {username} -d {database}\n * ```\n *\n * **Handling `REMOTE HOST IDENTIFICATION HAS CHANGED!` error**\n *\n * If you've redeployed a bastion host that you've previously connected to, you may see an error like:\n *\n * ```\n * @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@\n * @    WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED!     @\n * @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@\n * IT IS POSSIBLE THAT SOMEONE IS DOING SOMETHING NASTY!\n * Someone could be eavesdropping on you right now (man-in-the-middle attack)!\n * It is also possible that a host key has just been changed.\n * The fingerprint for the ECDSA key sent by the remote host is\n * SHA256:mPnxAOXTpb06PFgI1Qc8TMQ2e9b7goU8y2NdS5hzIr8.\n * Please contact your system administrator.\n * Add correct host key in /Users/username/.ssh/known_hosts to get rid of this message.\n * Offending ECDSA key in /Users/username/.ssh/known_hosts:28\n * ECDSA host key for ec2-12-34-56-789.us-west-2.compute.amazonaws.com has changed and you have requested strict checking.\n * Host key verification failed.\n * ```\n *\n * This is due to the server's fingerprint changing. We can scrub the fingerprint from our system with a command like:\n *\n * ```\n * ssh-keygen -R 12.34.56.789\n * ```\n *\n */\nexport class BastionHost extends Construct {\n  instance: ec2.Instance;\n\n  constructor(scope: Construct, id: string, props: BastionHostProps) {\n    super(scope, id);\n\n    const { stackName } = Stack.of(this);\n\n    // Build ec2 instance\n    this.instance = new ec2.Instance(this, \"bastion-host\", {\n      vpc: props.vpc,\n      vpcSubnets: { subnetType: ec2.SubnetType.PUBLIC },\n      instanceName: `${stackName} bastion host`,\n      instanceType: ec2.InstanceType.of(\n        ec2.InstanceClass.BURSTABLE4_GRAVITON,\n        ec2.InstanceSize.NANO\n      ),\n      machineImage: ec2.MachineImage.latestAmazonLinux({\n        generation: ec2.AmazonLinuxGeneration.AMAZON_LINUX_2,\n        cpuType: ec2.AmazonLinuxCpuType.ARM_64,\n      }),\n      userData: props.userData,\n      userDataCausesReplacement: true,\n    });\n\n    // Assign elastic IP\n    if (props.createElasticIp ?? true) {\n      new ec2.CfnEIP(this, \"IP\", {\n        instanceId: this.instance.instanceId,\n        tags: [{ key: \"Name\", value: stackName }],\n      });\n    }\n\n    // Allow bastion host to connect to db\n    this.instance.connections.allowTo(\n      props.db.connections.securityGroups[0],\n      ec2.Port.tcp(5432),\n      \"Allow connection from bastion host\"\n    );\n\n    // Allow IP access to bastion host\n    for (const ipv4 of props.ipv4Allowlist) {\n      this.instance.connections.allowFrom(\n        ec2.Peer.ipv4(ipv4),\n        ec2.Port.tcp(props.sshPort || 22),\n        \"SSH Access\"\n      );\n    }\n\n    // Integrate with SSM\n    this.instance.addToRolePolicy(\n      new iam.PolicyStatement({\n        actions: [\n          \"ssmmessages:*\",\n          \"ssm:UpdateInstanceInformation\",\n          \"ec2messages:*\",\n        ],\n        resources: [\"*\"],\n      })\n    );\n\n    new CfnOutput(this, \"instance-id-output\", {\n      value: this.instance.instanceId,\n      exportName: `${stackName}-instance-id`,\n    });\n    new CfnOutput(this, \"instance-public-ip-output\", {\n      value: this.instance.instancePublicIp,\n      exportName: `${stackName}-instance-public-ip`,\n    });\n    new CfnOutput(this, \"instance-public-dns-name-output\", {\n      value: this.instance.instancePublicDnsName,\n      exportName: `${stackName}-public-dns-name`,\n    });\n  }\n}\n\nexport interface BastionHostProps {\n  readonly vpc: ec2.IVpc;\n  readonly db: rds.IDatabaseInstance;\n  readonly userData: ec2.UserData;\n  readonly ipv4Allowlist: string[];\n  readonly sshPort?: number;\n\n  /**\n   * Whether or not an elastic IP should be created for the bastion host.\n   *\n   * @default false\n   */\n  readonly createElasticIp?: boolean;\n}\n"]}
|
|
@@ -69,5 +69,5 @@ class BootstrapPgStac extends constructs_1.Construct {
|
|
|
69
69
|
}
|
|
70
70
|
exports.BootstrapPgStac = BootstrapPgStac;
|
|
71
71
|
_a = JSII_RTTI_SYMBOL_1;
|
|
72
|
-
BootstrapPgStac[_a] = { fqn: "eoapi-cdk.BootstrapPgStac", version: "5.
|
|
72
|
+
BootstrapPgStac[_a] = { fqn: "eoapi-cdk.BootstrapPgStac", version: "5.3.0" };
|
|
73
73
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":";;;;;AAAA,6CAUqB;AACrB,2CAAuC;AAEvC,SAAS,MAAM,CACb,QAA8D;IAE9D,OAAQ,QAAqC,CAAC,GAAG,KAAK,SAAS,CAAC;AAClE,CAAC;AAED,MAAM,sBAAsB,GAAG,QAAQ,CAAC;AAExC;;GAEG;AACH,MAAa,eAAgB,SAAQ,sBAAS;IAG5C,YAAY,KAAgB,EAAE,EAAU,EAAE,KAA2B;QACnE,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,MAAM,EAAE,aAAa,GAAG,sBAAsB,EAAE,GAAG,KAAK,CAAC;QACzD,MAAM,OAAO,GAAG,IAAI,wBAAU,CAAC,QAAQ,CAAC,IAAI,EAAE,QAAQ,EAAE;YACtD,OAAO,EAAE,iBAAiB;YAC1B,OAAO,EAAE,wBAAU,CAAC,OAAO,CAAC,UAAU;YACtC,IAAI,EAAE,wBAAU,CAAC,IAAI,CAAC,eAAe,CAAC,SAAS,EAAE;gBAC/C,IAAI,EAAE,oBAAoB;gBAC1B,SAAS,EAAE,EAAE,cAAc,EAAE,aAAa,EAAE;aAC7C,CAAC;YACF,OAAO,EAAE,sBAAQ,CAAC,OAAO,CAAC,CAAC,CAAC;YAC5B,GAAG,EAAE,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG;YAC5D,YAAY,EAAE,sBAAQ,CAAC,aAAa,CAAC,QAAQ;SAC9C,CAAC,CAAC;QAEH,IAAI,CAAC,MAAM,GAAG,IAAI,gCAAkB,CAAC,MAAM,CAAC,IAAI,EAAE,QAAQ,EAAE;YAC1D,UAAU,EAAE;gBACV,KAAK,CAAC,aAAa,IAAI,QAAQ;gBAC/B,EAAE;gBACF,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;aACzB,CAAC,IAAI,CAAC,GAAG,CAAC;YACX,oBAAoB,EAAE;gBACpB,oBAAoB,EAAE,IAAI,CAAC,SAAS,CAAC;oBACnC,MAAM,EAAE,KAAK,CAAC,YAAY,IAAI,QAAQ;oBACtC,MAAM,EAAE,UAAU;oBAClB,IAAI,EAAE,IAAI;oBACV,IAAI,EAAE,KAAK,CAAC,QAAQ,CAAC,gBAAgB,CAAC,QAAQ;oBAC9C,QAAQ,EAAE,KAAK,CAAC,cAAc,IAAI,aAAa;iBAChD,CAAC;gBACF,iBAAiB,EAAE,UAAU;gBAC7B,kBAAkB,EAAE,IAAI;aACzB;YACD,WAAW,EAAE,mCACX,mBAAK,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,SACjB,EAAE;SACH,CAAC,CAAC;QAEH,qBAAqB;QACrB,uBAAuB;QACvB,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;QAC/B,uBAAuB;QACvB,KAAK,CAAC,QAAQ,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;QAClC,sBAAsB;QACtB,KAAK,CAAC,QAAQ,CAAC,WAAW,CAAC,SAAS,CAAC,OAAO,EAAE,qBAAO,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC;QAEtE,iDAAiD;QACjD,IAAI,4BAAc,CAAC,IAAI,EAAE,cAAc,EAAE;YACvC,YAAY,EAAE,OAAO,CAAC,WAAW;YACjC,UAAU,EAAE;gBACV,sDAAsD;gBACtD,gEAAgE;gBAChE,cAAc,EAAE,aAAa;gBAC7B,eAAe,EAAE,KAAK,CAAC,QAAQ,CAAC,SAAS;gBACzC,mBAAmB,EAAE,IAAI,CAAC,MAAM,CAAC,SAAS;aAC3C;YACD,aAAa,EAAE,2BAAa,CAAC,MAAM;SACpC,CAAC,CAAC;IACL,CAAC;;AA7DH,0CA8DC","sourcesContent":["import {\n  aws_ec2,\n  aws_rds,\n  aws_lambda,\n  aws_logs,\n  aws_secretsmanager,\n  CustomResource,\n  Duration,\n  Stack,\n  RemovalPolicy,\n} from \"aws-cdk-lib\";\nimport { Construct } from \"constructs\";\n\nfunction hasVpc(\n  instance: aws_rds.DatabaseInstance | aws_rds.IDatabaseInstance\n): instance is aws_rds.DatabaseInstance {\n  return (instance as aws_rds.DatabaseInstance).vpc !== undefined;\n}\n\nconst DEFAULT_PGSTAC_VERSION = \"0.6.13\";\n\n/**\n * Bootstraps a database instance, installing pgSTAC onto the database.\n */\nexport class BootstrapPgStac extends Construct {\n  secret: aws_secretsmanager.ISecret;\n\n  constructor(scope: Construct, id: string, props: BootstrapPgStacProps) {\n    super(scope, id);\n\n    const { pgstacVersion = DEFAULT_PGSTAC_VERSION } = props;\n    const handler = new aws_lambda.Function(this, \"lambda\", {\n      handler: \"handler.handler\",\n      runtime: aws_lambda.Runtime.PYTHON_3_8,\n      code: aws_lambda.Code.fromDockerBuild(__dirname, {\n        file: \"runtime/Dockerfile\",\n        buildArgs: { PGSTAC_VERSION: pgstacVersion },\n      }),\n      timeout: Duration.minutes(2),\n      vpc: hasVpc(props.database) ? props.database.vpc : props.vpc,\n      logRetention: aws_logs.RetentionDays.ONE_WEEK,\n    });\n\n    this.secret = new aws_secretsmanager.Secret(this, \"secret\", {\n      secretName: [\n        props.secretsPrefix || \"pgstac\",\n        id,\n        this.node.addr.slice(-8),\n      ].join(\"/\"),\n      generateSecretString: {\n        secretStringTemplate: JSON.stringify({\n          dbname: props.pgstacDbName || \"pgstac\",\n          engine: \"postgres\",\n          port: 5432,\n          host: props.database.instanceEndpoint.hostname,\n          username: props.pgstacUsername || \"pgstac_user\",\n        }),\n        generateStringKey: \"password\",\n        excludePunctuation: true,\n      },\n      description: `PgSTAC database bootstrapped by ${\n        Stack.of(this).stackName\n      }`,\n    });\n\n    // Allow lambda to...\n    // read new user secret\n    this.secret.grantRead(handler);\n    // read database secret\n    props.dbSecret.grantRead(handler);\n    // connect to database\n    props.database.connections.allowFrom(handler, aws_ec2.Port.tcp(5432));\n\n    // this.connections = props.database.connections;\n    new CustomResource(this, \"bootstrapper\", {\n      serviceToken: handler.functionArn,\n      properties: {\n        // By setting pgstac_version in the properties assures\n        // that Create/Update events will be passed to the service token\n        pgstac_version: pgstacVersion,\n        conn_secret_arn: props.dbSecret.secretArn,\n        new_user_secret_arn: this.secret.secretArn,\n      },\n      removalPolicy: RemovalPolicy.RETAIN, // This retains the custom resource (which doesn't really exist), not the database\n    });\n  }\n}\n\nexport interface BootstrapPgStacProps {\n  /**\n   * VPC in which the database resides.\n   *\n   * Note - Must be explicitely set if the `database` only conforms to the\n   * `aws_rds.IDatabaseInstace` interface (ie it is a reference to a database instance\n   * rather than a database instance.)\n   *\n   * @default - `vpc` property of the `database` instance provided.\n   */\n  readonly vpc?: aws_ec2.IVpc;\n\n  /**\n   * Database onto which pgSTAC should be installed.\n   */\n  readonly database: aws_rds.DatabaseInstance | aws_rds.IDatabaseInstance;\n\n  /**\n   * Secret containing valid connection details for the database instance. Secret must\n   * conform to the format of CDK's `DatabaseInstance` (i.e. a JSON object containing a\n   * `username`, `password`, `host`, `port`, and optionally a `dbname`). If a `dbname`\n   * property is not specified within the secret, the bootstrapper will attempt to\n   * connect to a database with the name of `\"postgres\"`.\n   */\n  readonly dbSecret: aws_secretsmanager.ISecret;\n\n  /**\n   * Name of database that is to be created and onto which pgSTAC will be installed.\n   *\n   * @default pgstac\n   */\n  readonly pgstacDbName?: string;\n\n  /**\n   * Name of user that will be generated for connecting to the pgSTAC database.\n   *\n   * @default pgstac_user\n   */\n  readonly pgstacUsername?: string;\n\n  /**\n   * pgSTAC version to be installed.\n   *\n   * @default 0.6.8\n   */\n  readonly pgstacVersion?: string;\n\n  /**\n   * Prefix to assign to the generated `secrets_manager.Secret`\n   *\n   * @default pgstac\n   */\n  readonly secretsPrefix?: string;\n}\n"]}
|
package/lib/database/index.js
CHANGED
|
@@ -80,5 +80,5 @@ class PgStacDatabase extends constructs_1.Construct {
|
|
|
80
80
|
}
|
|
81
81
|
exports.PgStacDatabase = PgStacDatabase;
|
|
82
82
|
_a = JSII_RTTI_SYMBOL_1;
|
|
83
|
-
PgStacDatabase[_a] = { fqn: "eoapi-cdk.PgStacDatabase", version: "5.
|
|
83
|
+
PgStacDatabase[_a] = { fqn: "eoapi-cdk.PgStacDatabase", version: "5.3.0" };
|
|
84
84
|
//# 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_rds as rds,\n  aws_secretsmanager as secretsmanager,\n} from \"aws-cdk-lib\";\nimport { Construct } from \"constructs\";\nimport { BootstrapPgStac, BootstrapPgStacProps } from \"../bootstrapper\";\n\nconst instanceSizes: Record<string, number> = require(\"./instance-memory.json\");\n\n/**\n * An RDS instance with pgSTAC installed. This is a wrapper around the\n * `rds.DatabaseInstance` higher-level construct making use\n * of the BootstrapPgStac construct.\n */\nexport class PgStacDatabase extends Construct {\n  db: rds.DatabaseInstance;\n  pgstacSecret: secretsmanager.ISecret;\n\n  constructor(scope: Construct, id: string, props: PgStacDatabaseProps) {\n    super(scope, id);\n\n    const defaultParameters = this.getParameters(\n      props.instanceType?.toString() || \"m5.large\",\n      props.parameters\n    );\n    const parameterGroup = new rds.ParameterGroup(this, \"parameterGroup\", {\n      engine: props.engine,\n      parameters: {\n        shared_buffers: defaultParameters.sharedBuffers,\n        effective_cache_size: defaultParameters.effectiveCacheSize,\n        work_mem: defaultParameters.workMem,\n        maintenance_work_mem: defaultParameters.maintenanceWorkMem,\n        max_locks_per_transaction: defaultParameters.maxLocksPerTransaction,\n        temp_buffers: defaultParameters.tempBuffers,\n        seq_page_cost: defaultParameters.seqPageCost,\n        random_page_cost: defaultParameters.randomPageCost,\n        ...props.parameters,\n      },\n    });\n\n    this.db = new rds.DatabaseInstance(this, \"db\", {\n      instanceIdentifier: Stack.of(this).stackName,\n      parameterGroup,\n      ...props,\n    });\n\n    const bootstrap = new BootstrapPgStac(this, \"bootstrap-pgstac-instance\", {\n      vpc: props.vpc,\n      database: this.db,\n      dbSecret: this.db.secret!,\n      pgstacDbName: props.pgstacDbName,\n      pgstacVersion: props.pgstacVersion,\n      pgstacUsername: props.pgstacUsername,\n      secretsPrefix: props.secretsPrefix,\n    });\n\n    this.pgstacSecret = bootstrap.secret;\n  }\n\n  public getParameters(\n    instanceType: string,\n    parameters: PgStacDatabaseProps[\"parameters\"]\n  ): DatabaseParameters {\n    // https://github.com/aws/aws-cli/issues/1279#issuecomment-909318236\n    const memory_in_kb = instanceSizes[instanceType] * 1024;\n\n    // It's only necessary to consider passed in parameters for any value that used to\n    // derive subsequent values. Values that don't have dependencies will be overriden\n    // when we unpack the passed-in user parameters\n    const maxConnections = parameters?.maxConnections\n      ? Number.parseInt(parameters.maxConnections)\n      : // https://docs.aws.amazon.com/AmazonRDS/latest/UserGuide/CHAP_Limits.html#RDS_Limits.MaxConnections\n        Math.min(Math.round((memory_in_kb * 1024) / 9531392), 5000);\n    const sharedBuffers = parameters?.sharedBufers\n      ? Number.parseInt(parameters.sharedBufers)\n      : Math.round(0.25 * memory_in_kb);\n\n    const effectiveCacheSize = Math.round(0.75 * memory_in_kb);\n    const workMem = Math.floor(sharedBuffers / maxConnections);\n    const maintenanceWorkMem = Math.round(0.25 * sharedBuffers);\n\n    const tempBuffers = 128 * 1024;\n    const seqPageCost = 1;\n    const randomPageCost = 1.1;\n\n    return {\n      maxConnections: `${maxConnections}`,\n      sharedBuffers: `${sharedBuffers / 8}`, // Represented in 8kb blocks\n      effectiveCacheSize: `${effectiveCacheSize}`,\n      workMem: `${workMem}`,\n      maintenanceWorkMem: `${maintenanceWorkMem}`,\n      maxLocksPerTransaction: \"1024\",\n      tempBuffers: `${tempBuffers}`,\n      seqPageCost: `${seqPageCost}`,\n      randomPageCost: `${randomPageCost}`,\n    };\n  }\n}\n\nexport interface PgStacDatabaseProps extends rds.DatabaseInstanceProps {\n  readonly pgstacDbName?: BootstrapPgStacProps[\"pgstacDbName\"];\n  readonly pgstacVersion?: BootstrapPgStacProps[\"pgstacVersion\"];\n  readonly pgstacUsername?: BootstrapPgStacProps[\"pgstacUsername\"];\n  readonly secretsPrefix?: BootstrapPgStacProps[\"secretsPrefix\"];\n}\n\nexport interface DatabaseParameters {\n  /**\n   * @default - LEAST({DBInstanceClassMemory/9531392}, 5000)\n   */\n  readonly maxConnections: string;\n\n  /**\n   * Note: This value is measured in 8KB blocks.\n   *\n   * @default '{DBInstanceClassMemory/32768}' 25% of instance memory, ie `{(DBInstanceClassMemory/(1024*8)) * 0.25}`\n   */\n  readonly sharedBuffers: string;\n\n  /**\n   * @default - 75% of instance memory\n   */\n  readonly effectiveCacheSize: string;\n\n  /**\n   * @default - shared buffers divided by max connections\n   */\n  readonly workMem: string;\n\n  /**\n   * @default - 25% of shared buffers\n   */\n  readonly maintenanceWorkMem: string;\n\n  /**\n   * @default 1024\n   */\n  readonly maxLocksPerTransaction: string;\n\n  /**\n   * @default 131172 (128 * 1024)\n   */\n  readonly tempBuffers: string;\n\n  /**\n   * @default 1\n   */\n  readonly seqPageCost: string;\n\n  /**\n   * @default 1.1\n   */\n  readonly randomPageCost: string;\n}\n"]}
|
package/lib/index.d.ts
CHANGED
package/lib/index.js
CHANGED
|
@@ -16,4 +16,6 @@ __exportStar(require("./database"), exports);
|
|
|
16
16
|
__exportStar(require("./ingestor-api"), exports);
|
|
17
17
|
__exportStar(require("./stac-api"), exports);
|
|
18
18
|
__exportStar(require("./titiler-pgstac-api"), exports);
|
|
19
|
-
|
|
19
|
+
__exportStar(require("./stac-browser"), exports);
|
|
20
|
+
__exportStar(require("./tipg-api"), exports);
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7QUFBQSxpREFBK0I7QUFDL0IsaURBQStCO0FBQy9CLDZDQUEyQjtBQUMzQixpREFBK0I7QUFDL0IsNkNBQTJCO0FBQzNCLHVEQUFxQztBQUNyQyxpREFBK0I7QUFDL0IsNkNBQTJCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vYmFzdGlvbi1ob3N0XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9ib290c3RyYXBwZXJcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2RhdGFiYXNlXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9pbmdlc3Rvci1hcGlcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3N0YWMtYXBpXCI7XG5leHBvcnQgKiBmcm9tIFwiLi90aXRpbGVyLXBnc3RhYy1hcGlcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3N0YWMtYnJvd3NlclwiO1xuZXhwb3J0ICogZnJvbSBcIi4vdGlwZy1hcGlcIjtcbiJdfQ==
|
|
@@ -148,5 +148,5 @@ class StacIngestor extends constructs_1.Construct {
|
|
|
148
148
|
}
|
|
149
149
|
exports.StacIngestor = StacIngestor;
|
|
150
150
|
_a = JSII_RTTI_SYMBOL_1;
|
|
151
|
-
StacIngestor[_a] = { fqn: "eoapi-cdk.StacIngestor", version: "5.
|
|
151
|
+
StacIngestor[_a] = { fqn: "eoapi-cdk.StacIngestor", version: "5.3.0" };
|
|
152
152
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  aws_apigateway as apigateway,\n  aws_dynamodb as dynamodb,\n  aws_ec2 as ec2,\n  aws_iam as iam,\n  aws_lambda as lambda,\n  aws_lambda_event_sources as events,\n  aws_secretsmanager as secretsmanager,\n  aws_ssm as ssm,\n  Duration,\n  RemovalPolicy,\n  Stack,\n} from \"aws-cdk-lib\";\nimport { PythonFunction } from \"@aws-cdk/aws-lambda-python-alpha\";\nimport { Construct } from \"constructs\";\n\nexport class StacIngestor extends Construct {\n  table: dynamodb.Table;\n  public handlerRole: iam.Role;\n\n  constructor(scope: Construct, id: string, props: StacIngestorProps) {\n    super(scope, id);\n\n    this.table = this.buildTable();\n\n    const env: Record<string, string> = {\n      DYNAMODB_TABLE: this.table.tableName,\n      ROOT_PATH: `/${props.stage}`,\n      NO_PYDANTIC_SSM_SETTINGS: \"1\",\n      STAC_URL: props.stacUrl,\n      DATA_ACCESS_ROLE: props.dataAccessRole.roleArn,\n      ...props.apiEnv,\n    };\n\n    this.handlerRole = new iam.Role(this, \"execution-role\", {\n      description:\n        \"Role used by STAC Ingestor. Manually defined so that we can choose a name that is supported by the data access roles trust policy\",\n      assumedBy: new iam.ServicePrincipal(\"lambda.amazonaws.com\"),\n      managedPolicies: [\n        iam.ManagedPolicy.fromAwsManagedPolicyName(\n          \"service-role/AWSLambdaBasicExecutionRole\",\n        ),\n        iam.ManagedPolicy.fromAwsManagedPolicyName(\n          \"service-role/AWSLambdaVPCAccessExecutionRole\",\n        ),\n      ],\n    });\n    \n    const handler = this.buildApiLambda({\n      table: this.table,\n      env,\n      dataAccessRole: props.dataAccessRole,\n      stage: props.stage,\n      dbSecret: props.stacDbSecret,\n      dbVpc: props.vpc,\n      dbSecurityGroup: props.stacDbSecurityGroup,\n      subnetSelection: props.subnetSelection,\n    });\n\n    this.buildApiEndpoint({\n      handler,\n      stage: props.stage,\n      endpointConfiguration: props.apiEndpointConfiguration,\n      policy: props.apiPolicy,\n      ingestorDomainNameOptions: props.ingestorDomainNameOptions,\n    });\n\n    this.buildIngestor({\n      table: this.table,\n      env: env,\n      dbSecret: props.stacDbSecret,\n      dbVpc: props.vpc,\n      dbSecurityGroup: props.stacDbSecurityGroup,\n      subnetSelection: props.subnetSelection,\n    });\n\n    this.registerSsmParameter({\n      name: \"dynamodb_table\",\n      value: this.table.tableName,\n      description: \"Name of table used to store ingestions\",\n    });\n  }\n\n  private buildTable(): dynamodb.Table {\n    const table = new dynamodb.Table(this, \"ingestions-table\", {\n      partitionKey: { name: \"created_by\", type: dynamodb.AttributeType.STRING },\n      sortKey: { name: \"id\", type: dynamodb.AttributeType.STRING },\n      billingMode: dynamodb.BillingMode.PAY_PER_REQUEST,\n      removalPolicy: RemovalPolicy.DESTROY,\n      stream: dynamodb.StreamViewType.NEW_IMAGE,\n    });\n\n    table.addGlobalSecondaryIndex({\n      indexName: \"status\",\n      partitionKey: { name: \"status\", type: dynamodb.AttributeType.STRING },\n      sortKey: { name: \"created_at\", type: dynamodb.AttributeType.STRING },\n    });\n\n    return table;\n  }\n\n  private buildApiLambda(props: {\n    table: dynamodb.ITable;\n    env: Record<string, string>;\n    dataAccessRole: iam.IRole;\n    stage: string;\n    dbSecret: secretsmanager.ISecret;\n    dbVpc: ec2.IVpc;\n    dbSecurityGroup: ec2.ISecurityGroup;\n    subnetSelection: ec2.SubnetSelection\n  }): PythonFunction {\n    \n    const handler = new PythonFunction(this, \"api-handler\", {\n      entry: `${__dirname}/runtime`,\n      index: \"src/handler.py\",\n      runtime: lambda.Runtime.PYTHON_3_9,\n      timeout: Duration.seconds(30),\n      environment: { DB_SECRET_ARN: props.dbSecret.secretArn, ...props.env },\n      vpc: props.dbVpc,\n      vpcSubnets: props.subnetSelection,\n      allowPublicSubnet: true,\n      role: this.handlerRole,\n      memorySize: 2048,\n    });\n\n    // Allow handler to read DB secret\n    props.dbSecret.grantRead(handler);\n\n    // Allow handler to connect to DB\n    props.dbSecurityGroup.addIngressRule(\n      handler.connections.securityGroups[0],\n      ec2.Port.tcp(5432),\n      \"Allow connections from STAC Ingestor\"\n    );\n\n    props.table.grantReadWriteData(handler);\n\n    return handler;\n  }\n\n  private buildIngestor(props: {\n    table: dynamodb.ITable;\n    env: Record<string, string>;\n    dbSecret: secretsmanager.ISecret;\n    dbVpc: ec2.IVpc;\n    dbSecurityGroup: ec2.ISecurityGroup;\n    subnetSelection: ec2.SubnetSelection;\n  }): PythonFunction {\n    const handler = new PythonFunction(this, \"stac-ingestor\", {\n      entry: `${__dirname}/runtime`,\n      index: \"src/ingestor.py\",\n      runtime: lambda.Runtime.PYTHON_3_9,\n      timeout: Duration.seconds(180),\n      environment: { DB_SECRET_ARN: props.dbSecret.secretArn, ...props.env },\n      vpc: props.dbVpc,\n      vpcSubnets: props.subnetSelection,\n      allowPublicSubnet: true,\n      memorySize: 2048,\n    });\n\n    // Allow handler to read DB secret\n    props.dbSecret.grantRead(handler);\n\n    // Allow handler to connect to DB\n    props.dbSecurityGroup.addIngressRule(\n      handler.connections.securityGroups[0],\n      ec2.Port.tcp(5432),\n      \"Allow connections from STAC Ingestor\"\n    );\n\n    // Allow handler to write results back to DBƒ\n    props.table.grantWriteData(handler);\n\n    // Trigger handler from writes to DynamoDB table\n    handler.addEventSource(\n      new events.DynamoEventSource(props.table, {\n        // Read when batches reach size...\n        batchSize: 1000,\n        // ... or when window is reached.\n        maxBatchingWindow: Duration.seconds(10),\n        // Read oldest data first.\n        startingPosition: lambda.StartingPosition.TRIM_HORIZON,\n        retryAttempts: 1,\n      })\n    );\n\n    return handler;\n  }\n\n  private buildApiEndpoint(props: {\n    handler: lambda.IFunction;\n    stage: string;\n    policy?: iam.PolicyDocument;\n    endpointConfiguration?: apigateway.EndpointConfiguration;\n    ingestorDomainNameOptions?: apigateway.DomainNameOptions;\n  }): apigateway.LambdaRestApi {\n\n    return new apigateway.LambdaRestApi(\n      this,\n      `${Stack.of(this).stackName}-ingestor-api`,\n      {\n        handler: props.handler,\n        proxy: true,\n\n        cloudWatchRole: true,\n        deployOptions: { stageName: props.stage },\n        endpointExportName: `${Stack.of(this)}-ingestor-api`,\n\n        endpointConfiguration: props.endpointConfiguration,\n        policy: props.policy,\n\n        domainName:  props.ingestorDomainNameOptions ? {\n          domainName: props.ingestorDomainNameOptions.domainName,\n          certificate: props.ingestorDomainNameOptions.certificate,\n        } : undefined,\n      }\n    );\n  }\n\n  private registerSsmParameter(props: {\n    name: string;\n    value: string;\n    description: string;\n  }): ssm.IStringParameter {\n    const parameterNamespace = Stack.of(this).stackName;\n    return new ssm.StringParameter(\n      this,\n      `${props.name.replace(\"_\", \"-\")}-parameter`,\n      {\n        description: props.description,\n        parameterName: `/${parameterNamespace}/${props.name}`,\n        stringValue: props.value,\n      }\n    );\n  }\n}\n\nexport interface StacIngestorProps {\n  /**\n   * ARN of AWS Role used to validate access to S3 data\n   */\n  readonly dataAccessRole: iam.IRole;\n\n  /**\n   * URL of STAC API\n   */\n  readonly stacUrl: string;\n\n  /**\n   * Stage of deployment (e.g. `dev`, `prod`)\n   */\n  readonly stage: string;\n\n  /**\n   * Secret containing pgSTAC DB connection information\n   */\n  readonly stacDbSecret: secretsmanager.ISecret;\n\n  /**\n   * VPC running pgSTAC DB\n   */\n  readonly vpc: ec2.IVpc;\n\n  /**\n   * Security Group used by pgSTAC DB\n   */\n  readonly stacDbSecurityGroup: ec2.ISecurityGroup;\n\n  /**\n   * Boolean indicating whether or not pgSTAC DB is in a public subnet\n   */\n  readonly subnetSelection: ec2.SubnetSelection;\n\n  /**\n   * Environment variables to be sent to Lambda.\n   */\n  readonly apiEnv?: Record<string, string>;\n\n  /**\n   * API Endpoint Configuration, useful for creating private APIs.\n   */\n  readonly apiEndpointConfiguration?: apigateway.EndpointConfiguration;\n\n  /**\n   * API Policy Document, useful for creating private APIs.\n   */\n  readonly apiPolicy?: iam.PolicyDocument;\n\n  /**\n   * Custom Domain Name Options for Ingestor API\n   */\n   readonly ingestorDomainNameOptions?: apigateway.DomainNameOptions;\n}\n"]}
|
package/lib/stac-api/index.js
CHANGED
|
@@ -59,5 +59,5 @@ class PgStacApiLambda extends constructs_1.Construct {
|
|
|
59
59
|
}
|
|
60
60
|
exports.PgStacApiLambda = PgStacApiLambda;
|
|
61
61
|
_a = JSII_RTTI_SYMBOL_1;
|
|
62
|
-
PgStacApiLambda[_a] = { fqn: "eoapi-cdk.PgStacApiLambda", version: "5.
|
|
62
|
+
PgStacApiLambda[_a] = { fqn: "eoapi-cdk.PgStacApiLambda", version: "5.3.0" };
|
|
63
63
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLDZDQU9xQjtBQUNyQiw4RUFHMEM7QUFDMUMsNEVBQXVFO0FBQ3ZFLHNHQUFxRjtBQUNyRiwyQ0FBdUM7QUFFdkMsTUFBYSxlQUFnQixTQUFRLHNCQUFTO0lBSTVDLFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBMkI7UUFDbkUsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVqQixNQUFNLE9BQU8sR0FBRyxLQUFLLENBQUMsT0FBTyxJQUFJO1lBQy9CLEtBQUssRUFBRSxHQUFHLFNBQVMsVUFBVTtZQUM3QixLQUFLLEVBQUUsZ0JBQWdCO1lBQ3ZCLE9BQU8sRUFBRSxTQUFTO1NBQ25CLENBQUM7UUFFRixJQUFJLENBQUMscUJBQXFCLEdBQUcsSUFBSSx3Q0FBYyxDQUFDLElBQUksRUFBRSxVQUFVLEVBQUU7WUFDaEUsR0FBRyxPQUFPO1lBQ1Y7Ozs7Ozs7Ozs7aUJBVUs7WUFDTCxPQUFPLEVBQUUsd0JBQU0sQ0FBQyxPQUFPLENBQUMsVUFBVTtZQUNsQyxZQUFZLEVBQUUsd0JBQU0sQ0FBQyxZQUFZLENBQUMsTUFBTTtZQUN4QyxXQUFXLEVBQUU7Z0JBQ1gsaUJBQWlCLEVBQUUsS0FBSyxDQUFDLFFBQVEsQ0FBQyxTQUFTO2dCQUMzQyxnQkFBZ0IsRUFBRSxHQUFHO2dCQUNyQixnQkFBZ0IsRUFBRSxHQUFHO2dCQUNyQixHQUFHLEtBQUssQ0FBQyxNQUFNO2FBQ2hCO1lBQ0QsR0FBRyxFQUFFLEtBQUssQ0FBQyxHQUFHO1lBQ2QsVUFBVSxFQUFFLEtBQUssQ0FBQyxlQUFlO1lBQ2pDLGlCQUFpQixFQUFFLElBQUk7WUFDdkIsVUFBVSxFQUFFLElBQUk7U0FDakIsQ0FBQyxDQUFDO1FBRUgsS0FBSyxDQUFDLFFBQVEsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLHFCQUFxQixDQUFDLENBQUM7UUFDckQsSUFBSSxDQUFDLHFCQUFxQixDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLEVBQUUsRUFBRSxxQkFBRyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztRQUU3RSxNQUFNLE9BQU8sR0FBRyxJQUFJLGdDQUFPLENBQUMsSUFBSSxFQUFFLEdBQUcsbUJBQUssQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLENBQUMsU0FBUyxXQUFXLEVBQUU7WUFDeEUsb0JBQW9CLEVBQUUsS0FBSyxDQUFDLGlCQUFpQixDQUFDLENBQUMsQ0FBQztnQkFDOUMsVUFBVSxFQUFFLEtBQUssQ0FBQyxpQkFBaUI7YUFDcEMsQ0FBQyxDQUFDLENBQUMsU0FBUztZQUNiLGtCQUFrQixFQUFFLElBQUksMkRBQXFCLENBQUMsYUFBYSxFQUFFLElBQUksQ0FBQyxxQkFBcUIsQ0FBQztTQUN6RixDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsR0FBRyxHQUFHLE9BQU8sQ0FBQyxHQUFJLENBQUM7UUFFeEIsSUFBSSx1QkFBUyxDQUFDLElBQUksRUFBRSxpQkFBaUIsRUFBRTtZQUNyQyxVQUFVLEVBQUUsR0FBRyxtQkFBSyxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxTQUFTLE1BQU07WUFDN0MsS0FBSyxFQUFFLElBQUksQ0FBQyxHQUFHO1NBQ2hCLENBQUMsQ0FBQztJQUNMLENBQUM7O0FBeERILDBDQXlEQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIFN0YWNrLFxuICBhd3NfZWMyIGFzIGVjMixcbiAgYXdzX3JkcyBhcyByZHMsXG4gIGF3c19sYW1iZGEgYXMgbGFtYmRhLFxuICBhd3Nfc2VjcmV0c21hbmFnZXIgYXMgc2VjcmV0c21hbmFnZXIsXG4gIENmbk91dHB1dCxcbn0gZnJvbSBcImF3cy1jZGstbGliXCI7XG5pbXBvcnQge1xuICBQeXRob25GdW5jdGlvbixcbiAgUHl0aG9uRnVuY3Rpb25Qcm9wcyxcbn0gZnJvbSBcIkBhd3MtY2RrL2F3cy1sYW1iZGEtcHl0aG9uLWFscGhhXCI7XG5pbXBvcnQgeyBJRG9tYWluTmFtZSwgSHR0cEFwaSB9IGZyb20gXCJAYXdzLWNkay9hd3MtYXBpZ2F0ZXdheXYyLWFscGhhXCI7XG5pbXBvcnQgeyBIdHRwTGFtYmRhSW50ZWdyYXRpb24gfSBmcm9tIFwiQGF3cy1jZGsvYXdzLWFwaWdhdGV3YXl2Mi1pbnRlZ3JhdGlvbnMtYWxwaGFcIjtcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gXCJjb25zdHJ1Y3RzXCI7XG5cbmV4cG9ydCBjbGFzcyBQZ1N0YWNBcGlMYW1iZGEgZXh0ZW5kcyBDb25zdHJ1Y3Qge1xuICByZWFkb25seSB1cmw6IHN0cmluZztcbiAgcHVibGljIHN0YWNBcGlMYW1iZGFGdW5jdGlvbjogUHl0aG9uRnVuY3Rpb247XG5cbiAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM6IFBnU3RhY0FwaUxhbWJkYVByb3BzKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkKTtcblxuICAgIGNvbnN0IGFwaUNvZGUgPSBwcm9wcy5hcGlDb2RlIHx8IHtcbiAgICAgIGVudHJ5OiBgJHtfX2Rpcm5hbWV9L3J1bnRpbWVgLFxuICAgICAgaW5kZXg6IFwic3JjL2hhbmRsZXIucHlcIixcbiAgICAgIGhhbmRsZXI6IFwiaGFuZGxlclwiLFxuICAgIH07XG5cbiAgICB0aGlzLnN0YWNBcGlMYW1iZGFGdW5jdGlvbiA9IG5ldyBQeXRob25GdW5jdGlvbih0aGlzLCBcInN0YWMtYXBpXCIsIHtcbiAgICAgIC4uLmFwaUNvZGUsXG4gICAgICAvKipcbiAgICAgICAqIE5PVEU6IFVuYWJsZSB0byB1c2UgUHkzLjksIGR1ZSB0byBpc3N1ZXMgd2l0aCBoYXNoZXM6XG4gICAgICAgKlxuICAgICAgICogICAgRVJST1I6IEhhc2hlcyBhcmUgcmVxdWlyZWQgaW4gLS1yZXF1aXJlLWhhc2hlcyBtb2RlLCBidXQgdGhleSBhcmUgbWlzc2luZ1xuICAgICAgICogICAgZnJvbSBzb21lIHJlcXVpcmVtZW50cy4gSGVyZSBpcyBhIGxpc3Qgb2YgdGhvc2UgcmVxdWlyZW1lbnRzIGFsb25nIHdpdGggdGhlXG4gICAgICAgKiAgICBoYXNoZXMgdGhlaXIgZG93bmxvYWRlZCBhcmNoaXZlcyBhY3R1YWxseSBoYWQuIEFkZCBsaW5lcyBsaWtlIHRoZXNlIHRvIHlvdXJcbiAgICAgICAqICAgIHJlcXVpcmVtZW50cyBmaWxlcyB0byBwcmV2ZW50IHRhbXBlcmluZy4gKElmIHlvdSBkaWQgbm90IGVuYWJsZVxuICAgICAgICogICAgLS1yZXF1aXJlLWhhc2hlcyBtYW51YWxseSwgbm90ZSB0aGF0IGl0IHR1cm5zIG9uIGF1dG9tYXRpY2FsbHkgd2hlbiBhbnlcbiAgICAgICAqICAgIHBhY2thZ2UgaGFzIGEgaGFzaC4pXG4gICAgICAgKiAgICAgICAgYW55aW89PTMuNi4xIC0taGFzaD1zaGEyNTY6Y2IyOWI5YzcwNjIwNTA2YTlhOGY4N2EzMDk1OTE3MTM0NDY5NTMzMDJkN2Q5OTUzNDRkMGQ3YzZjMGM5YTdiZVxuICAgICAgICogKi9cbiAgICAgIHJ1bnRpbWU6IGxhbWJkYS5SdW50aW1lLlBZVEhPTl8zXzgsXG4gICAgICBhcmNoaXRlY3R1cmU6IGxhbWJkYS5BcmNoaXRlY3R1cmUuWDg2XzY0LFxuICAgICAgZW52aXJvbm1lbnQ6IHtcbiAgICAgICAgUEdTVEFDX1NFQ1JFVF9BUk46IHByb3BzLmRiU2VjcmV0LnNlY3JldEFybixcbiAgICAgICAgREJfTUlOX0NPTk5fU0laRTogXCIwXCIsXG4gICAgICAgIERCX01BWF9DT05OX1NJWkU6IFwiMVwiLFxuICAgICAgICAuLi5wcm9wcy5hcGlFbnYsXG4gICAgICB9LFxuICAgICAgdnBjOiBwcm9wcy52cGMsXG4gICAgICB2cGNTdWJuZXRzOiBwcm9wcy5zdWJuZXRTZWxlY3Rpb24sXG4gICAgICBhbGxvd1B1YmxpY1N1Ym5ldDogdHJ1ZSxcbiAgICAgIG1lbW9yeVNpemU6IDgxOTIsXG4gICAgfSk7XG5cbiAgICBwcm9wcy5kYlNlY3JldC5ncmFudFJlYWQodGhpcy5zdGFjQXBpTGFtYmRhRnVuY3Rpb24pO1xuICAgIHRoaXMuc3RhY0FwaUxhbWJkYUZ1bmN0aW9uLmNvbm5lY3Rpb25zLmFsbG93VG8ocHJvcHMuZGIsIGVjMi5Qb3J0LnRjcCg1NDMyKSk7XG5cbiAgICBjb25zdCBzdGFjQXBpID0gbmV3IEh0dHBBcGkodGhpcywgYCR7U3RhY2sub2YodGhpcykuc3RhY2tOYW1lfS1zdGFjLWFwaWAsIHtcbiAgICAgIGRlZmF1bHREb21haW5NYXBwaW5nOiBwcm9wcy5zdGFjQXBpRG9tYWluTmFtZSA/IHsgXG4gICAgICAgIGRvbWFpbk5hbWU6IHByb3BzLnN0YWNBcGlEb21haW5OYW1lXG4gICAgICB9IDogdW5kZWZpbmVkLFxuICAgICAgZGVmYXVsdEludGVncmF0aW9uOiBuZXcgSHR0cExhbWJkYUludGVncmF0aW9uKFwiaW50ZWdyYXRpb25cIiwgdGhpcy5zdGFjQXBpTGFtYmRhRnVuY3Rpb24pLFxuICAgIH0pO1xuXG4gICAgdGhpcy51cmwgPSBzdGFjQXBpLnVybCE7XG5cbiAgICBuZXcgQ2ZuT3V0cHV0KHRoaXMsIFwic3RhYy1hcGktb3V0cHV0XCIsIHtcbiAgICAgIGV4cG9ydE5hbWU6IGAke1N0YWNrLm9mKHRoaXMpLnN0YWNrTmFtZX0tdXJsYCxcbiAgICAgIHZhbHVlOiB0aGlzLnVybCxcbiAgICB9KTtcbiAgfVxufVxuXG5leHBvcnQgaW50ZXJmYWNlIFBnU3RhY0FwaUxhbWJkYVByb3BzIHtcbiAgLyoqXG4gICAqIFZQQyBpbnRvIHdoaWNoIHRoZSBsYW1iZGEgc2hvdWxkIGJlIGRlcGxveWVkLlxuICAgKi9cbiAgcmVhZG9ubHkgdnBjOiBlYzIuSVZwYztcblxuICAvKipcbiAgICogUkRTIEluc3RhbmNlIHdpdGggaW5zdGFsbGVkIHBnU1RBQy5cbiAgICovXG4gIHJlYWRvbmx5IGRiOiByZHMuSURhdGFiYXNlSW5zdGFuY2U7XG5cbiAgLyoqXG4gICAqIFN1Ym5ldCBpbnRvIHdoaWNoIHRoZSBsYW1iZGEgc2hvdWxkIGJlIGRlcGxveWVkLlxuICAgKi9cbiAgcmVhZG9ubHkgc3VibmV0U2VsZWN0aW9uOiBlYzIuU3VibmV0U2VsZWN0aW9uO1xuXG4gIC8qKlxuICAgKiBTZWNyZXQgY29udGFpbmluZyBjb25uZWN0aW9uIGluZm9ybWF0aW9uIGZvciBwZ1NUQUMgZGF0YWJhc2UuXG4gICAqL1xuICByZWFkb25seSBkYlNlY3JldDogc2VjcmV0c21hbmFnZXIuSVNlY3JldDtcblxuICAvKipcbiAgICogQ3VzdG9tIGNvZGUgdG8gcnVuIGZvciBmYXN0YXBpLXBnc3RhYy5cbiAgICpcbiAgICogQGRlZmF1bHQgLSBzaW1wbGlmaWVkIHZlcnNpb24gb2YgZmFzdGFwaS1wZ3N0YWNcbiAgICovXG4gIHJlYWRvbmx5IGFwaUNvZGU/OiBBcGlFbnRyeXBvaW50O1xuXG4gIC8qKlxuICAgKiBDdXN0b21pemVkIGVudmlyb25tZW50IHZhcmlhYmxlcyB0byBzZW5kIHRvIGZhc3RhcGktcGdzdGFjIHJ1bnRpbWUuXG4gICAqL1xuICByZWFkb25seSBhcGlFbnY/OiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+O1xuXG4gIC8qKlxuICAgKiBDdXN0b20gRG9tYWluIE5hbWUgT3B0aW9ucyBmb3IgU1RBQyBBUEksXG4gICAqL1xuICAgcmVhZG9ubHkgc3RhY0FwaURvbWFpbk5hbWU/OiBJRG9tYWluTmFtZTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBBcGlFbnRyeXBvaW50IHtcbiAgLyoqXG4gICAqIFBhdGggdG8gdGhlIHNvdXJjZSBvZiB0aGUgZnVuY3Rpb24gb3IgdGhlIGxvY2F0aW9uIGZvciBkZXBlbmRlbmNpZXMuXG4gICAqL1xuICByZWFkb25seSBlbnRyeTogUHl0aG9uRnVuY3Rpb25Qcm9wc1tcImVudHJ5XCJdO1xuICAvKipcbiAgICogVGhlIHBhdGggKHJlbGF0aXZlIHRvIGVudHJ5KSB0byB0aGUgaW5kZXggZmlsZSBjb250YWluaW5nIHRoZSBleHBvcnRlZCBoYW5kbGVyLlxuICAgKi9cbiAgcmVhZG9ubHkgaW5kZXg6IFB5dGhvbkZ1bmN0aW9uUHJvcHNbXCJpbmRleFwiXTtcbiAgLyoqXG4gICAqIFRoZSBuYW1lIG9mIHRoZSBleHBvcnRlZCBoYW5kbGVyIGluIHRoZSBpbmRleCBmaWxlLlxuICAgKi9cbiAgcmVhZG9ubHkgaGFuZGxlcjogUHl0aG9uRnVuY3Rpb25Qcm9wc1tcImhhbmRsZXJcIl07XG59XG4iXX0=
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { aws_s3 as s3, aws_s3_deployment as s3_deployment } from "aws-cdk-lib";
|
|
2
|
+
import { Construct } from "constructs";
|
|
3
|
+
export declare class StacBrowser extends Construct {
|
|
4
|
+
bucket: s3.IBucket;
|
|
5
|
+
bucketDeployment: s3_deployment.BucketDeployment;
|
|
6
|
+
constructor(scope: Construct, id: string, props: StacBrowserProps);
|
|
7
|
+
private buildApp;
|
|
8
|
+
}
|
|
9
|
+
export interface StacBrowserProps {
|
|
10
|
+
/**
|
|
11
|
+
* Bucket ARN. If specified, the identity used to deploy the stack must have the appropriate permissions to create a deployment for this bucket.
|
|
12
|
+
* In addition, if specified, `cloudFrontDistributionArn` is ignored since the policy of an imported resource can't be modified.
|
|
13
|
+
*
|
|
14
|
+
* @default - No bucket ARN. A new bucket will be created.
|
|
15
|
+
*/
|
|
16
|
+
readonly bucketArn?: string;
|
|
17
|
+
/**
|
|
18
|
+
* STAC catalog URL
|
|
19
|
+
*/
|
|
20
|
+
readonly stacCatalogUrl: string;
|
|
21
|
+
/**
|
|
22
|
+
* Tag of the radiant earth stac-browser repo to use to build the app.
|
|
23
|
+
*/
|
|
24
|
+
readonly githubRepoTag: string;
|
|
25
|
+
/**
|
|
26
|
+
* The ARN of the cloudfront distribution that will be added to the bucket policy with read access.
|
|
27
|
+
* If `bucketArn` is specified, this parameter is ignored since the policy of an imported bucket can't be modified.
|
|
28
|
+
*
|
|
29
|
+
* @default - No cloudfront distribution ARN. The bucket policy will not be modified.
|
|
30
|
+
*/
|
|
31
|
+
readonly cloudFrontDistributionArn?: string;
|
|
32
|
+
/**
|
|
33
|
+
* The name of the index document (e.g. "index.html") for the website. Enables static website
|
|
34
|
+
* hosting for this bucket.
|
|
35
|
+
*
|
|
36
|
+
* @default - No index document.
|
|
37
|
+
*/
|
|
38
|
+
readonly websiteIndexDocument?: string;
|
|
39
|
+
/**
|
|
40
|
+
* Location in the filesystem where to compile the browser code.
|
|
41
|
+
*
|
|
42
|
+
* @default - DEFAULT_CLONE_DIRECTORY
|
|
43
|
+
*/
|
|
44
|
+
readonly cloneDirectory?: string;
|
|
45
|
+
}
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var _a;
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.StacBrowser = void 0;
|
|
5
|
+
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
|
+
const aws_cdk_lib_1 = require("aws-cdk-lib");
|
|
7
|
+
const aws_cdk_lib_2 = require("aws-cdk-lib");
|
|
8
|
+
const aws_iam_1 = require("aws-cdk-lib/aws-iam");
|
|
9
|
+
const constructs_1 = require("constructs");
|
|
10
|
+
const child_process_1 = require("child_process");
|
|
11
|
+
const fs = require("fs");
|
|
12
|
+
const DEFAULT_CLONE_DIRECTORY = './stac-browser';
|
|
13
|
+
class StacBrowser extends constructs_1.Construct {
|
|
14
|
+
constructor(scope, id, props) {
|
|
15
|
+
super(scope, id);
|
|
16
|
+
const buildPath = this.buildApp(props.stacCatalogUrl, props.githubRepoTag, props.cloneDirectory || DEFAULT_CLONE_DIRECTORY);
|
|
17
|
+
// import a bucket from props.bucketArn if defined, otherwise create a new bucket
|
|
18
|
+
if (props.bucketArn) {
|
|
19
|
+
this.bucket = aws_cdk_lib_1.aws_s3.Bucket.fromBucketArn(this, 'Bucket', props.bucketArn);
|
|
20
|
+
}
|
|
21
|
+
else {
|
|
22
|
+
this.bucket = new aws_cdk_lib_1.aws_s3.Bucket(this, 'Bucket', {
|
|
23
|
+
accessControl: aws_cdk_lib_1.aws_s3.BucketAccessControl.PRIVATE,
|
|
24
|
+
removalPolicy: aws_cdk_lib_2.RemovalPolicy.DESTROY,
|
|
25
|
+
websiteIndexDocument: props.websiteIndexDocument
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
// if props.cloudFrontDistributionArn is defined and props.bucketArn is not defined, add a bucket policy to allow read access from the cloudfront distribution
|
|
29
|
+
if (props.cloudFrontDistributionArn && !props.bucketArn) {
|
|
30
|
+
this.bucket.addToResourcePolicy(new aws_iam_1.PolicyStatement({
|
|
31
|
+
sid: 'AllowCloudFrontServicePrincipal',
|
|
32
|
+
effect: aws_iam_1.Effect.ALLOW,
|
|
33
|
+
actions: ['s3:GetObject'],
|
|
34
|
+
principals: [new aws_iam_1.ServicePrincipal('cloudfront.amazonaws.com')],
|
|
35
|
+
resources: [this.bucket.arnForObjects('*')],
|
|
36
|
+
conditions: {
|
|
37
|
+
'StringEquals': {
|
|
38
|
+
'aws:SourceArn': props.cloudFrontDistributionArn
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
}));
|
|
42
|
+
}
|
|
43
|
+
// add the compiled code to the bucket as a bucket deployment
|
|
44
|
+
this.bucketDeployment = new aws_cdk_lib_1.aws_s3_deployment.BucketDeployment(this, 'BucketDeployment', {
|
|
45
|
+
destinationBucket: this.bucket,
|
|
46
|
+
sources: [aws_cdk_lib_1.aws_s3_deployment.Source.asset(buildPath)]
|
|
47
|
+
});
|
|
48
|
+
new aws_cdk_lib_2.CfnOutput(this, "bucket-name", {
|
|
49
|
+
exportName: `${aws_cdk_lib_1.Stack.of(this).stackName}-bucket-name`,
|
|
50
|
+
value: this.bucket.bucketName,
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
buildApp(stacCatalogUrl, githubRepoTag, cloneDirectory) {
|
|
54
|
+
// Define where to clone and build
|
|
55
|
+
const githubRepoUrl = 'https://github.com/radiantearth/stac-browser.git';
|
|
56
|
+
// Maybe the repo already exists in cloneDirectory. Try checking out the desired version and if it fails, delete and reclone.
|
|
57
|
+
try {
|
|
58
|
+
console.log(`Checking if a valid cloned repo exists with version ${githubRepoTag}...`);
|
|
59
|
+
child_process_1.execSync(`git checkout tags/${githubRepoTag}`, { cwd: cloneDirectory });
|
|
60
|
+
}
|
|
61
|
+
catch (error) {
|
|
62
|
+
// if directory exists, raise an error
|
|
63
|
+
if (fs.existsSync(cloneDirectory)) {
|
|
64
|
+
throw new Error(`Directory ${cloneDirectory} already exists and is not a valid clone of ${githubRepoUrl}. Please delete this directory or specify a different cloneDirectory.`);
|
|
65
|
+
}
|
|
66
|
+
// else, we clone and check out the version.
|
|
67
|
+
// Clone the repo
|
|
68
|
+
console.log(`Cloning ${githubRepoUrl} into ${cloneDirectory}...`);
|
|
69
|
+
child_process_1.execSync(`git clone ${githubRepoUrl} ${cloneDirectory}`);
|
|
70
|
+
// Check out the desired version
|
|
71
|
+
console.log(`Checking out version ${githubRepoTag}...`);
|
|
72
|
+
child_process_1.execSync(`git checkout tags/${githubRepoTag}`, { cwd: cloneDirectory });
|
|
73
|
+
}
|
|
74
|
+
// Install the dependencies and build the application
|
|
75
|
+
console.log(`Installing dependencies`);
|
|
76
|
+
child_process_1.execSync('npm install', { cwd: cloneDirectory });
|
|
77
|
+
// Build the app with catalogUrl
|
|
78
|
+
console.log(`Building app with catalogUrl=${stacCatalogUrl} into ${cloneDirectory}`);
|
|
79
|
+
child_process_1.execSync(`npm run build -- --catalogUrl=${stacCatalogUrl}`, { cwd: cloneDirectory });
|
|
80
|
+
return './stac-browser/dist';
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
exports.StacBrowser = StacBrowser;
|
|
84
|
+
_a = JSII_RTTI_SYMBOL_1;
|
|
85
|
+
StacBrowser[_a] = { fqn: "eoapi-cdk.StacBrowser", version: "5.3.0" };
|
|
86
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":";;;;;AAAA,6CAAqF;AACrF,6CAAuD;AACvD,iDAAgF;AAEhF,2CAAuC;AACvC,iDAAyC;AACzC,yBAAyB;AAEzB,MAAM,uBAAuB,GAAG,gBAAgB,CAAC;AAEjD,MAAa,WAAY,SAAQ,sBAAS;IAKtC,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAuB;QAC7D,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,MAAM,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,cAAc,EAAE,KAAK,CAAC,aAAa,EAAE,KAAK,CAAC,cAAc,IAAI,uBAAuB,CAAC,CAAC;QAE5H,iFAAiF;QACjF,IAAI,KAAK,CAAC,SAAS,EAAE;YACjB,IAAI,CAAC,MAAM,GAAG,oBAAE,CAAC,MAAM,CAAC,aAAa,CAAC,IAAI,EAAE,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;SAC1E;aAAM;YACH,IAAI,CAAC,MAAM,GAAG,IAAI,oBAAE,CAAC,MAAM,CAAC,IAAI,EAAE,QAAQ,EAAE;gBACxC,aAAa,EAAE,oBAAE,CAAC,mBAAmB,CAAC,OAAO;gBAC7C,aAAa,EAAE,2BAAa,CAAC,OAAO;gBACpC,oBAAoB,EAAE,KAAK,CAAC,oBAAoB;aACnD,CAAC,CAAA;SACL;QAED,8JAA8J;QAC9J,IAAI,KAAK,CAAC,yBAAyB,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE;YACrD,IAAI,CAAC,MAAM,CAAC,mBAAmB,CAAC,IAAI,yBAAe,CAAC;gBACxC,GAAG,EAAE,iCAAiC;gBACtC,MAAM,EAAE,gBAAM,CAAC,KAAK;gBACpB,OAAO,EAAE,CAAC,cAAc,CAAC;gBACzB,UAAU,EAAE,CAAC,IAAI,0BAAgB,CAAC,0BAA0B,CAAC,CAAC;gBAC9D,SAAS,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;gBAC3C,UAAU,EAAE;oBACR,cAAc,EAAE;wBACZ,eAAe,EAAE,KAAK,CAAC,yBAAyB;qBACnD;iBACJ;aACJ,CAAC,CAAC,CAAC;SACf;QAED,6DAA6D;QAC7D,IAAI,CAAC,gBAAgB,GAAG,IAAI,+BAAa,CAAC,gBAAgB,CAAC,IAAI,EAAE,kBAAkB,EAAE;YACjF,iBAAiB,EAAE,IAAI,CAAC,MAAM;YAC9B,OAAO,EAAE,CAAC,+BAAa,CAAC,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;SACjD,CAAC,CAAC;QAEL,IAAI,uBAAS,CAAC,IAAI,EAAE,aAAa,EAAE;YACnC,UAAU,EAAE,GAAG,mBAAK,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,SAAS,cAAc;YACrD,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,UAAU;SAC5B,CAAC,CAAC;IAEP,CAAC;IAEO,QAAQ,CAAC,cAAsB,EAAE,aAAqB,EAAE,cAAsB;QAElF,kCAAkC;QAClC,MAAM,aAAa,GAAG,kDAAkD,CAAC;QAGzE,8HAA8H;QAC9H,IAAI;YACA,OAAO,CAAC,GAAG,CAAC,uDAAuD,aAAa,KAAK,CAAC,CAAA;YACtF,wBAAQ,CAAC,qBAAqB,aAAa,EAAE,EAAE,EAAE,GAAG,EAAE,cAAc,EAAE,CAAC,CAAC;SAC3E;QACD,OAAO,KAAK,EAAE;YAEV,sCAAsC;YACtC,IAAI,EAAE,CAAC,UAAU,CAAC,cAAc,CAAC,EAAE;gBAC/B,MAAM,IAAI,KAAK,CAAC,aAAa,cAAc,+CAA+C,aAAa,uEAAuE,CAAC,CAAC;aACnL;YAED,4CAA4C;YAE5C,iBAAiB;YACjB,OAAO,CAAC,GAAG,CAAC,WAAW,aAAa,SAAS,cAAc,KAAK,CAAC,CAAA;YACjE,wBAAQ,CAAC,aAAa,aAAa,IAAI,cAAc,EAAE,CAAC,CAAC;YAEzD,gCAAgC;YAChC,OAAO,CAAC,GAAG,CAAC,wBAAwB,aAAa,KAAK,CAAC,CAAA;YACvD,wBAAQ,CAAC,qBAAqB,aAAa,EAAE,EAAE,EAAE,GAAG,EAAE,cAAc,EAAE,CAAC,CAAC;SAE3E;QAED,qDAAqD;QACrD,OAAO,CAAC,GAAG,CAAC,yBAAyB,CAAC,CAAA;QACtC,wBAAQ,CAAC,aAAa,EAAE,EAAE,GAAG,EAAE,cAAc,EAAE,CAAC,CAAC;QAEjD,gCAAgC;QAChC,OAAO,CAAC,GAAG,CAAC,gCAAgC,cAAc,SAAS,cAAc,EAAE,CAAC,CAAA;QACpF,wBAAQ,CAAC,iCAAiC,cAAc,EAAE,EAAE,EAAE,GAAG,EAAE,cAAc,EAAE,CAAC,CAAC;QAErF,OAAO,qBAAqB,CAAA;IAEhC,CAAC;;AA1FL,kCA6FC","sourcesContent":["import { Stack, aws_s3 as s3, aws_s3_deployment as s3_deployment} from \"aws-cdk-lib\";\nimport { RemovalPolicy, CfnOutput } from \"aws-cdk-lib\";\nimport { PolicyStatement, ServicePrincipal, Effect } from \"aws-cdk-lib/aws-iam\";\n\nimport { Construct } from \"constructs\";\nimport { execSync } from \"child_process\";\nimport * as fs from 'fs';\n\nconst DEFAULT_CLONE_DIRECTORY = './stac-browser';\n\nexport class StacBrowser extends Construct {\n\n    public bucket: s3.IBucket;\n    public bucketDeployment: s3_deployment.BucketDeployment;\n\n    constructor(scope: Construct, id: string, props: StacBrowserProps) {\n        super(scope, id);\n\n        const buildPath = this.buildApp(props.stacCatalogUrl, props.githubRepoTag, props.cloneDirectory || DEFAULT_CLONE_DIRECTORY);\n\n        // import a bucket from props.bucketArn if defined, otherwise create a new bucket\n        if (props.bucketArn) {\n            this.bucket = s3.Bucket.fromBucketArn(this, 'Bucket', props.bucketArn);\n        } else {\n            this.bucket = new s3.Bucket(this, 'Bucket', {\n                accessControl: s3.BucketAccessControl.PRIVATE,\n                removalPolicy: RemovalPolicy.DESTROY,\n                websiteIndexDocument: props.websiteIndexDocument\n            })\n        }\n        \n        // if props.cloudFrontDistributionArn is defined and props.bucketArn is not defined, add a bucket policy to allow read access from the cloudfront distribution\n        if (props.cloudFrontDistributionArn && !props.bucketArn) {\n            this.bucket.addToResourcePolicy(new PolicyStatement({\n                        sid: 'AllowCloudFrontServicePrincipal',\n                        effect: Effect.ALLOW, \n                        actions: ['s3:GetObject'],\n                        principals: [new ServicePrincipal('cloudfront.amazonaws.com')],\n                        resources: [this.bucket.arnForObjects('*')],\n                        conditions: {\n                            'StringEquals': {\n                                'aws:SourceArn': props.cloudFrontDistributionArn\n                            }\n                        }\n                    }));\n        }\n        \n        // add the compiled code to the bucket as a bucket deployment\n        this.bucketDeployment = new s3_deployment.BucketDeployment(this, 'BucketDeployment', {\n            destinationBucket: this.bucket,\n            sources: [s3_deployment.Source.asset(buildPath)]\n          });\n\n        new CfnOutput(this, \"bucket-name\", {\n        exportName: `${Stack.of(this).stackName}-bucket-name`,\n        value: this.bucket.bucketName,\n        });\n\n    }\n\n    private buildApp(stacCatalogUrl: string, githubRepoTag: string, cloneDirectory: string): string {\n            \n        // Define where to clone and build\n        const githubRepoUrl = 'https://github.com/radiantearth/stac-browser.git';\n\n\n        // Maybe the repo already exists in cloneDirectory. Try checking out the desired version and if it fails, delete and reclone. \n        try {\n            console.log(`Checking if a valid cloned repo exists with version ${githubRepoTag}...`)\n            execSync(`git checkout tags/${githubRepoTag}`, { cwd: cloneDirectory });\n        }\n        catch (error) {\n\n            // if directory exists, raise an error\n            if (fs.existsSync(cloneDirectory)) {\n                throw new Error(`Directory ${cloneDirectory} already exists and is not a valid clone of ${githubRepoUrl}. Please delete this directory or specify a different cloneDirectory.`);\n            }\n\n            // else, we clone and check out the version.\n\n            // Clone the repo\n            console.log(`Cloning ${githubRepoUrl} into ${cloneDirectory}...`)\n            execSync(`git clone ${githubRepoUrl} ${cloneDirectory}`);\n\n            // Check out the desired version\n            console.log(`Checking out version ${githubRepoTag}...`)\n            execSync(`git checkout tags/${githubRepoTag}`, { cwd: cloneDirectory });\n\n        }\n\n        // Install the dependencies and build the application\n        console.log(`Installing dependencies`)\n        execSync('npm install', { cwd: cloneDirectory });\n\n        // Build the app with catalogUrl\n        console.log(`Building app with catalogUrl=${stacCatalogUrl} into ${cloneDirectory}`)\n        execSync(`npm run build -- --catalogUrl=${stacCatalogUrl}`, { cwd: cloneDirectory });\n\n        return './stac-browser/dist'\n\n    }\n\n\n}\n\nexport interface StacBrowserProps {\n\n    /**\n     * Bucket ARN. If specified, the identity used to deploy the stack must have the appropriate permissions to create a deployment for this bucket. \n     * In addition, if specified, `cloudFrontDistributionArn` is ignored since the policy of an imported resource can't be modified.\n     * \n     * @default - No bucket ARN. A new bucket will be created.\n     */\n\n    readonly bucketArn?: string;\n\n    /**\n     * STAC catalog URL\n     */    \n    readonly stacCatalogUrl: string;\n\n    /**\n     * Tag of the radiant earth stac-browser repo to use to build the app.\n     */\n    readonly githubRepoTag: string;\n\n\n    /**\n     * The ARN of the cloudfront distribution that will be added to the bucket policy with read access.\n     * If `bucketArn` is specified, this parameter is ignored since the policy of an imported bucket can't be modified.\n     * \n     * @default - No cloudfront distribution ARN. The bucket policy will not be modified.\n     */    \n    readonly cloudFrontDistributionArn?: string;\n    \n    /**\n     * The name of the index document (e.g. \"index.html\") for the website. Enables static website\n     * hosting for this bucket.\n     *\n     * @default - No index document.\n     */\n    readonly websiteIndexDocument?: string;\n\n    /**\n     * Location in the filesystem where to compile the browser code. \n     * \n     * @default - DEFAULT_CLONE_DIRECTORY\n     */\n    readonly cloneDirectory?: string;\n\n}\n"]}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { aws_ec2 as ec2, aws_rds as rds, aws_secretsmanager as secretsmanager } from "aws-cdk-lib";
|
|
2
|
+
import { PythonFunction, PythonFunctionProps } from "@aws-cdk/aws-lambda-python-alpha";
|
|
3
|
+
import { IDomainName } from "@aws-cdk/aws-apigatewayv2-alpha";
|
|
4
|
+
import { Construct } from "constructs";
|
|
5
|
+
export declare class TiPgApiLambda extends Construct {
|
|
6
|
+
readonly url: string;
|
|
7
|
+
tiPgLambdaFunction: PythonFunction;
|
|
8
|
+
constructor(scope: Construct, id: string, props: TiPgApiLambdaProps);
|
|
9
|
+
}
|
|
10
|
+
export interface TiPgApiLambdaProps {
|
|
11
|
+
/**
|
|
12
|
+
* VPC into which the lambda should be deployed.
|
|
13
|
+
*/
|
|
14
|
+
readonly vpc: ec2.IVpc;
|
|
15
|
+
/**
|
|
16
|
+
* RDS Instance with installed pgSTAC.
|
|
17
|
+
*/
|
|
18
|
+
readonly db: rds.IDatabaseInstance;
|
|
19
|
+
/**
|
|
20
|
+
* Subnet into which the lambda should be deployed.
|
|
21
|
+
*/
|
|
22
|
+
readonly subnetSelection: ec2.SubnetSelection;
|
|
23
|
+
/**
|
|
24
|
+
* Secret containing connection information for pgSTAC database.
|
|
25
|
+
*/
|
|
26
|
+
readonly dbSecret: secretsmanager.ISecret;
|
|
27
|
+
/**
|
|
28
|
+
* Custom code to run for fastapi-pgstac.
|
|
29
|
+
*
|
|
30
|
+
* @default - simplified version of fastapi-pgstac
|
|
31
|
+
*/
|
|
32
|
+
readonly apiCode?: TiPgApiEntrypoint;
|
|
33
|
+
/**
|
|
34
|
+
* Customized environment variables to send to titiler-pgstac runtime.
|
|
35
|
+
*/
|
|
36
|
+
readonly apiEnv?: Record<string, string>;
|
|
37
|
+
/**
|
|
38
|
+
* Custom Domain Name for tipg API. If defined, will create the
|
|
39
|
+
* domain name and integrate it with the tipg API.
|
|
40
|
+
*
|
|
41
|
+
* @default - undefined
|
|
42
|
+
*/
|
|
43
|
+
readonly tipgApiDomainName?: IDomainName;
|
|
44
|
+
}
|
|
45
|
+
export interface TiPgApiEntrypoint {
|
|
46
|
+
/**
|
|
47
|
+
* Path to the source of the function or the location for dependencies.
|
|
48
|
+
*/
|
|
49
|
+
readonly entry: PythonFunctionProps["entry"];
|
|
50
|
+
/**
|
|
51
|
+
* The path (relative to entry) to the index file containing the exported handler.
|
|
52
|
+
*/
|
|
53
|
+
readonly index: PythonFunctionProps["index"];
|
|
54
|
+
/**
|
|
55
|
+
* The name of the exported handler in the index file.
|
|
56
|
+
*/
|
|
57
|
+
readonly handler: PythonFunctionProps["handler"];
|
|
58
|
+
}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var _a;
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.TiPgApiLambda = void 0;
|
|
5
|
+
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
|
+
const aws_cdk_lib_1 = require("aws-cdk-lib");
|
|
7
|
+
const aws_lambda_python_alpha_1 = require("@aws-cdk/aws-lambda-python-alpha");
|
|
8
|
+
const aws_apigatewayv2_alpha_1 = require("@aws-cdk/aws-apigatewayv2-alpha");
|
|
9
|
+
const aws_apigatewayv2_integrations_alpha_1 = require("@aws-cdk/aws-apigatewayv2-integrations-alpha");
|
|
10
|
+
const constructs_1 = require("constructs");
|
|
11
|
+
class TiPgApiLambda extends constructs_1.Construct {
|
|
12
|
+
constructor(scope, id, props) {
|
|
13
|
+
super(scope, id);
|
|
14
|
+
const apiCode = props.apiCode || {
|
|
15
|
+
entry: `${__dirname}/runtime`,
|
|
16
|
+
index: "src/handler.py",
|
|
17
|
+
handler: "handler",
|
|
18
|
+
};
|
|
19
|
+
this.tiPgLambdaFunction = new aws_lambda_python_alpha_1.PythonFunction(this, "tipg-api", {
|
|
20
|
+
...apiCode,
|
|
21
|
+
runtime: aws_cdk_lib_1.aws_lambda.Runtime.PYTHON_3_10,
|
|
22
|
+
architecture: aws_cdk_lib_1.aws_lambda.Architecture.X86_64,
|
|
23
|
+
environment: {
|
|
24
|
+
PGSTAC_SECRET_ARN: props.dbSecret.secretArn,
|
|
25
|
+
DB_MIN_CONN_SIZE: "1",
|
|
26
|
+
DB_MAX_CONN_SIZE: "1",
|
|
27
|
+
...props.apiEnv,
|
|
28
|
+
},
|
|
29
|
+
vpc: props.vpc,
|
|
30
|
+
vpcSubnets: props.subnetSelection,
|
|
31
|
+
allowPublicSubnet: true,
|
|
32
|
+
memorySize: 1024,
|
|
33
|
+
timeout: aws_cdk_lib_1.Duration.seconds(30),
|
|
34
|
+
});
|
|
35
|
+
props.dbSecret.grantRead(this.tiPgLambdaFunction);
|
|
36
|
+
this.tiPgLambdaFunction.connections.allowTo(props.db, aws_cdk_lib_1.aws_ec2.Port.tcp(5432), "allow connections from tipg");
|
|
37
|
+
const tipgApi = new aws_apigatewayv2_alpha_1.HttpApi(this, `${aws_cdk_lib_1.Stack.of(this).stackName}-tipg-api`, {
|
|
38
|
+
defaultDomainMapping: props.tipgApiDomainName ? {
|
|
39
|
+
domainName: props.tipgApiDomainName
|
|
40
|
+
} : undefined,
|
|
41
|
+
defaultIntegration: new aws_apigatewayv2_integrations_alpha_1.HttpLambdaIntegration("integration", this.tiPgLambdaFunction),
|
|
42
|
+
});
|
|
43
|
+
this.url = tipgApi.url;
|
|
44
|
+
new aws_cdk_lib_1.CfnOutput(this, "tipg-api-output", {
|
|
45
|
+
exportName: `${aws_cdk_lib_1.Stack.of(this).stackName}-tip-url`,
|
|
46
|
+
value: this.url,
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
exports.TiPgApiLambda = TiPgApiLambda;
|
|
51
|
+
_a = JSII_RTTI_SYMBOL_1;
|
|
52
|
+
TiPgApiLambda[_a] = { fqn: "eoapi-cdk.TiPgApiLambda", version: "5.3.0" };
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLDZDQVF1QjtBQUNyQiw4RUFHMEM7QUFDMUMsNEVBQXVFO0FBQ3ZFLHNHQUFxRjtBQUNyRiwyQ0FBdUM7QUFFdkMsTUFBYSxhQUFjLFNBQVEsc0JBQVM7SUFJMUMsWUFBWSxLQUFnQixFQUFFLEVBQVUsRUFBRSxLQUF5QjtRQUNqRSxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRWpCLE1BQU0sT0FBTyxHQUFHLEtBQUssQ0FBQyxPQUFPLElBQUk7WUFDL0IsS0FBSyxFQUFFLEdBQUcsU0FBUyxVQUFVO1lBQzdCLEtBQUssRUFBRSxnQkFBZ0I7WUFDdkIsT0FBTyxFQUFFLFNBQVM7U0FDbkIsQ0FBQztRQUVGLElBQUksQ0FBQyxrQkFBa0IsR0FBRyxJQUFJLHdDQUFjLENBQUMsSUFBSSxFQUFFLFVBQVUsRUFBRTtZQUM3RCxHQUFHLE9BQU87WUFDVixPQUFPLEVBQUUsd0JBQU0sQ0FBQyxPQUFPLENBQUMsV0FBVztZQUNuQyxZQUFZLEVBQUUsd0JBQU0sQ0FBQyxZQUFZLENBQUMsTUFBTTtZQUN4QyxXQUFXLEVBQUU7Z0JBQ1gsaUJBQWlCLEVBQUUsS0FBSyxDQUFDLFFBQVEsQ0FBQyxTQUFTO2dCQUMzQyxnQkFBZ0IsRUFBRSxHQUFHO2dCQUNyQixnQkFBZ0IsRUFBRSxHQUFHO2dCQUNyQixHQUFHLEtBQUssQ0FBQyxNQUFNO2FBQ2hCO1lBQ0QsR0FBRyxFQUFFLEtBQUssQ0FBQyxHQUFHO1lBQ2QsVUFBVSxFQUFFLEtBQUssQ0FBQyxlQUFlO1lBQ2pDLGlCQUFpQixFQUFFLElBQUk7WUFDdkIsVUFBVSxFQUFFLElBQUk7WUFDaEIsT0FBTyxFQUFFLHNCQUFRLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztTQUM5QixDQUFDLENBQUM7UUFFSCxLQUFLLENBQUMsUUFBUSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsa0JBQWtCLENBQUMsQ0FBQztRQUNsRCxJQUFJLENBQUMsa0JBQWtCLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsRUFBRSxFQUFFLHFCQUFHLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRSw2QkFBNkIsQ0FBQyxDQUFDO1FBRXpHLE1BQU0sT0FBTyxHQUFHLElBQUksZ0NBQU8sQ0FBQyxJQUFJLEVBQUUsR0FBRyxtQkFBSyxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxTQUFTLFdBQVcsRUFBRTtZQUN4RSxvQkFBb0IsRUFBRSxLQUFLLENBQUMsaUJBQWlCLENBQUMsQ0FBQyxDQUFDO2dCQUM5QyxVQUFVLEVBQUUsS0FBSyxDQUFDLGlCQUFpQjthQUNwQyxDQUFDLENBQUMsQ0FBQyxTQUFTO1lBQ2Isa0JBQWtCLEVBQUUsSUFBSSwyREFBcUIsQ0FBQyxhQUFhLEVBQUUsSUFBSSxDQUFDLGtCQUFrQixDQUFDO1NBQ3RGLENBQUMsQ0FBQztRQUVILElBQUksQ0FBQyxHQUFHLEdBQUcsT0FBTyxDQUFDLEdBQUksQ0FBQztRQUV4QixJQUFJLHVCQUFTLENBQUMsSUFBSSxFQUFFLGlCQUFpQixFQUFFO1lBQ3JDLFVBQVUsRUFBRSxHQUFHLG1CQUFLLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDLFNBQVMsVUFBVTtZQUNqRCxLQUFLLEVBQUUsSUFBSSxDQUFDLEdBQUc7U0FDaEIsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs7QUE5Q0gsc0NBK0NDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgICBTdGFjayxcbiAgICBhd3NfZWMyIGFzIGVjMixcbiAgICBhd3NfcmRzIGFzIHJkcyxcbiAgICBhd3NfbGFtYmRhIGFzIGxhbWJkYSxcbiAgICBhd3Nfc2VjcmV0c21hbmFnZXIgYXMgc2VjcmV0c21hbmFnZXIsXG4gICAgQ2ZuT3V0cHV0LFxuICAgIER1cmF0aW9uLFxuICB9IGZyb20gXCJhd3MtY2RrLWxpYlwiO1xuICBpbXBvcnQge1xuICAgIFB5dGhvbkZ1bmN0aW9uLFxuICAgIFB5dGhvbkZ1bmN0aW9uUHJvcHMsXG4gIH0gZnJvbSBcIkBhd3MtY2RrL2F3cy1sYW1iZGEtcHl0aG9uLWFscGhhXCI7XG4gIGltcG9ydCB7IElEb21haW5OYW1lLCBIdHRwQXBpIH0gZnJvbSBcIkBhd3MtY2RrL2F3cy1hcGlnYXRld2F5djItYWxwaGFcIjtcbiAgaW1wb3J0IHsgSHR0cExhbWJkYUludGVncmF0aW9uIH0gZnJvbSBcIkBhd3MtY2RrL2F3cy1hcGlnYXRld2F5djItaW50ZWdyYXRpb25zLWFscGhhXCI7XG4gIGltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gXCJjb25zdHJ1Y3RzXCI7XG5cbiAgZXhwb3J0IGNsYXNzIFRpUGdBcGlMYW1iZGEgZXh0ZW5kcyBDb25zdHJ1Y3Qge1xuICAgIHJlYWRvbmx5IHVybDogc3RyaW5nO1xuICAgIHB1YmxpYyB0aVBnTGFtYmRhRnVuY3Rpb246IFB5dGhvbkZ1bmN0aW9uO1xuXG4gICAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM6IFRpUGdBcGlMYW1iZGFQcm9wcykge1xuICAgICAgc3VwZXIoc2NvcGUsIGlkKTtcblxuICAgICAgY29uc3QgYXBpQ29kZSA9IHByb3BzLmFwaUNvZGUgfHwge1xuICAgICAgICBlbnRyeTogYCR7X19kaXJuYW1lfS9ydW50aW1lYCxcbiAgICAgICAgaW5kZXg6IFwic3JjL2hhbmRsZXIucHlcIixcbiAgICAgICAgaGFuZGxlcjogXCJoYW5kbGVyXCIsXG4gICAgICB9O1xuXG4gICAgICB0aGlzLnRpUGdMYW1iZGFGdW5jdGlvbiA9IG5ldyBQeXRob25GdW5jdGlvbih0aGlzLCBcInRpcGctYXBpXCIsIHtcbiAgICAgICAgLi4uYXBpQ29kZSxcbiAgICAgICAgcnVudGltZTogbGFtYmRhLlJ1bnRpbWUuUFlUSE9OXzNfMTAsXG4gICAgICAgIGFyY2hpdGVjdHVyZTogbGFtYmRhLkFyY2hpdGVjdHVyZS5YODZfNjQsXG4gICAgICAgIGVudmlyb25tZW50OiB7XG4gICAgICAgICAgUEdTVEFDX1NFQ1JFVF9BUk46IHByb3BzLmRiU2VjcmV0LnNlY3JldEFybixcbiAgICAgICAgICBEQl9NSU5fQ09OTl9TSVpFOiBcIjFcIixcbiAgICAgICAgICBEQl9NQVhfQ09OTl9TSVpFOiBcIjFcIixcbiAgICAgICAgICAuLi5wcm9wcy5hcGlFbnYsXG4gICAgICAgIH0sXG4gICAgICAgIHZwYzogcHJvcHMudnBjLFxuICAgICAgICB2cGNTdWJuZXRzOiBwcm9wcy5zdWJuZXRTZWxlY3Rpb24sXG4gICAgICAgIGFsbG93UHVibGljU3VibmV0OiB0cnVlLFxuICAgICAgICBtZW1vcnlTaXplOiAxMDI0LFxuICAgICAgICB0aW1lb3V0OiBEdXJhdGlvbi5zZWNvbmRzKDMwKSxcbiAgICAgIH0pO1xuXG4gICAgICBwcm9wcy5kYlNlY3JldC5ncmFudFJlYWQodGhpcy50aVBnTGFtYmRhRnVuY3Rpb24pO1xuICAgICAgdGhpcy50aVBnTGFtYmRhRnVuY3Rpb24uY29ubmVjdGlvbnMuYWxsb3dUbyhwcm9wcy5kYiwgZWMyLlBvcnQudGNwKDU0MzIpLCBcImFsbG93IGNvbm5lY3Rpb25zIGZyb20gdGlwZ1wiKTtcblxuICAgICAgY29uc3QgdGlwZ0FwaSA9IG5ldyBIdHRwQXBpKHRoaXMsIGAke1N0YWNrLm9mKHRoaXMpLnN0YWNrTmFtZX0tdGlwZy1hcGlgLCB7XG4gICAgICAgIGRlZmF1bHREb21haW5NYXBwaW5nOiBwcm9wcy50aXBnQXBpRG9tYWluTmFtZSA/IHsgXG4gICAgICAgICAgZG9tYWluTmFtZTogcHJvcHMudGlwZ0FwaURvbWFpbk5hbWVcbiAgICAgICAgfSA6IHVuZGVmaW5lZCxcbiAgICAgICAgZGVmYXVsdEludGVncmF0aW9uOiBuZXcgSHR0cExhbWJkYUludGVncmF0aW9uKFwiaW50ZWdyYXRpb25cIiwgdGhpcy50aVBnTGFtYmRhRnVuY3Rpb24pLFxuICAgICAgfSk7XG5cbiAgICAgIHRoaXMudXJsID0gdGlwZ0FwaS51cmwhO1xuXG4gICAgICBuZXcgQ2ZuT3V0cHV0KHRoaXMsIFwidGlwZy1hcGktb3V0cHV0XCIsIHtcbiAgICAgICAgZXhwb3J0TmFtZTogYCR7U3RhY2sub2YodGhpcykuc3RhY2tOYW1lfS10aXAtdXJsYCxcbiAgICAgICAgdmFsdWU6IHRoaXMudXJsLFxuICAgICAgfSk7XG4gICAgfVxuICB9XG5cbiAgZXhwb3J0IGludGVyZmFjZSBUaVBnQXBpTGFtYmRhUHJvcHMge1xuXG4gICAgLyoqXG4gICAgICogVlBDIGludG8gd2hpY2ggdGhlIGxhbWJkYSBzaG91bGQgYmUgZGVwbG95ZWQuXG4gICAgICovXG4gICAgcmVhZG9ubHkgdnBjOiBlYzIuSVZwYztcblxuICAgIC8qKlxuICAgICAqIFJEUyBJbnN0YW5jZSB3aXRoIGluc3RhbGxlZCBwZ1NUQUMuXG4gICAgICovXG4gICAgcmVhZG9ubHkgZGI6IHJkcy5JRGF0YWJhc2VJbnN0YW5jZTtcblxuICAgIC8qKlxuICAgICAqIFN1Ym5ldCBpbnRvIHdoaWNoIHRoZSBsYW1iZGEgc2hvdWxkIGJlIGRlcGxveWVkLlxuICAgICAqL1xuICAgIHJlYWRvbmx5IHN1Ym5ldFNlbGVjdGlvbjogZWMyLlN1Ym5ldFNlbGVjdGlvbjtcblxuICAgIC8qKlxuICAgICAqIFNlY3JldCBjb250YWluaW5nIGNvbm5lY3Rpb24gaW5mb3JtYXRpb24gZm9yIHBnU1RBQyBkYXRhYmFzZS5cbiAgICAgKi9cbiAgICByZWFkb25seSBkYlNlY3JldDogc2VjcmV0c21hbmFnZXIuSVNlY3JldDtcblxuICAgIC8qKlxuICAgICAqIEN1c3RvbSBjb2RlIHRvIHJ1biBmb3IgZmFzdGFwaS1wZ3N0YWMuXG4gICAgICpcbiAgICAgKiBAZGVmYXVsdCAtIHNpbXBsaWZpZWQgdmVyc2lvbiBvZiBmYXN0YXBpLXBnc3RhY1xuICAgICAqL1xuICAgIHJlYWRvbmx5IGFwaUNvZGU/OiBUaVBnQXBpRW50cnlwb2ludDtcblxuICAgIC8qKlxuICAgICAqIEN1c3RvbWl6ZWQgZW52aXJvbm1lbnQgdmFyaWFibGVzIHRvIHNlbmQgdG8gdGl0aWxlci1wZ3N0YWMgcnVudGltZS5cbiAgICAgKi9cbiAgICByZWFkb25seSBhcGlFbnY/OiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+O1xuICBcbiAgICAvKipcbiAgICAgKiBDdXN0b20gRG9tYWluIE5hbWUgZm9yIHRpcGcgQVBJLiBJZiBkZWZpbmVkLCB3aWxsIGNyZWF0ZSB0aGUgXG4gICAgICogZG9tYWluIG5hbWUgYW5kIGludGVncmF0ZSBpdCB3aXRoIHRoZSB0aXBnIEFQSS4gXG4gICAgICogXG4gICAgICogQGRlZmF1bHQgLSB1bmRlZmluZWRcbiAgICAgKi9cbiAgICByZWFkb25seSB0aXBnQXBpRG9tYWluTmFtZT86IElEb21haW5OYW1lO1xuICB9XG5cbiAgZXhwb3J0IGludGVyZmFjZSBUaVBnQXBpRW50cnlwb2ludCB7XG4gICAgLyoqXG4gICAgICogUGF0aCB0byB0aGUgc291cmNlIG9mIHRoZSBmdW5jdGlvbiBvciB0aGUgbG9jYXRpb24gZm9yIGRlcGVuZGVuY2llcy5cbiAgICAgKi9cbiAgICByZWFkb25seSBlbnRyeTogUHl0aG9uRnVuY3Rpb25Qcm9wc1tcImVudHJ5XCJdO1xuICAgIC8qKlxuICAgICAqIFRoZSBwYXRoIChyZWxhdGl2ZSB0byBlbnRyeSkgdG8gdGhlIGluZGV4IGZpbGUgY29udGFpbmluZyB0aGUgZXhwb3J0ZWQgaGFuZGxlci5cbiAgICAgKi9cbiAgICByZWFkb25seSBpbmRleDogUHl0aG9uRnVuY3Rpb25Qcm9wc1tcImluZGV4XCJdO1xuICAgIC8qKlxuICAgICAqIFRoZSBuYW1lIG9mIHRoZSBleHBvcnRlZCBoYW5kbGVyIGluIHRoZSBpbmRleCBmaWxlLlxuICAgICAqL1xuICAgIHJlYWRvbmx5IGhhbmRsZXI6IFB5dGhvbkZ1bmN0aW9uUHJvcHNbXCJoYW5kbGVyXCJdO1xuICB9XG4iXX0=
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
"""
|
|
2
|
+
Handler for AWS Lambda.
|
|
3
|
+
"""
|
|
4
|
+
|
|
5
|
+
import asyncio
|
|
6
|
+
import os
|
|
7
|
+
from mangum import Mangum
|
|
8
|
+
from src.utils import load_pgstac_secret
|
|
9
|
+
|
|
10
|
+
load_pgstac_secret(os.environ["PGSTAC_SECRET_ARN"]) # required for the below imports
|
|
11
|
+
|
|
12
|
+
# skipping linting rule that wants all imports at the top
|
|
13
|
+
from tipg.main import app # noqa: E402
|
|
14
|
+
from tipg.collections import register_collection_catalog # noqa: E402
|
|
15
|
+
from tipg.database import connect_to_db # noqa: E402
|
|
16
|
+
from tipg.settings import ( # noqa: E402
|
|
17
|
+
CustomSQLSettings, # noqa: E402
|
|
18
|
+
DatabaseSettings, # noqa: E402
|
|
19
|
+
PostgresSettings, # noqa: E402
|
|
20
|
+
) # noqa: E402
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
postgres_settings = PostgresSettings()
|
|
24
|
+
db_settings = DatabaseSettings()
|
|
25
|
+
custom_sql_settings = CustomSQLSettings()
|
|
26
|
+
|
|
27
|
+
|
|
28
|
+
@app.on_event("startup")
|
|
29
|
+
async def startup_event() -> None:
|
|
30
|
+
"""Connect to database on startup."""
|
|
31
|
+
await connect_to_db(
|
|
32
|
+
app,
|
|
33
|
+
settings=postgres_settings,
|
|
34
|
+
schemas=db_settings.schemas,
|
|
35
|
+
user_sql_files=custom_sql_settings.sql_files,
|
|
36
|
+
)
|
|
37
|
+
await register_collection_catalog(
|
|
38
|
+
app,
|
|
39
|
+
schemas=db_settings.schemas,
|
|
40
|
+
tables=db_settings.tables,
|
|
41
|
+
exclude_tables=db_settings.exclude_tables,
|
|
42
|
+
exclude_table_schemas=db_settings.exclude_table_schemas,
|
|
43
|
+
functions=db_settings.functions,
|
|
44
|
+
exclude_functions=db_settings.exclude_functions,
|
|
45
|
+
exclude_function_schemas=db_settings.exclude_function_schemas,
|
|
46
|
+
spatial=db_settings.only_spatial_tables,
|
|
47
|
+
)
|
|
48
|
+
|
|
49
|
+
|
|
50
|
+
handler = Mangum(app, lifespan="off")
|
|
51
|
+
|
|
52
|
+
if "AWS_EXECUTION_ENV" in os.environ:
|
|
53
|
+
loop = asyncio.get_event_loop()
|
|
54
|
+
loop.run_until_complete(app.router.startup())
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import base64
|
|
2
|
+
import json
|
|
3
|
+
import boto3
|
|
4
|
+
import os
|
|
5
|
+
|
|
6
|
+
|
|
7
|
+
def load_pgstac_secret(secret_name: str):
|
|
8
|
+
"""Retrieve secrets from AWS Secrets Manager
|
|
9
|
+
|
|
10
|
+
Args:
|
|
11
|
+
secret_name (str): name of aws secrets manager secret containing database connection secrets
|
|
12
|
+
profile_name (str, optional): optional name of aws profile for use in debugger only
|
|
13
|
+
|
|
14
|
+
Returns:
|
|
15
|
+
secrets (dict): decrypted secrets in dict
|
|
16
|
+
"""
|
|
17
|
+
|
|
18
|
+
# Create a Secrets Manager client
|
|
19
|
+
session = boto3.session.Session()
|
|
20
|
+
client = session.client(service_name="secretsmanager")
|
|
21
|
+
|
|
22
|
+
get_secret_value_response = client.get_secret_value(SecretId=secret_name)
|
|
23
|
+
|
|
24
|
+
if "SecretString" in get_secret_value_response:
|
|
25
|
+
secret = json.loads(get_secret_value_response["SecretString"])
|
|
26
|
+
else:
|
|
27
|
+
secret = json.loads(base64.b64decode(get_secret_value_response["SecretBinary"]))
|
|
28
|
+
|
|
29
|
+
try:
|
|
30
|
+
os.environ.update(
|
|
31
|
+
{
|
|
32
|
+
"postgres_host": secret["host"],
|
|
33
|
+
"postgres_dbname": secret["dbname"],
|
|
34
|
+
"postgres_user": secret["username"],
|
|
35
|
+
"postgres_pass": secret["password"],
|
|
36
|
+
"postgres_port": str(secret["port"]),
|
|
37
|
+
}
|
|
38
|
+
)
|
|
39
|
+
except Exception as ex:
|
|
40
|
+
print("Could not load the pgstac environment variables from the secret")
|
|
41
|
+
raise ex
|
|
@@ -66,5 +66,5 @@ class TitilerPgstacApiLambda extends constructs_1.Construct {
|
|
|
66
66
|
}
|
|
67
67
|
exports.TitilerPgstacApiLambda = TitilerPgstacApiLambda;
|
|
68
68
|
_a = JSII_RTTI_SYMBOL_1;
|
|
69
|
-
TitilerPgstacApiLambda[_a] = { fqn: "eoapi-cdk.TitilerPgstacApiLambda", version: "5.
|
|
69
|
+
TitilerPgstacApiLambda[_a] = { fqn: "eoapi-cdk.TitilerPgstacApiLambda", version: "5.3.0" };
|
|
70
70
|
//# 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_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\";\n  import { IDomainName, HttpApi } from \"@aws-cdk/aws-apigatewayv2-alpha\";\n  import { HttpLambdaIntegration } from \"@aws-cdk/aws-apigatewayv2-integrations-alpha\";\n  import { Construct } from \"constructs\";\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      const titilerPgstacEnv = {\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          \"PGSTAC_SECRET_ARN\": props.dbSecret.secretArn,\n      }\n    \n      \n      this.titilerPgstacLambdaFunction = new lambda.Function(this, \"lambda\", {\n        handler: \"handler.handler\",\n        runtime: lambda.Runtime.PYTHON_3_10,\n        code: lambda.Code.fromDockerBuild(__dirname, {\n          file: \"runtime/Dockerfile\",\n          buildArgs: { PYTHON_VERSION: '3.10' },\n        }),\n        timeout: Duration.seconds(30),\n        vpc: props.vpc,\n        vpcSubnets: props.subnetSelection,\n        allowPublicSubnet: true,\n        memorySize: 3008,\n        logRetention: aws_logs.RetentionDays.ONE_WEEK,\n        environment: titilerPgstacEnv,\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      this.titilerPgstacLambdaFunction.connections.allowTo(props.db, ec2.Port.tcp(5432), \"allow connections from titiler\");\n  \n      const stacApi = new HttpApi(this, `${Stack.of(this).stackName}-titiler-pgstac-api`, {\n        defaultDomainMapping: props.titilerPgstacApiDomainName ? { \n          domainName: props.titilerPgstacApiDomainName \n        } : undefined,\n        defaultIntegration: new HttpLambdaIntegration(\"integration\", this.titilerPgstacLambdaFunction),\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    /**\n     * VPC into which the lambda should be deployed.\n     */\n    readonly vpc: ec2.IVpc;\n  \n    /**\n     * RDS Instance with installed pgSTAC.\n     */\n    readonly db: rds.IDatabaseInstance;\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     * 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    readonly titilerPgstacApiDomainName?: IDomainName;\n  }\n"]}
|
package/package.json
CHANGED
package/tox.ini
CHANGED
package/tsconfig.tsbuildinfo
CHANGED
|
@@ -6729,8 +6729,16 @@
|
|
|
6729
6729
|
"version": "dd16f73144a3c7dd2fd759d876d5a6940ba8250dca9f930a324d5637c07a25da",
|
|
6730
6730
|
"affectsGlobalScope": false
|
|
6731
6731
|
},
|
|
6732
|
+
"./lib/stac-browser/index.ts": {
|
|
6733
|
+
"version": "096ba9b2817599e3b8dc280c0d315f3a5fb6d1ae51aff31c4ab13e4da48313ae",
|
|
6734
|
+
"affectsGlobalScope": false
|
|
6735
|
+
},
|
|
6736
|
+
"./lib/tipg-api/index.ts": {
|
|
6737
|
+
"version": "6d028789fd0d34f24dd7d44bd1c5e4c224476c75ca8d6874a4ae6a9f6c37e9f6",
|
|
6738
|
+
"affectsGlobalScope": false
|
|
6739
|
+
},
|
|
6732
6740
|
"./lib/index.ts": {
|
|
6733
|
-
"version": "
|
|
6741
|
+
"version": "f002e6147370577a20a4b47a34767123970b7d1ee8d04c41b09d95161d5f0455",
|
|
6734
6742
|
"affectsGlobalScope": false
|
|
6735
6743
|
},
|
|
6736
6744
|
"./node_modules/typescript/lib/lib.es2020.d.ts": {
|
|
@@ -7115,6 +7123,8 @@
|
|
|
7115
7123
|
"./lib/database/index.ts",
|
|
7116
7124
|
"./lib/ingestor-api/index.ts",
|
|
7117
7125
|
"./lib/stac-api/index.ts",
|
|
7126
|
+
"./lib/stac-browser/index.ts",
|
|
7127
|
+
"./lib/tipg-api/index.ts",
|
|
7118
7128
|
"./lib/titiler-pgstac-api/index.ts",
|
|
7119
7129
|
"./node_modules/@types/node/ts4.8/util.d.ts"
|
|
7120
7130
|
],
|
|
@@ -7132,6 +7142,22 @@
|
|
|
7132
7142
|
"./node_modules/aws-cdk-lib/index.d.ts",
|
|
7133
7143
|
"./node_modules/constructs/lib/index.d.ts"
|
|
7134
7144
|
],
|
|
7145
|
+
"./lib/stac-browser/index.ts": [
|
|
7146
|
+
"./node_modules/@types/node/ts4.8/child_process.d.ts",
|
|
7147
|
+
"./node_modules/@types/node/ts4.8/fs.d.ts",
|
|
7148
|
+
"./node_modules/@types/node/ts4.8/util.d.ts",
|
|
7149
|
+
"./node_modules/aws-cdk-lib/aws-iam/index.d.ts",
|
|
7150
|
+
"./node_modules/aws-cdk-lib/index.d.ts",
|
|
7151
|
+
"./node_modules/constructs/lib/index.d.ts"
|
|
7152
|
+
],
|
|
7153
|
+
"./lib/tipg-api/index.ts": [
|
|
7154
|
+
"./node_modules/@aws-cdk/aws-apigatewayv2-alpha/lib/index.d.ts",
|
|
7155
|
+
"./node_modules/@aws-cdk/aws-apigatewayv2-integrations-alpha/lib/index.d.ts",
|
|
7156
|
+
"./node_modules/@aws-cdk/aws-lambda-python-alpha/lib/index.d.ts",
|
|
7157
|
+
"./node_modules/@types/node/ts4.8/util.d.ts",
|
|
7158
|
+
"./node_modules/aws-cdk-lib/index.d.ts",
|
|
7159
|
+
"./node_modules/constructs/lib/index.d.ts"
|
|
7160
|
+
],
|
|
7135
7161
|
"./lib/titiler-pgstac-api/index.ts": [
|
|
7136
7162
|
"./node_modules/@aws-cdk/aws-apigatewayv2-alpha/lib/index.d.ts",
|
|
7137
7163
|
"./node_modules/@aws-cdk/aws-apigatewayv2-integrations-alpha/lib/index.d.ts",
|