Skip to content

Commit

Permalink
Release/1.5.0 (#244)
Browse files Browse the repository at this point in the history
* Paginate DynamoDB query results to return all items

* Update changelog with issue

* Update changelog for release candidate 1.5.0

* Update Hydrocron dependencies

* Disable pylint warning for too many positional arguments

* Update VCR to decode compressed response for track ingest CMR test

* /version 1.5.0rc1

---------

Co-authored-by: nikki-t <[email protected]>
  • Loading branch information
nikki-t and nikki-t authored Oct 10, 2024
1 parent 027afd1 commit 7d8fd12
Show file tree
Hide file tree
Showing 7 changed files with 3,647 additions and 4,075 deletions.
10 changes: 10 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,12 +5,22 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).

## [Unreleased]

### Added
### Changed
### Deprecated
### Removed
### Fixed
### Security

## [1.5.0]

### Added
### Changed
### Deprecated
### Removed
### Fixed
- Issue 243 - Fix cases where not all time steps were returned for a feature id
### Security

## [1.4.0]
Expand Down
11 changes: 3 additions & 8 deletions hydrocron/api/controllers/timeseries.py
Original file line number Diff line number Diff line change
Expand Up @@ -213,7 +213,7 @@ def sanitize_time(start_time, end_time):
return start_time, end_time


def timeseries_get(feature, feature_id, start_time, end_time, output, fields): # noqa: E501
def timeseries_get(feature, feature_id, start_time, end_time, output, fields): # pylint: disable=too-many-positional-arguments
"""Get Timeseries for a particular Reach, Node, or LakeID
Get Timeseries for a particular Reach, Node, or LakeID # noqa: E501
Expand All @@ -239,12 +239,7 @@ def timeseries_get(feature, feature_id, start_time, end_time, output, fields):
hits = 0

data_repository = DynamoDataRepository(connection.dynamodb_resource)
if feature.lower() == 'reach':
results = data_repository.get_reach_series_by_feature_id(feature_id, start_time, end_time)
if feature.lower() == 'node':
results = data_repository.get_node_series_by_feature_id(feature_id, start_time, end_time)
if feature.lower() == 'priorlake':
results = data_repository.get_prior_lake_series_by_feature_id(feature_id, start_time, end_time)
results = data_repository.get_series_by_feature_id(feature, feature_id, start_time, end_time)

if len(results['Items']) == 0:
data['http_code'] = '400 Bad Request'
Expand Down Expand Up @@ -344,7 +339,7 @@ def add_units(gdf, columns):
return columns + unit_columns


def get_response(results, hits, elapsed, return_type, output, compact):
def get_response(results, hits, elapsed, return_type, output, compact): # pylint: disable=too-many-positional-arguments
"""Create and return HTTP response based on results.
:param results: Dictionary of SWOT timeseries results
Expand Down
93 changes: 54 additions & 39 deletions hydrocron/api/data_access/db.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
import logging

from boto3.resources.base import ServiceResource
from boto3.dynamodb.conditions import Key # noqa: E501 # pylint: disable=C0412
from boto3.dynamodb.conditions import Key, And # noqa: E501 # pylint: disable=C0412

from hydrocron.utils import constants

Expand All @@ -19,61 +19,76 @@ def __init__(self, dynamo_resource: ServiceResource):
self._dynamo_instance = dynamo_resource
self._logger = logging.getLogger('hydrocron.api.data_access.db.DynamoDataRepository')

def get_reach_series_by_feature_id(self, feature_id: str, start_time: str, end_time: str): # noqa: E501 # pylint: disable=W0613
def get_series_by_feature_id(self, feature_type: str, feature_id: str, start_time: str, end_time: str): # noqa: E501 # pylint: disable=W0613
"""
@param feature_type:
@param feature_id:
@param start_time:
@param end_time:
@return:
"""
table_name = constants.SWOT_REACH_TABLE_NAME

