- Bump the minimum version of
aiohttp-client-cache>=0.12.3
to fix an issue with the latest version ofaiohttp
. (:issue_async:`48`)
- Drop support for Python 3.8 since its end-of-life date is October 2024.
- Remove all exceptions from the main module and raise them from the
exceptions
module. This is to declutter the public API and make it easier to maintain.
- Make
nest_asyncio
a required dependency since most users will need it to run the package in Jupyter notebooks.
- Drop support for Python 3.8 since its end-of-life date is October 2024.
- Add the
exceptions
module to the high-level API to declutter the main module. In the future, all exceptions will be raised from this module and not from the main module. For now, the exceptions are raised from both modules for backward compatibility. - Switch to using the
src
layout instead of theflat
layout for the package structure. This is to make the package more maintainable and to avoid any potential conflicts with other packages. - Add artifact attestations to the release workflow.
- When a request fails with encoding error, it gets retried with the
encoding set to
latine1
. This is to handle cases where the server sends a response with an encoding that is not supported by the client. (:issue_hydro:`120`)
- Add a new environmental variable called
"HYRIVER_SSL_CERT"
for setting the path to a SSL certificate file other than the default one. You can do this like so:
import os
os.environ["HYRIVER_SSL_CERT"] = "path/to/file.pem"
- Fix an issue with getting all valid keywords that
aiohttp
accepts by usingaiohttp.ClientSession()._request
directly.
From release 0.15 onward, all minor versions of HyRiver packages
will be pinned. This ensures that previous minor versions of HyRiver
packages cannot be installed with later minor releases. For example,
if you have py3dep==0.14.x
installed, you cannot install
pydaymet==0.15.x
. This is to ensure that the API is
consistent across all minor versions.
- When
raise_status
isFalse
, responses for failed requests used to return asNone
but their requests ID was not returned, so sorting would have failed. Now request IDs are returned for all requests regardless of whether they were successful or not. - Give precedence to non-default arguments for caching related arguments instead of directly getting them from env variables. This is to avoid the case where the user sets the env variables but then passes different arguments to the function. In this case, the function should use the passed arguments instead of the env variables.
- Add a new option to all functions called
raise_status
. IfFalse
no exception will be raised and insteadNone
is returned for those requests that led to exceptions. This will allow for returning all responses that were successful and ignoring the ones that failed. This option defaults toTrue
for retaining backward compatibility. - Set the cache expiration time to one week from never expire. To ensure all users have a smooth transition, cache files that were created before the release of this version will be deleted, and a new cache will be created.
- Sync all minor versions of HyRiver packages to 0.14.0.
- Rewrite the private
async_session
function as two separate functions calledasync_session_without_cache
andasync_session_with_cache
. This makes the code more readable and easier to maintain. - Fully migrate
setup.cfg
andsetup.py
topyproject.toml
. - Convert relative imports to absolute with
absolufy-imports
. - Make
utils
module private. - Sync all patch versions of HyRiver packages to x.x.12.
- Refactor the
show_versions
function to improve performance and print the output in a nicer table-like format.
- Fix a bug in reading the
HYRIVER_CACHE_EXPIRE
environmental variable. - Bump the minimum version of
aiohttp-client-cache
to 0.8.1 to fix a bug in reading cache files that were created with previous versions. (:issue_async:`41`)
- Enable
fast_save
inaiohttp-client-cache
to speed up saving responses to the cache file. - Use
pyright
for type checking instead ofmypy
and fix all type errors. - Skip 0.13.8/9 versions so the minor version of all HyRiver packages become the same.
- Add support for specifying the chunk size in
stream_write
. Defaults toNone
which was the default behavior before, and means iterating over and writing the responses as they are received from the server.
- Use
pyupgrade
package to update the type hinting annotations to Python 3.10 style. - Modify the codebase based on Refurb suggestions.
- Add the missing PyPi classifiers for the supported Python versions.
- Release the package as both
async_retriever
andasync-retriever
on PyPi and Conda-forge.
- Append "Error" to all exception classes for conforming to PEP-8 naming conventions.
- Bump minimum version of
aiohttp-client-cache
to 0.7.3 since theattrs
version issue has been addressed.
- Add a new function,
stream_write
, for writing a response to a file as it's being retrieved. This could be very useful for downloading large files. This function does not use persistent caching.
- Set the minimum supported version of Python to 3.8 since many of the
dependencies such as
xarray
,pandas
,rioxarray
have dropped support for Python 3.7.
- Use micromamba for running tests and use nox for linting in CI.
Add support for setting caching-related arguments using three environmental variables:
HYRIVER_CACHE_NAME
: Path to the caching SQLite database.HYRIVER_CACHE_EXPIRE
: Expiration time for cached requests in seconds.HYRIVER_CACHE_DISABLE
: Disable reading/writing from/to the cache file.
You can do this like so:
import os
os.environ["HYRIVER_CACHE_NAME"] = "path/to/file.sqlite"
os.environ["HYRIVER_CACHE_EXPIRE"] = "3600"
os.environ["HYRIVER_CACHE_DISABLE"] = "true"
- Include the URL of a failed request in its exception error message.
- Add three new functions called
retrieve_text
,retrieve_json
, andretrieve_binary
. These functions are derived from theretrieve
function and are used to retrieve the text, JSON, or binary content of a response. They are meant to help with type hinting since they have only one return type instead of the three different return types that theretrieve
function has.
- Move all private functions to a new module called
utils
. This makes the code-base more readable and easier to maintain.
- Set the expiration time to never expire by default.
- Add two new arguments to
retrieve
for controlling caching. First,delete_url_cache
for deleting caches for specific requests. Second,expire_after
for setting a custom expiration time. - Expose the
ssl
argument for disabling the SSL certification verification (:issue_day:`41`). - Add a new option called
disable
that temporarily disables caching requests/responses if set toTrue
. It defaults toFalse
.
- Add two new arguments,
timeout
andexpire_after
, toretrieve
. These two arguments give the user more control in dealing with issues related to caching.
- Revert to
pytest
as the testing framework. - Use
importlib-metadata
for getting the version instead ofpkg_resources
to decrease import time as discussed in this issue.
- Use
ujon
for converting responses to JSON.
- Fix an issue with catching service error messages.
- Use
ujson
for JSON parsing instead oforjson
sinceorjson
only serializes tobytes
which is not compatible withaiohttp
.
- Add a new function,
clean_cache
, for manually removing the expired responses from the cache database.
- Handle all cache file-related operations in the
create_cachefile
function.
- The responses now are returned to the same order as the input URLs.
- Add support for passing connection type, i.e., IPv4 only, IPv6 only,
or both via the
family
argument. Defaults toboth
. - Set
trust_env=True
, so the session can read the system'snetrc
files. This can be useful for working with services such as EarthData service that read the user authentication info from anetrc
file.
- Replace the
AsyncRequest
class with the_retrieve
function to increase readability and reduce overhead. - More robust handling of validating user inputs via a new class called
ValidateInputs
. - Move all if-blocks in
async_session
to other functions to improve performance.
- Make persistent caching dependencies required.
- Rename
request
argument torequest_method
inretrieve
which now accepts both lower and upper cases ofget
andpost
.
- Pass a new loop explicitly to
nest_asyncio
(:issue_async:`1`).
- Refactor the entire code-base for more efficient handling of different request methods.
- Check the validity of inputs before sending requests.
- Improve documentation.
- Improve cache handling by removing the expired responses before returning the results.
- Increase testing coverage to 100%.
- Initial release.