Skip to main content

Python API client for Enhydris

Project description

enhydris-api-client

Pypi Build Coverage Updates

Python API client for Enhydris

  • Free software: GNU General Public License v3

This package has some functionality to make it easier to use the Enhydris API.

Installation

pip install enhydris-api-client

Example

from enhydris_api_client import EnhydrisApiClient

with EnhydrisApiClient("https://openmeteo.org", "my_auth_token") as api_client:
    # Get a dict with attrs of station with id=42
    station = api_client.get_model(Station, 42)

    # Create a new station
    api_client.post_model(Station, data={"name": "my station"})

Reference

EnhydrisApiClient(base_url, token=None)

Creates and returns an api client. It can also be used as a context manager, though this is not necessary. If not used as a context manager, you might get warnings about unclosed sockets.

Not specifying token is deprecated. token will become mandatory in future versions.

EnhydrisApiClient objects have the following methods:

.get_token(username, password)

(Deprecated.) Gets an API token from Enhydris and thereafter uses it in subsequent requests. The method will be removed in future versions.

.get_station(id)
.post_station(data)
.put_station(station_id, data)
.patch_station(station_id, data)
.delete_station(station_id)

Methods that create, retrieve, update or delete stations. The data argument (for those methods that receive one) is a dictionary. get_station() returns a dictionary with the data for the station. post_station() returns the created station’s id.

.get_timeseries_group(station_id, timeseries_group_id)
.post_timeseries_group(station_id, timeseries_group_id, data)
.put_timeseries_group(station_id, timeseries_group_id, data)
.patch_timeseries_group(station_id, timeseries_group_id, data)
.delete_timeseries_group(station_id, timeseries_group_id)

Methods that create, retrieve, update or delete time series groups. Similar to the ones for station.

.list_timeseries(station_id, timeseries_group_id)
.get_timeseries(station_id, timeseries_group_id, timeseries_id)
.post_timeseries(station_id, timeseries_group_id, data)
.delete_timeseries(station_id, timeseries_group_id, timeseries_id)

Methods that create, retrieve or delete time series. Similar to the ones for station. list_timeseries() returns a list of dictionaries.

.read_tsdata(station_id, timeseries_group_id, timeseries_id, start_date=None, end_date=None, timezone=None)
.post_tsdata(station_id, timeseries_group_id, timeseries_id, ts)
.get_ts_end_date(station_id, timeseries_group_id, timeseries_id, timezone=None)

Methods that retrieve or update time series data.

read_ts_data() retrieves the time series data into a htimeseries object that it returns. If start_date and/or end_date (aware datetime objects) are specified, only the part of the time series between these dates is retrieved. The timestamps are returned in the specified time zone. If unspecified, then they are returned in the time zone specified by the station’s display_timezone.

post_tsdata() `` posts a time series to Enhydris, appending the records to any already existing. ``ts is a htimeseries object.

get_ts_end_date() returns a datetime object which is the last timestamp of the time series. If the time series is empty it returns None. The returned timestamp is always naive, but it is in the specified timezone (or the station’s display_timezone if unspecified).

History

4.0.0 (2024-04-16)

  • Requires htimeseries 7.

  • When downloading time series data without specifying the time zone, it uses the display_timezone of that Enhydris station, whereas in 3.x.x it used UTC. The behaviour is now similar to that of 2.x.x.

3.0.1 (2024-04-14)

  • Compatible with htimeseries 4 to 7.

3.0.0 (2022-12-04)

  • Requires Enhydris 4 and htimeseries 4, and therefore requires aware HTimeseries objects.

  • Supports specifying time zone when downloading time series data.

  • Support for creating, retrieving, updating, and deleting time series groups.

2.0.1 (2021-08-31)

  • Updated dependences (the version of htimeseries required was too old).

2.0.0 (2020-10-06)

  • We now support the time series groups of Enhydris 3. Earlier Enhydris versions are unsupported. Use enhydris-api-client v1 for Enhydris v2.

  • We now use token authentication. Using a username and password have been deprecated and will be removed in a future version. Accordingly, the .login() method has been removed; it has been replaced with the deprecated .get_token() method.

1.0.0 (2020-02-28)

  • We now support only Python 3.7 or greater.

  • If there is an http error, the error message now includes the response body.

0.5.1 (2020-01-05)

  • Minor fix for compatibility with htimeseries 2

0.5.0 (2019-06-13)

  • Can now be used as a context manager

  • Added post/put/patch/delete station

0.4.1 (2019-06-12)

  • Fixed bug where .read_tsdata() was failing to set the metadata attributes of the time series.

0.4.0 (2019-06-12)

  • .read_tsdata() now accepts optional arguments start_date and end_date.

0.3.0 (2019-06-06)

  • Upgrade dependecy htimeseries to 1.0

0.2.0 (2019-04-17)

  • Support new API of Enhydris 3

0.1.0 (2019-03-06)

  • Initial release

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

enhydris-api-client-4.0.0.tar.gz (11.7 kB view details)

Uploaded Source

Built Distribution

enhydris_api_client-4.0.0-py2.py3-none-any.whl (6.1 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file enhydris-api-client-4.0.0.tar.gz.

File metadata

  • Download URL: enhydris-api-client-4.0.0.tar.gz
  • Upload date:
  • Size: 11.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.2

File hashes

Hashes for enhydris-api-client-4.0.0.tar.gz
Algorithm Hash digest
SHA256 11d0d266227064dede6335d363b1f917cc049bedef18827e3681fc888876cc1c
MD5 84ec03f97c0449570c0d3fa34eaa395e
BLAKE2b-256 d9bf16f28ac6221fe0d708edd032817a3d32ac23287296d5645b1e3f6143f2cb

See more details on using hashes here.

File details

Details for the file enhydris_api_client-4.0.0-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for enhydris_api_client-4.0.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 aff43d56bcbc5c6ea0a0b2e6d5b552957807b099056367c83ff5a071561454cd
MD5 bb15a4a067c3360560545b5f98b48f05
BLAKE2b-256 d9ce4a3430f2ec2bd9ee24d2bea22c6bf12f2ce497f415db0ae4249225464377

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page