hydrocron_table = self._dynamo_instance.Table(table_name)
hydrocron_table.load()

items = hydrocron_table.query(KeyConditionExpression=(
Key(constants.SWOT_REACH_PARTITION_KEY).eq(feature_id) &
Key(constants.SWOT_REACH_SORT_KEY).between(start_time, end_time))
)
return items

def get_node_series_by_feature_id(self, feature_id, start_time, end_time): # noqa: E501 # pylint: disable=W0613
"""
@param feature_id:
@param start_time:
@param end_time:
@return:
"""
table_name = constants.SWOT_NODE_TABLE_NAME

hydrocron_table = self._dynamo_instance.Table(table_name)
hydrocron_table.load()
if feature_type.lower() == 'reach':
table_name = constants.SWOT_REACH_TABLE_NAME
partition_key = constants.SWOT_REACH_PARTITION_KEY
sort_key = constants.SWOT_REACH_SORT_KEY
elif feature_type.lower() == 'node':
table_name = constants.SWOT_NODE_TABLE_NAME
partition_key = constants.SWOT_NODE_PARTITION_KEY
sort_key = constants.SWOT_NODE_SORT_KEY
elif feature_type.lower() == 'priorlake':
table_name = constants.SWOT_PRIOR_LAKE_TABLE_NAME
partition_key = constants.SWOT_PRIOR_LAKE_PARTITION_KEY
sort_key = constants.SWOT_PRIOR_LAKE_SORT_KEY
else:
table_name = ''
partition_key = ''
sort_key = ''

if table_name:
hydrocron_table = self._dynamo_instance.Table(table_name)
hydrocron_table.load()
key_condition_expression = (
Key(partition_key).eq(feature_id) &
Key(sort_key).between(start_time, end_time)
)
items = self._query_hydrocron_table(hydrocron_table, key_condition_expression)
else:
items = {'Items': []}

items = hydrocron_table.query(KeyConditionExpression=(
Key(constants.SWOT_NODE_PARTITION_KEY).eq(feature_id) &
Key(constants.SWOT_NODE_SORT_KEY).between(start_time, end_time))
)
return items

def get_prior_lake_series_by_feature_id(self, feature_id, start_time, end_time): # noqa: E501 # pylint: disable=W0613
def _query_hydrocron_table(self, hydrocron_table: str, key_condition_expression: And):
"""
@param feature_id:
@param start_time:
@param end_time:
@param hydrocron_table:
@param key_condition_expression:
@return:
"""
table_name = constants.SWOT_PRIOR_LAKE_TABLE_NAME

hydrocron_table = self._dynamo_instance.Table(table_name)
hydrocron_table.load()
items = hydrocron_table.query(
KeyConditionExpression=key_condition_expression
)
last_key_evaluated = ''
if 'LastEvaluatedKey' in items.keys():
last_key_evaluated = items['LastEvaluatedKey']

while last_key_evaluated:
next_items = hydrocron_table.query(
ExclusiveStartKey=last_key_evaluated,
KeyConditionExpression=key_condition_expression
)
items['Items'].extend(next_items['Items'])
items['Count'] += next_items['Count']
items['ScannedCount'] += next_items['ScannedCount']
items['ResponseMetadata'] = next_items['ResponseMetadata']
last_key_evaluated = ''
if 'LastEvaluatedKey' in next_items.keys():
last_key_evaluated = next_items['LastEvaluatedKey']
else:
items.pop('LastEvaluatedKey')

items = hydrocron_table.query(KeyConditionExpression=(
Key(constants.SWOT_PRIOR_LAKE_PARTITION_KEY).eq(feature_id) &
Key(constants.SWOT_PRIOR_LAKE_SORT_KEY).between(start_time, end_time))
)
return items

def get_granule_ur(self, table_name, granule_ur):
Expand Down
Loading

0 comments on commit 7d8fd12

Please sign in to comment.