Skip to content
This repository has been archived by the owner on Dec 19, 2024. It is now read-only.

Latest commit

 

History

History
45 lines (31 loc) · 2.04 KB

README.md

File metadata and controls

45 lines (31 loc) · 2.04 KB

pangeo-forge-exploration

This repository has been archived.

This repository contains notes and code to explore the use of pangeo-forge.

After further thought and discussion with pangeo-forge contributors we concluded that the pangeo-forge approach was not well-aligned with our use-case. Notes from our discussion with pangeo-forge maintainers can be found here: https://qgreenland-net.github.io/notes/2024-04-04_pangeo-forge.html

Custom writers

Custom writers are currently a challenge being worked on in Pangeo Forge. While it looks straightforward to create a custom writer, there is special logic that injects the output directory (target_root) to writers based on a hard-coded data structure of classes to receive injection. We reached out for support and were recommended to pursue the following workaround (thank you, Greg!):

  1. Fork pangeo-forge-recipes, add custom writer PTransform to e.g. transforms.py.
  2. Ensure the new transform has a special argument based on this example custom writer class.
  3. In the fork, update injections.py to add our new PTransform to the static data structure.
  4. In recipe repository, update requirements.txt to point to the forked pangeo-forge-runner instead of the official following git+https://github.com/... notation.

Some examples:

What about a monkeypatch approach so my custom transform can live with my recipe?

This approach is ruled out because the injection happens prior to runtime.

The dependency injection approach is currently being revisited. _TODO: Link to GitHub issues/discussions where this is happening!*