go.anx.io
This repository holds the templates and configuration for our go vanity URL website at go.anx.io.
Usage
- add your package to
packages.yaml
, optionally overriding targetName
and summary
- add a GitHub actions workflow to trigger updates when code is pushed to your repository
- be sure your
go.mod
uses the correct import path go.anx.io/$targetName
- profit :)
You can look at anexia-it/go-anxcloud#96 for an example
what to do, there is also a handy sed
in the comments to change import paths over the whole repository.
# anexia/go.anx.io/packages.yaml
# This package can be imported as go.anx.io/awesomeLibrary
- source: https://github.com/anexia/go-awesome-library.git
targetName: awesomeLibrary
summary: This library does some really awesome things
# This package can be imported as go.anx.io/go-boring-library
- source: https://github.com/anexia/go-boring-library.git
targetName
defaults to the last part of the URL without the .git
, summary
to the first top-level
header in README.md
on the default branch.
Add this as a new workflow or add the job trigger
to one of your existing workflows. You can also modify it
to run after your tests went through. Make sure to run it for both branches and tags.
# anexia/go-awesome-library/.github/workflows/push.yaml
name: Trigger go.anx.io update
on:
push:
jobs:
trigger:
name: Trigger go.anx.io update
runs-on: ubuntu-latest
steps:
- uses: anexia/go.anx.io@main
env:
GOANXIO_E5E_TOKEN: "${{ secrets.GOANXIO_E5E_TOKEN }}"
The update trigger
Triggering workflows in a repository from another repositories workflow needs a personal access token (PATs) to
create a repository_dispatch
event, which workflows can be triggered on. Since those PATs are powerful and we
want as less config as possible in each library (so not adding this token to every libraries settings), we use
an E5E function to do the actual GitHub API call. This way we have that token securely in our own infrastructure
in a piece of code that can only trigger this specific API.
The E5E function is "System Engineering / github-dispatch / Trigger go.anx.io rebuild" and called via Frontier
"System Engineering / github-dispatch / trigger go.anx.io rebuild".
Contributing
Contributions are welcome! Read the Contributing Guide for more information.
Only packages by Anexia will be published on go.anx.io, though.
Licensing
See LICENSE for more information.