Skip to main content

Client for EarthRanger API

Project description

EarthRanger Client

Introduction

EarthRanger is a software solution that helps protected area managers, ecologists, and wildlife biologists make informed operational decisions for wildlife conservation.

The earthranger-client (er-client) is a Python library for accessing the EarthRanger HTTP API. It simplifies interaction with the API by abstracting away the complexity of resource-based endpoints and provides multi-threaded and async capabilities for improved performance.

Uses of er-client

  • Extracting data for analysis
  • Importing ecological or other historical data
  • Integrating a new field sensor type. If you do and will be supporting multiple ER sites, contact us to talk about our Gundi integrations platform
  • Performing external analysis that results in publishing an Alert on the ER platform.

Quick Start

see simple-example.py

Installation

From pypi

pip install earthranger-client

Usage

In your code, import the library and create an instance of the client. You must provide client_id (e.g. example_client_id) for username/password authentication.

from erclient import ERClient

client = ERClient(service_root="https://sandbox.pamdas.org", client_id="example_client_id", username="", password="")

Async Support

We also offer an async client (asyncio).

Disclaimer: The async client current capabilities are limited to:

  • Posting Sensor Observations (a.k.a Positions)
  • Posting Events (a.k.a Reports)
  • Posting Event Attachments
  • Posting Camera Trap Reports
  • Getting Event Types
  • Getting Events
  • Getting Observations
  • Getting Subject Groups
  • Getting Feature groups
  • Getting Sources
  • Getting Source Assignments (aka SubjectSource resources)
  • Deleting Subjects
  • Deleting Sources
from erclient import AsyncERClient

# You can use it as an async context-managed client
async with AsyncERClient(service_root="https://sandbox.pamdas.org", client_id="example_client_id", username="", password="") as client:
   await self.er_client.post_sensor_observation(position)
   await client.post_report(report)
   await self.er_client.post_camera_trap_report(camera_trap_payload, file)
   ...
   
async with AsyncERClient(service_root="https://sandbox.pamdas.org", client_id="example_client_id", username="", password="") as client:
   async for observation in client.get_observations(start="2023-11-10T00:00:00-06:00"):
      print(observation)
      ...

# Or create an instance and close the client explicitly later
client = AsyncERClient(service_root="https://sandbox.pamdas.org", client_id="example_client_id", username="", password="")
await self.er_client.post_sensor_observation(position)
await client.post_report(report)
await self.er_client.post_camera_trap_report(camera_trap_payload, file)
...
await client.close()  # Close the session used to send requests to ER API

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

earthranger_client-1.15.0.tar.gz (320.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

earthranger_client-1.15.0-py3-none-any.whl (27.4 kB view details)

Uploaded Python 3

File details

Details for the file earthranger_client-1.15.0.tar.gz.

File metadata

  • Download URL: earthranger_client-1.15.0.tar.gz
  • Upload date:
  • Size: 320.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.15

File hashes

Hashes for earthranger_client-1.15.0.tar.gz
Algorithm Hash digest
SHA256 989ae4ab05d25d9342d3c346476dc1a4ffbf017761d8d4ad4d32c41e0af92c63
MD5 72d960946efba7c07874d0bc1b6fba4a
BLAKE2b-256 f49d31688d9869d8ff46b0e7d1eb230208949fb9e32926157391fdff7cf94d50

See more details on using hashes here.

File details

Details for the file earthranger_client-1.15.0-py3-none-any.whl.

File metadata

File hashes

Hashes for earthranger_client-1.15.0-py3-none-any.whl
Algorithm Hash digest
SHA256 1de0090199005a2bcabc2b31786c0eea2f4bbe0cad5461a8a973460f52daec97
MD5 eead6fcd40974215b023ae87d56bf40e
BLAKE2b-256 74c74946c03feac1658ec6eb96db20431c2e8e2ea73f3ae0fc990926fa5f6c7d

See more details on using hashes here.

Supported by

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