Find out who is interested in your GitHub code!
This is a tool to find out some more information about the people who watch or star your GitHub repository. GitHub's native UI is good for this, but it doesn't present the information in aggregate or show which orgs people are a member of. This tool does.
Table of Contents
If a package maintainer uploads an open source package to a package manager, and no one sees it, does it make a sound?
Successful open source projects depend on their community for funding, interest, and long-term growth. Maintainers generally have to do a lot of leg-work themselves to make the package interesting, to attract more users, and to fund their own work. On GitHub, one way of tracking interest is to look at the contributors who have contributed code; or those who have opened issues; or those who have watched a repo; or, last, those who have starred a repository. There is some amount of information on GitHub in user profiles about interested users are and where they came from. Knowing that someone who starred your repo works for a company that may be able to sponsor continued work can be helpful for the maintainer.
This tool started as a simple idea: rather than manually looking through the people who star and watch repositories on GitHub, could we automatically get their affiliations?
Jabbar comes from al jabbar, meaning 'the giant' the medieval Arabic word for the constellation Orion. Look to the stars, eh? Any chance relation to the Gom Jabbar is purely not coincidental. (If you can think of a better name, open an issue.)
This package is on npm:
npm install --global jabbar
- Get a GitHub Token. Click on 'read:org' in the Scopes page.
npm install --global jabbar
GITHUB_TOKEN=asdsafs jabbar RichardLitt/jabbar
This module looks for an auth token in the environmental variable GITHUB_TOKEN
. It needs to have the read:org
scope in order to function properly. Make sure this var is set to a valid GitHub OAuth token. To create one see this article.
$ jabbar --help
Usage
$ jabbar <input> [--watchers|--stargazers]
Options
-r, --repo - Repository to search. Format: RichardLitt/jabbar
This flag is used as the default input.
--all - The default: get all watchers, stargazers, and forkers
-w, --watchers - Get watchers for a repository
-s, --stargazers - Get stargazers for a repository
-f, --forkers - Get forkers for a repository
--ignored - Ignore a user. Defaults to include owner of repository.
Use csv for multiple users.
-h, --help - Show this printout
--output <file> - Print the results to a file as JSON
Authentication
This script looks for an auth token in the env var GITHUB_TOKEN. It needs
to have the read:org scope in order to function properly. Make sure this
var is set to a valid GitHub OAuth token.
Examples
$ jabbar RichardLitt/jabbar
$ jabbar --repo RichardLitt/jabbar --watchers
$ jabbar RichardLitt/jabbar -w --output=results.json
# To pass an authentication token
$ GITHUB_TOKEN=sd2991s jabbar -r RichardLitt/jabbar -w
You can also install Jabbar locally.
const j = require('jabbar')
// The main functions return a Promise, so wrap it in an async function
(async () => {
let response = await j.getWatchers('RichardLitt', 'jabbar')
})()
Don't forget to set the GITHUB_TOKEN
somewhere in your env.
This module uses Mocha. To run the tests, run: npm run test
.
Get the aggregate users who have watched, forked, or stargazed at your repo.
Get all of the watchers for a repository.
Get all of the stargazers for a repository.
Get all users who have forked the repository.
Get information about the repository's forks.
Please do! This is an open source project. Check out the Contributing Guide, which probably is a short read at the moment. open issues, submit PRs, or send get well soon cards.
Abide by the Code of Conduct.
MIT © 2019 Burnt Fen Creative LLC