Skip to main content

An SDK for EarthScope API

Project description

EarthScope SDK

An SDK for interacting with EarthScope's APIs

Getting Started

Installation

Install from PyPI

pip install earthscope-sdk

Or with optional dependencies:

# install arrow dependencies for efficient data access
pip install earthscope-sdk[arrow]

Usage

For detailed usage info and examples, visit our SDK docs.

# Import and create a client
from earthscope_sdk import EarthScopeClient

client = EarthScopeClient()

# Example client method usage; retrieve your user profile
profile = client.user.get_profile()
print(profile)

# Client cleanup
client.close()

Async Usage

There is also an async client available

import asyncio
from earthscope_sdk import AsyncEarthScopeClient

async def main():
    client = AsyncEarthScopeClient()

    profile = await client.user.get_profile()
    print(profile)

    await client.close()

asyncio.run(main())

Context Managers

Client classes can also be used as context managers to ensure resource cleanup occurs.

# sync
with EarthScopeClient() as client:
   client.user.get_profile()

# async
async with AsyncEarthScopeClient() as client:
   await client.user.get_profile()

Bootstrapping Authentication

There are a few methods of bootstrapping authentication for the SDK.

Once refreshable credentials are available to the SDK, it will transparently handle access token refresh on your behalf.

Same host

If you have the EarthScope CLI installed on the same host that is running your application which uses earthscope-sdk, you can simply log in using the CLI. The CLI shares credentials and configuration with this SDK (when running on the same host).

Running es login will open your browser and prompt you to log in to your EarthScope account.

$ es login
Attempting to automatically open the SSO authorization page in your default browser.
If the browser does not open or you wish to use a different device to authorize this request, open the following URL:

https://login.earthscope.org/activate?user_code=ABCD-EFGH

Successful login! Access token expires at 2024-12-27 18:50:37+00:00

Now when you run your application, earthscope-sdk will find your credentials.

Different hosts

Sometimes your workload runs on different hosts than your main workstation and you cannot feasibly "log in" on all of them. For example, maybe you're running many containers in your workload.

You can still use the EarthScope CLI to facilitate auth for applications on other machines.

  1. Use the CLI on your primary workstation as described above to log in.

  2. Use the CLI to retrieve your refresh token.

    $ es user get-refresh-token
    <your-refresh-token>
    

    Note: your refresh token should be treated as a secret credential. Anyone with a valid refresh token can use it to continually retrieve new access tokens on your behalf.

  3. Pass this refresh token to all the hosts needing auth for the earthscope-sdk. For example, inject the ES_OAUTH2__REFRESH_TOKEN environment variable on these hosts.

    export ES_OAUTH2__REFRESH_TOKEN="<your-refresh-token>"
    

SDK Settings

SDK Settings are provided via the following methods (in order of precedence):

  1. initialization arguments (e.g. via class constructors)
  2. environment variables
  3. dotenv file (.env) variables
  4. user's home directory settings files
    1. ~/.earthscope/config.toml (for configuration)
    2. ~/.earthscope/<profile-name>/tokens.json (for tokens)
  5. legacy EarthScope CLI v0 credentials
  6. default settings

SDK configuration is managed by the SdkSettings class, and calling the constructor performs this settings loading chain.

from earthscope_sdk.config.settings import SdkSettings

settings = SdkSettings()  # loads settings via loading chain

For more details on SDK configuration, including what options are available, see our settings docs.

Contributing

For details on contributing to the EarthScope SDK, please see:

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

earthscope_sdk-1.3.0.tar.gz (72.3 kB view details)

Uploaded Source

Built Distribution

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

earthscope_sdk-1.3.0-py3-none-any.whl (76.5 kB view details)

Uploaded Python 3

File details

Details for the file earthscope_sdk-1.3.0.tar.gz.

File metadata

  • Download URL: earthscope_sdk-1.3.0.tar.gz
  • Upload date:
  • Size: 72.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.25

File hashes

Hashes for earthscope_sdk-1.3.0.tar.gz
Algorithm Hash digest
SHA256 1e0fda8187a2fcfca60b04ad8d1ff2888f86ea3beefc9e6c8cf2a7daf708cafd
MD5 1e7b9af911b87b0de4d2d0e33539b00b
BLAKE2b-256 2ea9270b5fca84584b4f0edbbaddf074289f62cd2215690334738ea38e2505f0

See more details on using hashes here.

File details

Details for the file earthscope_sdk-1.3.0-py3-none-any.whl.

File metadata

  • Download URL: earthscope_sdk-1.3.0-py3-none-any.whl
  • Upload date:
  • Size: 76.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.25

File hashes

Hashes for earthscope_sdk-1.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 56494369a114c59a137afbcfa08dbee7268d20dff0e8d7fcbd272597056573f7
MD5 5d8f9a01930b9f0ad20c507b4ac7cf03
BLAKE2b-256 6a5c3102e8c039e70f7e8cf579dbcdfbf5244860565c10d5e74a7cd608ccc960

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