GitHub Action
Open Source Heartbeat Interface
A GitHub action to generate a web interface to show GitHub activity for a subset of users or organizations.
- the interface is created under docs/
- events are populated in docs/_events
- the site is served via Jekyll
This means that you can use the action in your workflows too, and choose how often / when to run it, and how to update your GitHub pages. Continue reading to learn more.
The main page shows a sortable view of the top 100 new contributions. You can filter down to a contribution type, or click on browse to see a subset of that type.
Here is the browse view.
And here is looking at an archive for a contribution type. Archives are linked from the browse page.
And finally, a chart shows a summary of contributions.
If you have a custom set of users or organizations, you'll need to first generate a
users.txt file (or a differently named file that you'll specify as the users_file
for your action
and/or an orgs.txt file (for the orgs_file
to specify organizations to use).
As an alternative, you can have this file generated or updated via the GitHub action first
by specifying the query
argument. For help building your query, it's recommended to try
your search in the GitHub Advanced view. For example,
to search users for the location being "Stanford" I might use the query location%3AStanford
.
To summarize, you'll need to:
- Add A GitHub workflow for your run, you can see examples in the examples folder.
- Run the workflow as you have set up to generate the docs/ folder.
- Update the _config.yml in the docs folder to have the correct baseurl for your site.
Once the docs folder is added to your repository via a pull request, it won't be generated again, so you are free to customize it as you like.
Optional The path to the users.txt (or otherwise named) file that has a single GitHub username per line. These are the users that will have their events parsed to show on the website.
username1
username2
...
usernameN
If you define the query
variable this file will be updated, or created first
if it doesn't exist.
Optional If you want to add contributions based on organizations, you can
define an orgs_file
which defaults to orgs.txt. The format is the same as
the users_file
. If you don't define this variable, parsing organization
events will be skipped.
If you want to use an organization to look up public members, set this varaible.
It will default to user-orgs.txt
and be used if it's found.
Optional If defined, we will use update-users.py
to first update the users.txt based on your query. For example,
to search users for the location being "Stanford" I might use the query location%3AStanford
.
For help building your query, it's recommended to try your search in the
GitHub Advanced view. If this variable
is not defined, the update will be skipped, and you will be required to already
have a users.txt file.
If defined as anything, clean up the previous collection folder before generating new events. If not defined, skip cleanup entirely (old events will be preserved).
Optional The path to the exclude-users.txt (or otherwise named) file that has a single GitHub username per line for users to not include. For example, if we discover a username via a query but then don't want to add it (e.g., the user has requested not being added) it will not be included. This file has the same format as the users.txt file - one username per line.
username1
username2
...
usernameN
A comma separated list of allowed events. By default, we use "all" to allow all events. Events include:
- PushEvent
- IssueCommentEvent
- PullRequestEvent
- CreateEvent
- IssueCommentEvent
- ReleaseEvent
- IssuesEvent
- PublicEvent
- PullRequestReviewCommentEvent
- PullRequestReviewEvent
For example, maybe you are just interested in questions being asked by members of your orgs (or repos they need help or contribution to) - you would select the IssuesEvent. Or if you want to see contribution, you might choose the PullRequestEvent. It's up to you!
Your GitHub token is required to define in the environment to increase query limits for the GitHub API.
If you want to update the users.txt file manually (and via the same method done for the action) you can do that via:
$ python scripts/update-users.py --help
Present working directory is /home/vanessa/Desktop/Code/rseng/stanford-issues/scripts
usage: update-users.py [-h] [--version] [--users-file USERS_FILE] [--exclude-users-file EXCLUDE_USERS_FILE]
[--user-query USER_QUERY]
Open Source Heartbeat
optional arguments:
-h, --help show this help message and exit
--version suppress additional output.
--users-file USERS_FILE
The users.txt file with GitHub usernames on lines.
--exclude-users-file EXCLUDE_USERS_FILE
A list of users to never add (that might still be discovered).
--user-query USER_QUERY
The string portion of a user query, generate with
https://github.com/search/advanced.
For example:
$ python scripts/update-users.py --users-file users.txt --user-query "location%3AStanford"
...
users file: users.txt
users file: exclude-users.txt
Found 24 new users!
In the example usage below, you should update the master
branch to a versioned
release.
steps:
- name: Checkout Code
uses: actions/checkout@v2
- name: Generate OpenSource Heartbeat Interface
uses: rseng/opensource-heartbeat-action@master
with:
users_file: 'users.txt'
collection: 'docs/_events'
query: 'location%3AStanford'
token: ${{ secrets.GITHUB_TOKEN }}
If you want to just include a subset of organizations (and not parse individual users) then you can leave out the query, and don't define the users file.
steps:
- name: Checkout Code
uses: actions/checkout@v2
- name: Generate OpenSource Heartbeat Interface
uses: rseng/opensource-heartbeat-action@master
with:
orgs_file: 'orgs.txt'
collection: 'docs/_events'
token: ${{ secrets.GITHUB_TOKEN }}
For push and comment events, it might be the case that a user comments or pushes multiple times on a single repository. To be concise, we only add the first event of this type seen, per user and per repository. This means that the events that are generated are generally an underestimate of actual activity.
The interface will always be generated in the docs subfolder, so if you haven't created it there yet, the action will generate it the first time around. It's up to you to add all or a subset of files in docs/* or docs/_events after the content is generated. For example, you could add both docs and _issues in a next step that will commit to an existing or new branch:
git add docs/*
git add docs/_issues/*
This means that after the original docs is added and merged, you should be able to customize or otherwise update the template to your liking. The folder won't be edited if it already exists beyond the _events folder.
If you use the action and want to share, please open a pull request to add your repository here!
- vsoch Opensource Heartbeat
- rse-ops Opensource Heartbeat
- Stanford Opensource Heartbeat (removed/404 when @vsoch left Stanford)
- Coming soon LLNL RADIUSS
It would be nice to have the ability to see charts by year (e.g., to determine contribution changes over the years).