Skip to main content

A Python SDK for integrating with Prescient services

Project description

prescient-sdk

A Python SDK for integrating with Prescient services

SDK Documentation: https://sparkgeo.github.io/prescient-sdk/

Quickstart

Local Development

The project is set up using uv for package management. To develop locally:

  1. Install uv following these intructions

  2. (Optional) Use uv to set up your local env.

    Note that this will happen automatically when you run tests or any python application using uv, so it is not necessary

    uv sync
    
  3. Run the tests

    uv run pytest
    

    or

    make run-tests
    

Configuration

Configuration methods are discussed in the Jupyter Notebook configuration.ipynb

Code Formatting/Linting

Code format is set using the Ruff formatter. To run this formatter:

make format

Adding or removing dependencies

Add or remove dependencies using UV.

In the simplest case, you can add a new dependency like this:

uv add <some-dependency>

To add a dev dependency:

uv add <some-dependency> --dev

To remove a dependency:

uv remove <some-dependency>

For more complex features, see the uv documentation

Build the documentation

Public facing documentation is built using jupyter-books.

The docs folder contains the layout for the public facing documentation.

You can build the documentation locally, and access the built html pages in a local browser:

  1. Build the docs:

    make build-docs
    
  2. Open the html in a browser:

    After building the docs, the path to the index.html file will be logged, and should look something like docs/_build/html/index.html

Cutting a Release

In order to release a new version to be published to PyPI:

  1. Create a new branch from main with the new version as the branch name (v*..) following semantic versioning guidelines.

  2. Update the version in pyproject.toml under the [project] section.

  3. Sync the uv.lock file:

    uv sync
    
  4. Create a Pull Request against the main branch, have it reviewed and merged.

  5. Create a new Release with a tag and title named v*.*.*. Include a description of all major updates included in this new release.

    After the release has been created, you should see Actions running to publish the new release to PyPI, and to update the Github Pages documentation.

  6. conda-forge release

    Unfortunately, releasing new versions to conda-forge is more involved and less automated. See the conda-forge section below for details.

Conda-forge

This package is available on conda-forge, for comprehensive docs see https://conda-forge.org/docs/maintainer/. In order to release new versions you must already be set as a maintainer of the conda-forge recipe. To become a maintainer follow these instructions: https://conda-forge.org/docs/maintainer/updating_pkgs/#updating-the-maintainer-list

The feedstock repo is located here: https://github.com/conda-forge/prescient-sdk-feedstock

Note that any changes to the feedstock repo need to be made from a fork of that repository, do not create a branch in the repo itself if you need to make manual changes.

How to update the conda-forge release after PyPI has been updated

conda-forge bots should automatically create a PR in the feedstock repo after a new PYPI version has been released, but it may not contain all changes that you need (e.g. updated dependencies for example).

  1. Review the automatically created PR in the feedstock repo, specifically looking at the meta.yaml file in the recipe folder.

  2. To ensure dependencies have been properly updated, it is a good idea to use the grayskull recipe generator to create an alternate meta.yaml file locally and compare it to the the automatically generated version in the feedstock PR.

  3. If you want to maintain multiple versions on conda-forge instead of simply keeping the latest version, you may need to manually create a different PR from a different branch, following these instructions: https://conda-forge.org/docs/maintainer/updating_pkgs/#maintaining-several-versions

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

prescient_sdk-0.2.0.tar.gz (420.7 kB view details)

Uploaded Source

Built Distribution

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

prescient_sdk-0.2.0-py3-none-any.whl (9.4 kB view details)

Uploaded Python 3

File details

Details for the file prescient_sdk-0.2.0.tar.gz.

File metadata

  • Download URL: prescient_sdk-0.2.0.tar.gz
  • Upload date:
  • Size: 420.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.11

File hashes

Hashes for prescient_sdk-0.2.0.tar.gz
Algorithm Hash digest
SHA256 5937f75bb6d466b821ce1b29293b82c7b18a8c67f98291cb4a14061dd9b743ed
MD5 93c85e21e83ae798dbde3be735bb24a1
BLAKE2b-256 6412657e3e0a6adb4c2ed5f7294dd46dfaca83f0973f28156242077f19b3c33a

See more details on using hashes here.

File details

Details for the file prescient_sdk-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: prescient_sdk-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 9.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.11

File hashes

Hashes for prescient_sdk-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6210b4c6d0c60cee008f179f3f9bc10069a6e6453a104f51ac611cf67e75104b
MD5 a95c6a9e5c7312a674faae908c85d8a3
BLAKE2b-256 29d93e7c052a679afdc04158167975b9a05010f265b5a6682a2c5b35cfaecbbe

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