Skip to content

Commit

Permalink
Merge pull request #88 from /issues/87
Browse files Browse the repository at this point in the history
removed default bounding box per issue #87
  • Loading branch information
mike-gangl authored Jun 22, 2022
2 parents 9105adf + 2e95b4e commit 2fc34ce
Show file tree
Hide file tree
Showing 4 changed files with 46 additions and 54 deletions.
5 changes: 5 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,11 @@ All notable changes to this project will be documented in this file.

The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/)

## Unreleased
### Fixed
- Fixed an issue where using a default global bounding box prevented download of data that didn't use the horizontal spatial domain [87](https://github.com/podaac/data-subscriber/issues/87)


## [1.10.1]
### Fixed
- Support for SHA-256 and SHA-512 checksums
Expand Down
17 changes: 9 additions & 8 deletions subscriber/podaac_access.py
Original file line number Diff line number Diff line change
Expand Up @@ -129,16 +129,17 @@ def refresh_token(old_token: str, client_id: str):


def validate(args):
bounds = args.bbox.split(',')
if len(bounds) != 4:
raise ValueError(
"Error parsing '--bounds': " + args.bbox + ". Format is W Longitude,S Latitude,E Longitude,N Latitude without spaces ") # noqa E501
for b in bounds:
try:
float(b)
except ValueError:
if args.bbox is not None:
bounds = args.bbox.split(',')
if len(bounds) != 4:
raise ValueError(
"Error parsing '--bounds': " + args.bbox + ". Format is W Longitude,S Latitude,E Longitude,N Latitude without spaces ") # noqa E501
for b in bounds:
try:
float(b)
except ValueError:
raise ValueError(
"Error parsing '--bounds': " + args.bbox + ". Format is W Longitude,S Latitude,E Longitude,N Latitude without spaces ") # noqa E501

if args.startDate:
try:
Expand Down
26 changes: 11 additions & 15 deletions subscriber/podaac_data_downloader.py
Original file line number Diff line number Diff line change
Expand Up @@ -66,14 +66,14 @@ def create_parser():
help="The ISO date time before which data should be retrieved. For Example, --start-date 2021-01-14T00:00:00Z") # noqa E501
parser.add_argument("-ed", "--end-date", required=False, dest="endDate",
help="The ISO date time after which data should be retrieved. For Example, --end-date 2021-01-14T00:00:00Z") # noqa E501

# Adding optional arguments
parser.add_argument("-f", "--force", dest="force", action="store_true", help = "Flag to force downloading files that are listed in CMR query, even if the file exists and checksum matches") # noqa E501

# spatiotemporal arguments
parser.add_argument("-b", "--bounds", dest="bbox",
help="The bounding rectangle to filter result in. Format is W Longitude,S Latitude,E Longitude,N Latitude without spaces. Due to an issue with parsing arguments, to use this command, please use the -b=\"-180,-90,180,90\" syntax when calling from the command line. Default: \"-180,-90,180,90\".",
default="-180,-90,180,90") # noqa E501
default=None) # noqa E501

# Arguments for how data are stored locally - much processing is based on
# the underlying directory structure (e.g. year/Day-of-year)
Expand Down Expand Up @@ -158,9 +158,6 @@ def run(args=None):
logging.info("NOTE: Making new data directory at " + data_path + "(This is the first run.)")
makedirs(data_path, exist_ok=True)

# Change this to whatever extent you need. Format is W Longitude,S Latitude,E Longitude,N Latitude
bounding_extent = args.bbox

