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.4.0.tar.gz (212.5 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.4.0-py3-none-any.whl (22.5 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: jupyter_xarray_tiler-0.4.0.tar.gz
  • Upload date:
  • Size: 212.5 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.4.0.tar.gz
Algorithm Hash digest
SHA256 c4d0eb7f1afd4b1d9e792516d028e11655bffc003dfec702dc3d6e2fa4799268
MD5 eb0ae54ac477c8aa90b96a6153a1e49c
BLAKE2b-256 0bd0530a814bb38659044a7698f01c8c3dd759eb0a172d67910fd1244166123c

See more details on using hashes here.

Provenance

The following attestation bundles were made for jupyter_xarray_tiler-0.4.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.4.0-py3-none-any.whl.

File metadata

File hashes

Hashes for jupyter_xarray_tiler-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 7f12894885b9fb2b52c729a2ab43f7c439d62071c517cbe78820cc214cd625e8
MD5 8c6127f2a71e080042a85d6a5c3b473e
BLAKE2b-256 5f8efb7861f30748a2caa9f61643263d014d51a0bdea051f87feb3fbf4a2712a

See more details on using hashes here.

Provenance

The following attestation bundles were made for jupyter_xarray_tiler-0.4.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