diff --git a/Makefile b/Makefile index ea95f5d3..a662a85e 100644 --- a/Makefile +++ b/Makefile @@ -11,5 +11,11 @@ site-live: site-requirements.txt uvx --with-requirements $< mkdocs serve .PHONY: snippets -snippets: +snippets: trophies cargo run -- -h > docs/snippets/help.txt + +.PHONY: trophies +trophies: docs/snippets/trophies.md + +docs/snippets/trophies.md: docs/snippets/trophies.txt docs/snippets/render-trophies.py + uv run --no-project docs/snippets/render-trophies.py > $@ diff --git a/docs/development.md b/docs/development.md index ca76708c..054b1b31 100644 --- a/docs/development.md +++ b/docs/development.md @@ -167,6 +167,36 @@ INFO - [22:18:40] Browser connected: http://127.0.0.1:9999/zizmor/developmen Visit the listed URL to see your live changes. +### Updating the snippets + +`zizmor`'s website contains various static snippets. To update these: + +``` +make snippets +``` + +Most of the time, this should result in no changes, since the snippets +will already be up-to-date. + +### Updating the trophy case + +!!! tip + + Additions to the trophy case are welcome, but we currently limit them + to repositories with 100 or more "stars" to keep things tractable. + +The [Trophy Case](./trophy-case.md) is kept up-to-date through the data in +the `docs/snippets/trophies.txt` file. + +To add a new trophy to the trophy case, add it to that file *in the same +format* as the other entries. + +Then, regenerate the trophy case: + +``` +make trophies +``` + ## Adding or modifying an audit ### Before getting started @@ -245,11 +275,7 @@ The general procedure for changing an existing audit is: `zizmor`'s documentation contains a copy of `zizmor --help`, which the CI checks to ensure that it remains updated. If you change `zizmor`'s CLI, -you may need to regenerate the documentation snippets and check-in the results: - -```bash -make snippets -``` +you may need to [update the snippets](#updating-the-snippets). [clap]: https://docs.rs/clap/latest/clap/index.html diff --git a/docs/snippets/render-trophies.py b/docs/snippets/render-trophies.py new file mode 100644 index 00000000..38271614 --- /dev/null +++ b/docs/snippets/render-trophies.py @@ -0,0 +1,27 @@ +#!/usr/bin/env python + +# render-trophies: take trophies.txt and produce a pretty +# mkdocs-material card grid list from it + +from pathlib import Path + + +_TROPHIES = Path(__file__).parent / "trophies.txt" + +_TEMPLATE = """ +- data:image/s3,"s3://crabby-images/8236b/8236b55cb2954e89c6a7e653e8da9241ac527961" alt=""{{ width=\"40\" loading=lazy align=left }} {org}/{repo} + + --- + + {trophy}""" + +for trophy in sorted(_TROPHIES.open().readlines()): + trophy = trophy.strip() + if not trophy or trophy.startswith("#"): + continue + + org, rest = trophy.split("/") + repo, _ = rest.split("#") + # NOTE: We request 40x40 from GitHub, but sometimes it gives us a bigger one. + # Consequently, we also style with `width` to keep things consistent. + print(_TEMPLATE.format(org=org, repo=repo, trophy=trophy)) diff --git a/docs/snippets/trophies.md b/docs/snippets/trophies.md new file mode 100644 index 00000000..c7dfb03d --- /dev/null +++ b/docs/snippets/trophies.md @@ -0,0 +1,246 @@ + +- data:image/s3,"s3://crabby-images/0d19e/0d19e9c24ccba262720d9fff071027ef490c9b1c" alt=""{ width="40" loading=lazy align=left } DataDog/datadog-agent + + --- + + DataDog/datadog-agent#30871 + +- data:image/s3,"s3://crabby-images/0bddf/0bddf4096a7bc623a2711c92921d8882625e8d50" alt=""{ width="40" loading=lazy align=left } Diaoul/subliminal + + --- + + Diaoul/subliminal#1190 + +- data:image/s3,"s3://crabby-images/6023d/6023df07c880217803e9f54262b4d4c57e7061e8" alt=""{ width="40" loading=lazy align=left } Homebrew/brew + + --- + + Homebrew/brew#18662 + +- data:image/s3,"s3://crabby-images/6d3d4/6d3d46c7c3715ee3018f93eeb654a04d84210731" alt=""{ width="40" loading=lazy align=left } NetApp/harvest + + --- + + NetApp/harvest#3247 + +- data:image/s3,"s3://crabby-images/6042f/6042f57a9167b45b3ae3a44381054e2f60bc4178" alt=""{ width="40" loading=lazy align=left } PyO3/pyo3 + + --- + + PyO3/pyo3#4774 + +- data:image/s3,"s3://crabby-images/42909/42909fd4fda1f9e2956acb744be87f483d117b7b" alt=""{ width="40" loading=lazy align=left } adafruit/circuitpython + + --- + + adafruit/circuitpython#9785 + +- data:image/s3,"s3://crabby-images/6301f/6301f0a522ff7052e954c34cfce326339a207ab9" alt=""{ width="40" loading=lazy align=left } astral-sh/ruff + + --- + + astral-sh/ruff#14844 + +- data:image/s3,"s3://crabby-images/9ad99/9ad992cd03d57b9ddde939c491472ab9906d6cea" alt=""{ width="40" loading=lazy align=left } astropy/astropy + + --- + + astropy/astropy#17315 + +- data:image/s3,"s3://crabby-images/26b37/26b3771cd1ae3ae668e9b745f71961783c4fe1af" alt=""{ width="40" loading=lazy align=left } danmar/cppcheck + + --- + + danmar/cppcheck#7044 + +- data:image/s3,"s3://crabby-images/9b363/9b3633943d87d0e9167569873539893abb36de7d" alt=""{ width="40" loading=lazy align=left } hugovk/em-keyboard + + --- + + hugovk/em-keyboard#148 + +- data:image/s3,"s3://crabby-images/9b363/9b3633943d87d0e9167569873539893abb36de7d" alt=""{ width="40" loading=lazy align=left } hugovk/norwegianblue + + --- + + hugovk/norwegianblue#233 + +- data:image/s3,"s3://crabby-images/9b363/9b3633943d87d0e9167569873539893abb36de7d" alt=""{ width="40" loading=lazy align=left } hugovk/pypistats + + --- + + hugovk/pypistats#460 + +- data:image/s3,"s3://crabby-images/3bf93/3bf93bdf9cc4715135adeabd689285a11fc64f22" alt=""{ width="40" loading=lazy align=left } hynek/argon2-cffi + + --- + + hynek/argon2-cffi#185 + +- data:image/s3,"s3://crabby-images/3bf93/3bf93bdf9cc4715135adeabd689285a11fc64f22" alt=""{ width="40" loading=lazy align=left } hynek/doc2dash + + --- + + hynek/doc2dash#225 + +- data:image/s3,"s3://crabby-images/3bf93/3bf93bdf9cc4715135adeabd689285a11fc64f22" alt=""{ width="40" loading=lazy align=left } hynek/environ-config + + --- + + hynek/environ-config#88 + +- data:image/s3,"s3://crabby-images/3bf93/3bf93bdf9cc4715135adeabd689285a11fc64f22" alt=""{ width="40" loading=lazy align=left } hynek/hatch-fancy-pypi-readme + + --- + + hynek/hatch-fancy-pypi-readme#57 + +- data:image/s3,"s3://crabby-images/3bf93/3bf93bdf9cc4715135adeabd689285a11fc64f22" alt=""{ width="40" loading=lazy align=left } hynek/pem + + --- + + hynek/pem#100 + +- data:image/s3,"s3://crabby-images/3bf93/3bf93bdf9cc4715135adeabd689285a11fc64f22" alt=""{ width="40" loading=lazy align=left } hynek/prometheus-async + + --- + + hynek/prometheus-async#70 + +- data:image/s3,"s3://crabby-images/3bf93/3bf93bdf9cc4715135adeabd689285a11fc64f22" alt=""{ width="40" loading=lazy align=left } hynek/stamina + + --- + + hynek/stamina#81 + +- data:image/s3,"s3://crabby-images/3bf93/3bf93bdf9cc4715135adeabd689285a11fc64f22" alt=""{ width="40" loading=lazy align=left } hynek/structlog + + --- + + hynek/structlog#663 + +- data:image/s3,"s3://crabby-images/ea04a/ea04aa3538ec98e87bcf6f7d8bc21a353527f6bc" alt=""{ width="40" loading=lazy align=left } marcusvolz/strava_py + + --- + + marcusvolz/strava_py#53 + +- data:image/s3,"s3://crabby-images/0c8d7/0c8d792ee6e61c4a84ce7dab3a06b15b9deb9517" alt=""{ width="40" loading=lazy align=left } matplotlib/matplotlib + + --- + + matplotlib/matplotlib#29251 + +- data:image/s3,"s3://crabby-images/ba7e0/ba7e00dfd0dd1defd534a0da7db286c3c6a912ff" alt=""{ width="40" loading=lazy align=left } praetorian-inc/noseyparker + + --- + + praetorian-inc/noseyparker#228 + +- data:image/s3,"s3://crabby-images/51144/511440ce8fbe7cc80a1380cf41d59e58a8a65b55" alt=""{ width="40" loading=lazy align=left } prettytable/prettytable + + --- + + prettytable/prettytable#339 + +- data:image/s3,"s3://crabby-images/20656/2065682d130888086a9eb19ae54c889842c051a9" alt=""{ width="40" loading=lazy align=left } pyca/service-identity + + --- + + pyca/service-identity#75 + +- data:image/s3,"s3://crabby-images/e7d10/e7d10cc68bd097aba50f4832d7e5e3be6174cd87" alt=""{ width="40" loading=lazy align=left } pylast/pylast + + --- + + pylast/pylast#465 + +- data:image/s3,"s3://crabby-images/86812/868122a68535a13a5ca594bc493803ba23b03bca" alt=""{ width="40" loading=lazy align=left } pypa/pip-audit + + --- + + pypa/pip-audit#851 + +- data:image/s3,"s3://crabby-images/4e9db/4e9db11d1e51c3b136b3f109cd88ad19695ab334" alt=""{ width="40" loading=lazy align=left } python-attrs/attrs + + --- + + python-attrs/attrs#1368 + +- data:image/s3,"s3://crabby-images/4e9db/4e9db11d1e51c3b136b3f109cd88ad19695ab334" alt=""{ width="40" loading=lazy align=left } python-attrs/cattrs + + --- + + python-attrs/cattrs#605 + +- data:image/s3,"s3://crabby-images/94153/94153798df1518a7ac981da0e432a1d05efc64d5" alt=""{ width="40" loading=lazy align=left } python-humanize/humanize + + --- + + python-humanize/humanize#221 + +- data:image/s3,"s3://crabby-images/2227c/2227c45e56b5cd1d09c1c3648c83697e7c81dc4e" alt=""{ width="40" loading=lazy align=left } python-pillow/Pillow + + --- + + python-pillow/Pillow#8526 + +- data:image/s3,"s3://crabby-images/af208/af2080cb56581a6e166fc0c40b44f9715d203f20" alt=""{ width="40" loading=lazy align=left } python/cpython + + --- + + python/cpython#127749 + +- data:image/s3,"s3://crabby-images/af208/af2080cb56581a6e166fc0c40b44f9715d203f20" alt=""{ width="40" loading=lazy align=left } python/miss-islington + + --- + + python/miss-islington#705 + +- data:image/s3,"s3://crabby-images/fa480/fa480d6afd1e1caa6d5e276e2468b191c91554f2" alt=""{ width="40" loading=lazy align=left } rust-lang/crates.io + + --- + + rust-lang/crates.io#10176 + +- data:image/s3,"s3://crabby-images/d7af3/d7af38da3453e342a1b05d0cb493b0f75611f206" alt=""{ width="40" loading=lazy align=left } rustls/rustls + + --- + + rustls/rustls#2261 + +- data:image/s3,"s3://crabby-images/d7af3/d7af38da3453e342a1b05d0cb493b0f75611f206" alt=""{ width="40" loading=lazy align=left } rustls/tokio-rustls + + --- + + rustls/tokio-rustls#96 + +- data:image/s3,"s3://crabby-images/5f483/5f4836eb7f81f31ddcd746ce80cfa570e3330708" alt=""{ width="40" loading=lazy align=left } sigstore/cosign + + --- + + sigstore/cosign#3959 + +- data:image/s3,"s3://crabby-images/5f483/5f4836eb7f81f31ddcd746ce80cfa570e3330708" alt=""{ width="40" loading=lazy align=left } sigstore/gitsign + + --- + + sigstore/gitsign#602 + +- data:image/s3,"s3://crabby-images/a8549/a8549e2667ca8c211a35e914e0713463c4c34be1" alt=""{ width="40" loading=lazy align=left } termcolor/termcolor + + --- + + termcolor/termcolor#89 + +- data:image/s3,"s3://crabby-images/ad7c9/ad7c9a584b9bdcc2116c34fc03924391cdc3dee3" alt=""{ width="40" loading=lazy align=left } tornadoweb/tornado + + --- + + tornadoweb/tornado#3438 + +- data:image/s3,"s3://crabby-images/3f647/3f647d6de6b0e338a6ebc6e56eb59dbc187e409e" alt=""{ width="40" loading=lazy align=left } vlang/v + + --- + + vlang/v#22681 diff --git a/docs/snippets/trophies.txt b/docs/snippets/trophies.txt new file mode 100644 index 00000000..514e1fa5 --- /dev/null +++ b/docs/snippets/trophies.txt @@ -0,0 +1,46 @@ +# one per line, order is not important +# trophies MUST be formatted as owner/repo#number, +# where owner/repo is the GitHub repo slug and +# number is the issue/PR that introduces or uses zizmor + +adafruit/circuitpython#9785 +astral-sh/ruff#14844 +astropy/astropy#17315 +danmar/cppcheck#7044 +DataDog/datadog-agent#30871 +Diaoul/subliminal#1190 +Homebrew/brew#18662 +hugovk/em-keyboard#148 +hugovk/norwegianblue#233 +hugovk/pypistats#460 +hynek/argon2-cffi#185 +hynek/doc2dash#225 +hynek/environ-config#88 +hynek/hatch-fancy-pypi-readme#57 +hynek/pem#100 +hynek/prometheus-async#70 +hynek/stamina#81 +hynek/structlog#663 +matplotlib/matplotlib#29251 +marcusvolz/strava_py#53 +NetApp/harvest#3247 +praetorian-inc/noseyparker#228 +prettytable/prettytable#339 +pyca/service-identity#75 +pylast/pylast#465 +pypa/pip-audit#851 +python/cpython#127749 +python/miss-islington#705 +python-attrs/attrs#1368 +python-attrs/cattrs#605 +python-humanize/humanize#221 +python-pillow/Pillow#8526 +PyO3/pyo3#4774 +rust-lang/crates.io#10176 +rustls/rustls#2261 +rustls/tokio-rustls#96 +sigstore/cosign#3959 +sigstore/gitsign#602 +termcolor/termcolor#89 +tornadoweb/tornado#3438 +vlang/v#22681 diff --git a/docs/trophy-case.md b/docs/trophy-case.md index e57f3292..8c659359 100644 --- a/docs/trophy-case.md +++ b/docs/trophy-case.md @@ -6,49 +6,13 @@ the software we all rely on. This page documents key examples where `zizmor` helped make big projects more secure! -!!! important +!!! tip "Give yourself a trophy!" Do you contribute to or maintain a big (>100 star) project that had its GitHub - Actions security improved by `zizmor`? Open a PR to add it to our list! + Actions security improved by `zizmor`? + [Add it to our list](./development.md#updating-the-trophy-case)! + +