Go to file
Jack Grigg b1681021bc
Merge pull request #77 from zcash/ga
Update gh-pages.yml
2024-12-18 08:57:13 +13:00
.github/workflows Update gh-pages.yml 2024-12-17 12:55:36 -07:00
helpers Enable more than one repo within a single Zashi pipeline column 2024-11-19 14:45:08 +13:00
public Highlight nodes with S-waiting-on-review label 2023-01-23 21:12:25 +00:00
.gitignore switch to ZenHub GraphQL API 2024-10-31 13:47:30 +13:00
README.md Switch from poetry to uv 2024-10-31 13:29:22 +13:00
gen-dag.sh Switch from poetry to uv 2024-10-31 13:29:22 +13:00
gen-schema.sh Fix bug in `gen-schema.sh` 2024-11-01 11:04:19 +13:00
index.html Add a Zashi pipeline render 2024-10-31 18:50:48 +13:00
pyproject.toml switch to ZenHub GraphQL API 2024-10-31 13:47:30 +13:00
requirements.txt switch to ZenHub GraphQL API 2024-10-31 13:47:30 +13:00
uv.lock switch to ZenHub GraphQL API 2024-10-31 13:47:30 +13:00
zashi-pipeline.py Enable more than one repo within a single Zashi pipeline column 2024-11-19 14:45:08 +13:00
zcash-issue-dag.py Introduce a `Repo` class 2024-11-12 18:33:34 +13:00
zenhub-repo-ids.py Store ZenHub's repo ID alongside GitHub's 2024-11-12 18:33:34 +13:00

README.md

Zcash Developers Hub

This is the source repository for the Zcash Developers Hub website: https://zcash.github.io/developers/

For now, this repo hosts the script used to generate ECC's development dependency graph, and a workflow that generates and hosts it.

Setup

This project uses uv for dependency management: https://docs.astral.sh/uv/ It also depends on the Graphviz library; for Debian-based distros, install the libgraphviz-dev package.

After installing uv, run uv sync.

Authorization Tokens

The scripts provided by this project require two files:

  • GITHUB_TOKEN: a GitHub API token with permission to read the necessary repositories.
  • ZENHUB_TOKEN: a ZenHub REST API token. (Not a GraphQL token.)

After generating each token, paste the literal contents into the associated file. There is a .gitignore which ignores these files to ensure they are not committed. Be careful to avoid that editor temporary files or any copies or renames of these files aren't committed.

You can generate a GitHub token with this url. This token should not have any excess authority; it only needs public read access! Make sure all of those extra capability checkboxes are unchecked.

The DAG script depends upon GraphQL APIs for GitHub which can be generated using ./gen-schema.sh.

Generating DAGs

The simplest way to generate one or more DAGs is to use ./gen-dag.sh script. This takes a list of DAGs to render as arguments (default: core wallet tfl halo2 zf).

Alternatively, the zcash-issue-dag.py script supports several configuration options supplied as environment variables:

  • DAG_VIEW=[core|halo2|tfl|wallet|wallet-ios|wallet-android|zf]: The DAG to render (default: core).
  • SHOW_MILESTONES=[true|false]: Whether or not to render GitHub milestones as boxes (default: false).
  • SHOW_EPICS=[true|false]: Whether or not to render ZenHub epics as boxes (default: false).
  • INCLUDE_FINISHED=[true|false]: Whether or not to include closed issues with no open blockers (default: false).

Example command:

DAG_VIEW=core SHOW_MILESTONES=false uv run ./zcash-issue-dag.py