Skip to content

Commit

Permalink
fix: requester pays get head object if configured
Browse files Browse the repository at this point in the history
  • Loading branch information
anayeaye committed Jun 3, 2024
1 parent f5bd3ac commit e538be4
Show file tree
Hide file tree
Showing 4 changed files with 22 additions and 1 deletion.
5 changes: 5 additions & 0 deletions ingest_api/infrastructure/config.py
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,11 @@ class IngestorConfig(BaseSettings):
None, description="ARN of AWS Role used to validate access to S3 data"
)

raster_aws_request_payer: Optional[str] = Field(
None,
description="Set optional global parameter to 'requester' if the requester agrees to pay S3 transfer costs",
)

stac_api_url: str = Field(description="URL of STAC API used to serve STAC Items")

raster_api_url: str = Field(
Expand Down
4 changes: 4 additions & 0 deletions ingest_api/infrastructure/construct.py
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,10 @@ def __init__(
build_api_lambda_params["data_access_role"] = iam.Role.from_role_arn(
self, "data-access-role", config.raster_data_access_role_arn
)

if config.raster_aws_request_payer:
lambda_env["AWS_REQUEST_PAYER"] = config.raster_aws_request_payer

build_api_lambda_params["env"] = lambda_env

# create lambda
Expand Down
5 changes: 5 additions & 0 deletions ingest_api/runtime/src/config.py
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,11 @@ class Settings(BaseSettings):
description="ARN of AWS Role used to validate access to S3 data"
)

aws_request_payer: Optional[str] = Field(
None,
description="Set optional global parameter to 'requester' if the requester agrees to pay S3 transfer costs",
)

stac_url: AnyHttpUrl = Field(description="URL of STAC API")

userpool_id: str = Field(description="The Cognito Userpool used for authentication")
Expand Down
9 changes: 8 additions & 1 deletion ingest_api/runtime/src/validators.py
Original file line number Diff line number Diff line change
Expand Up @@ -28,9 +28,16 @@ def s3_object_is_accessible(bucket: str, key: str):
"""
Ensure we can send HEAD requests to S3 objects.
"""
from src.main import settings

client = boto3.client("s3", **get_s3_credentials())
try:
client.head_object(Bucket=bucket, Key=key)
if settings.aws_request_payer:
client.head_object(
Bucket=bucket, Key=key, RequestPayer=settings.aws_request_payer
)
else:
client.head_object(Bucket=bucket, Key=key)
except client.exceptions.ClientError as e:
raise ValueError(
f"Asset not accessible: {e.__dict__['response']['Error']['Message']}"
Expand Down

0 comments on commit e538be4

Please sign in to comment.