Skip to main content

A Jupyter server extension providing a TiTiler server, proxy, and a Python API to add Xarray datasets to the TiTiler server.

This project has been archived.

The maintainers of this project have marked this project as archived. No new releases are expected.

Project description

Jupyter Xarray Tiler

PyPI - Version PyPI - Downloads License ReadTheDocs Status Github Actions Status - Build Github Actions Status - Typecheck

[!IMPORTANT] This repository is experimental and in the prototype stage. Expect bugs. Expect a possible pivot and/or name change in the future :smile:

Your feedback and contributions are welcome! Please open an issue, DM Matt Fisher, or post in the #geojupyter channel on the Jupyter Zulip!

A Jupyter server extension which provides an API to launch a server to dynamically tile Xarray DataArrays for interactive visualization.

Who is this for?

Intended to be consumed by interactive map libraries for Jupyter, not end-users, e.g.:

What problem does this solve?

For authors of interactive map libraries for Jupyter, providing a dynamic HTTP tile server presents a unique problem: they don't know where Jupyter is running. It could be, for example, running on:

  • users' local machines
  • a shared JupyterLab instance on an intranet
  • an authenticated JupyterHub in a public cloud

The first case is the simplest; when the tile server is running on localhost, the map viewer running in JavaScript in the user's browser can connect to it.

In the other cases, the map viewer needs a public URL to connect to. The URL of the current JupyterHub instance may not be known. Additionally, a map server running in a Jupyter kernel isn't exposed to the public internet in many cases (for example, when it's running in a Kubernetes pod as part of a JupyterHub). This extension provides dynamic proxying to map servers running in the kernel.

Usage

As a Jupyter interactive map library author, you may implement a method like:

from jupyter_xarray_tiler.titiler import add_data_array


class MyMapLibrary:
  # ...

  def add_xarray_layer(self, da: xr.DataArray):
    # Add the layer to the tile server.
    # The server will be started the first time this is called.
    # A URL that passes through the Jupyter server proxy will be returned:
    url = add_data_array(da)

    # Add the layer to your map!
    self._add_tile_layer(url)

Install

Recommended:

uv add jupyter-xarray-tiler

Or:

[!WARNING] Installation with pixi/conda/mamba/micromamba is not yet supported. Please use another installation method!

pixi add jupyter-xarray-tiler

For other methods of installation, including pip, conda, mamba, and micromamba, see the installation instructions in the documentation.

From source

uv add git+https://github.com/geojupyter/jupyter-xarray-tiler.git#egg=jupyter-xarray-tiler

For development instructions, please view the development install instructions in our documentation's Contributor Guide!

Contributing

Please see the Contributor Guide in our documentation!

:rocket: Powered by...

TiTiler (Development Seed)

Other backends (e.g. xpublish-tiles (earthmover)) may be supported in the future!

:sparkles: Inspired by...

jupytergis-tiler by David Brochart

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

jupyter_xarray_tiler-0.3.0.tar.gz (282.9 kB view details)

Uploaded Source

Built Distribution

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

jupyter_xarray_tiler-0.3.0-py3-none-any.whl (22.5 kB view details)

Uploaded Python 3

File details

Details for the file jupyter_xarray_tiler-0.3.0.tar.gz.

File metadata

  • Download URL: jupyter_xarray_tiler-0.3.0.tar.gz
  • Upload date:
  • Size: 282.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for jupyter_xarray_tiler-0.3.0.tar.gz
Algorithm Hash digest
SHA256 8aaf7100c2844f02f43ff1c81975e2e85b8dd887046b6d31f4e1ca71afe841be
MD5 0e8f2bc54f2f6001fff8225eefa0d001
BLAKE2b-256 7271a45c655c5322d8ffa05870ad1a8497c2b015666d4fdae347247e9497b86b

See more details on using hashes here.

Provenance

The following attestation bundles were made for jupyter_xarray_tiler-0.3.0.tar.gz:

Publisher: publish.yml on geojupyter/jupyter-xarray-tiler

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file jupyter_xarray_tiler-0.3.0-py3-none-any.whl.

File metadata

File hashes

Hashes for jupyter_xarray_tiler-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3fb48851c8c3b2e4ccdce1de2932dd90b7e4d2b7e6077c65488b3b5665afa55e
MD5 dfa4ba2ccd7aa35a46312242e3aa2e9a
BLAKE2b-256 b93eb07501fbd7896e4d9764054531ca154b704b7811ac9d70acaef526604596

See more details on using hashes here.

Provenance

The following attestation bundles were made for jupyter_xarray_tiler-0.3.0-py3-none-any.whl:

Publisher: publish.yml on geojupyter/jupyter-xarray-tiler

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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