if search_cycles is not None:
cmr_cycles = search_cycles
params = [
Expand All @@ -169,7 +166,6 @@ def run(args=None):
('provider', provider),
('ShortName', short_name),
('token', token),
('bounding_box', bounding_extent),
]
for v in cmr_cycles:
params.append(("cycle[]", v))
Expand All @@ -179,20 +175,20 @@ def run(args=None):
else:
temporal_range = pa.get_temporal_range(start_date_time, end_date_time,
datetime.utcnow().strftime("%Y-%m-%dT%H:%M:%SZ")) # noqa E501
params = {
'page_size': page_size,
'sort_key': "-start_date",
'provider': provider,
'ShortName': short_name,
'temporal': temporal_range,
'token': token,
'bounding_box': bounding_extent,
}
params = [
('page_size', page_size),
('sort_key', "-start_date"),
('provider', provider),
('ShortName', short_name),
('temporal', temporal_range),
]
if args.verbose:
logging.info("Temporal Range: " + temporal_range)

if args.verbose:
logging.info("Provider: " + provider)
if args.bbox is not None:
params.append(('bounding_box', args.bbox))

# If 401 is raised, refresh token and try one more time
try:
Expand Down
52 changes: 21 additions & 31 deletions subscriber/podaac_data_subscriber.py
Original file line number Diff line number Diff line change
Expand Up @@ -73,7 +73,7 @@ def create_parser():
default=False) # noqa E501
parser.add_argument("-b", "--bounds", dest="bbox",
help="The bounding rectangle to filter result in. Format is W Longitude,S Latitude,E Longitude,N Latitude without spaces. Due to an issue with parsing arguments, to use this command, please use the -b=\"-180,-90,180,90\" syntax when calling from the command line. Default: \"-180,-90,180,90\".",
default="-180,-90,180,90") # noqa E501
default=None) # noqa E501

# Arguments for how data are stored locally - much processing is based on
# the underlying directory structure (e.g. year/Day-of-year)
Expand Down Expand Up @@ -178,46 +178,36 @@ def run(args=None):
else:
logging.warning("No .update__" + short_name + " in the data directory. (Is this the first run?)")

# Change this to whatever extent you need. Format is W Longitude,S Latitude,E Longitude,N Latitude
bounding_extent = args.bbox

# There are several ways to query for CMR updates that occured during a given timeframe. Read on in the CMR Search documentation:
# * https://cmr.earthdata.nasa.gov/search/site/docs/search/api.html#c-with-new-granules (Collections)
# * https://cmr.earthdata.nasa.gov/search/site/docs/search/api.html#c-with-revised-granules (Collections)
# * https://cmr.earthdata.nasa.gov/search/site/docs/search/api.html#g-production-date (Granules)
# * https://cmr.earthdata.nasa.gov/search/site/docs/search/api.html#g-created-at (Granules)
# The `created_at` parameter works for our purposes. It's a granule search parameter that returns the records ingested since the input timestamp.

if defined_time_range:
# if(data_since):
temporal_range = pa.get_temporal_range(start_date_time, end_date_time,
datetime.utcnow().strftime("%Y-%m-%dT%H:%M:%SZ")) # noqa E501

params = {
'page_size': page_size,
'sort_key': "-start_date",
'provider': provider,
'ShortName': short_name,
'updated_since': data_within_last_timestamp,
'token': token,
'bounding_box': bounding_extent,
}
params = [
('page_size',page_size),
('sort_key', "-start_date"),
('provider', provider),
('ShortName', short_name),
('updated_since', data_within_last_timestamp),
('token', token),
]

if defined_time_range:
params = {
'page_size': page_size,
'sort_key': "-start_date",
'provider': provider,
'updated_since': data_within_last_timestamp,
'ShortName': short_name,
'temporal': temporal_range,
'token': token,
'bounding_box': bounding_extent,
}

params = [
('page_size', page_size),
('sort_key', "-start_date"),
('provider', provider),
('updated_since', data_within_last_timestamp),
('ShortName', short_name),
('temporal', temporal_range),
('token', token),
]
if args.verbose:
logging.info("Temporal Range: " + temporal_range)

if args.bbox is not None:
params.append(('bounding_box', args.bbox))

if args.verbose:
logging.info("Provider: " + provider)
logging.info("Updated Since: " + data_within_last_timestamp)
Expand Down

0 comments on commit 2fc34ce

Please sign in to comment.