diff --git a/planet/cli/subscriptions.py b/planet/cli/subscriptions.py index 70b7dad7..b3bfe2ba 100644 --- a/planet/cli/subscriptions.py +++ b/planet/cli/subscriptions.py @@ -249,6 +249,7 @@ async def list_subscription_results_cmd(ctx, help='Source JSON. Can be a string, filename, or - for stdin.') @click.option( '--delivery', + required=True, type=types.JSON(), help=("Delivery configuration, including credentials for a cloud " "storage provider, to enable cloud delivery of data. Can be a " @@ -261,10 +262,6 @@ async def list_subscription_results_cmd(ctx, '--tools', type=types.JSON(), help='Toolchain JSON. Can be a string, filename, or - for stdin.') -@click.option( - '--hosting', - type=types.JSON(), - help='Hosting JSON. Can be a string, a filename, or - for stdin.') @click.option( '--clip-to-source', is_flag=True, @@ -276,7 +273,6 @@ def request(name, delivery, notifications, tools, - hosting, clip_to_source, pretty): """Generate a subscriptions request. @@ -291,7 +287,6 @@ def request(name, delivery, notifications=notifications, tools=tools, - hosting=hosting, clip_to_source=clip_to_source) echo_json(res, pretty) diff --git a/planet/subscription_request.py b/planet/subscription_request.py index 520e3411..fd1273c1 100644 --- a/planet/subscription_request.py +++ b/planet/subscription_request.py @@ -49,10 +49,9 @@ def build_request(name: str, source: Mapping, - delivery: Optional[Mapping] = None, + delivery: Mapping, notifications: Optional[Mapping] = None, tools: Optional[List[Mapping]] = None, - hosting: Optional[Mapping] = None, clip_to_source: Optional[bool] = False) -> dict: """Construct a Subscriptions API request. @@ -66,7 +65,6 @@ def build_request(name: str, notifications: Specify notifications via email/webhook. tools: Tools to apply to the products. The order of operation is determined by the service. - hosting: A hosting destination e.g. Sentinel Hub. clip_to_source: whether to clip to the source geometry or not (the default). If True a clip configuration will be added to the list of requested tools unless an existing clip tool @@ -108,20 +106,17 @@ def build_request(name: str, delivery = amazon_s3(ACCESS_KEY_ID, SECRET_ACCESS_KEY, "test", "us-east-1") - hosting = sentinel_hub("2716077c-191e-4e47-9e3f-01c9c429f88d") - subscription_request = build_request( - "test_subscription", source=source, delivery=delivery, hosting=hosting + "test_subscription", source=source, delivery=delivery ) ``` """ - # Because source is a Mapping we must make copies for + # Because source and delivery are Mappings we must make copies for # the function's return value. dict() shallow copies a Mapping # and returns a new dict. - details = {"name": name, "source": dict(source)} - - if delivery: - details['delivery'] = dict(delivery) + details = { + "name": name, "source": dict(source), "delivery": dict(delivery) + } if notifications: details['notifications'] = dict(notifications) @@ -150,9 +145,6 @@ def build_request(name: str, details['tools'] = tool_list - if hosting: - details['hosting'] = dict(hosting) - return details @@ -743,24 +735,3 @@ def cloud_filter_tool( } return _tool("cloud_filter", result) - - -def _hosting(type: str, parameters: dict) -> dict: - return {"type": type, "parameters": parameters} - - -def sentinel_hub(collection_id: Optional[str]) -> dict: - """Specify a Sentinel Hub hosting destination. - - Requires the user to have a Sentinel Hub account linked with their Planet - account. Subscriptions API will create a new collection to deliver data to - if collection_id is omitted from the request. - - Parameters: - collection_id: Sentinel Hub collection - """ - - parameters = {} - if collection_id: - parameters['collection_id'] = collection_id - return _hosting("sentinel_hub", parameters) diff --git a/tests/integration/test_subscriptions_api.py b/tests/integration/test_subscriptions_api.py index 7fbc9bab..aef5fa8b 100644 --- a/tests/integration/test_subscriptions_api.py +++ b/tests/integration/test_subscriptions_api.py @@ -204,18 +204,6 @@ async def test_create_subscription_success(): assert sub['name'] == 'test' -@pytest.mark.anyio -@create_mock -async def test_create_subscription_with_hosting_success(): - """Subscription is created, description has the expected items.""" - async with Session() as session: - client = SubscriptionsClient(session, base_url=TEST_URL) - sub = await client.create_subscription({ - 'name': 'test', 'source': 'test', 'hosting': 'yes, please' - }) - assert sub['name'] == 'test' - - @pytest.mark.anyio @failing_api_mock async def test_cancel_subscription_failure(): diff --git a/tests/integration/test_subscriptions_cli.py b/tests/integration/test_subscriptions_cli.py index 25b462dd..3ac230ee 100644 --- a/tests/integration/test_subscriptions_cli.py +++ b/tests/integration/test_subscriptions_cli.py @@ -95,16 +95,11 @@ def test_subscriptions_create_failure(invoke): # It must be updated when we begin to test against a more strict # imitation of the Planet Subscriptions API. GOOD_SUB_REQUEST = {'name': 'lol', 'delivery': True, 'source': 'wut'} -GOOD_SUB_REQUEST_WITH_HOSTING = { - 'name': 'lol', 'source': 'wut', 'hosting': True -} @pytest.mark.parametrize('cmd_arg, runner_input', [('-', json.dumps(GOOD_SUB_REQUEST)), - (json.dumps(GOOD_SUB_REQUEST), None), - ('-', json.dumps(GOOD_SUB_REQUEST_WITH_HOSTING)), - (json.dumps(GOOD_SUB_REQUEST_WITH_HOSTING), None)]) + (json.dumps(GOOD_SUB_REQUEST), None)]) @create_mock def test_subscriptions_create_success(invoke, cmd_arg, runner_input): """Subscriptions creation succeeds with a valid subscription request.""" diff --git a/tests/unit/test_subscription_request.py b/tests/unit/test_subscription_request.py index 2aa12f08..ef4e4348 100644 --- a/tests/unit/test_subscription_request.py +++ b/tests/unit/test_subscription_request.py @@ -119,59 +119,6 @@ def test_build_request_clip_to_source_failure(geom_geojson): ) -def test_build_request_host_sentinel_hub_with_collection(geom_geojson): - source = { - "type": "catalog", - "parameters": { - "geometry": geom_geojson, - "start_time": "2021-03-01T00:00:00Z", - "end_time": "2023-11-01T00:00:00Z", - "rrule": "FREQ=MONTHLY;BYMONTH=3,4,5,6,7,8,9,10", - "item_types": ["PSScene"], - "asset_types": ["ortho_analytic_4b"] - } - } - - hosting = {"type": "sentinel-hub"} - - res = subscription_request.build_request('test', - source=source, - hosting=hosting) - - expected = {"name": "test", "source": source, "hosting": hosting} - - assert res == expected - - -def test_build_request_host_sentinel_hub_no_collection(geom_geojson): - source = { - "type": "catalog", - "parameters": { - "geometry": geom_geojson, - "start_time": "2021-03-01T00:00:00Z", - "end_time": "2023-11-01T00:00:00Z", - "rrule": "FREQ=MONTHLY;BYMONTH=3,4,5,6,7,8,9,10", - "item_types": ["PSScene"], - "asset_types": ["ortho_analytic_4b"] - } - } - - hosting = { - "type": "sentinel-hub", - "parameters": { - "collection_id": "4c9af036-4274-4a97-bf0d-eb2a7853330d" - } - } - - res = subscription_request.build_request('test', - source=source, - hosting=hosting) - - expected = {"name": "test", "source": source, "hosting": hosting} - - assert res == expected - - def test_catalog_source_success(geom_geojson): res = subscription_request.catalog_source( item_types=["PSScene"],