The npm CLI Team's Internal Tools
npx -p @npmcli/stafftools <command> [...args]
Run commands across all npm-cli
repos on your local machine using working threads.
npx -p @npmcli/stafftools@latest gh <subcommand> [...args]
- Note: The
gh
cli needs to be installed and authenticated.
npx -p @npmcli/stafftools@latest gh pending-release publish-release \
--reject 'title: /\d+\.0\.0/' \ # Filter out PR titles matching \d.0.0 (major releases)
--reject 'id: npm/cli' \ # Filter out npm itself
--merge-strategy=rebase \ # Merge all PRs with rebase
--otp=OP # Use the 1Password `op` cli to get one time passwords
# OR specify an otp with --otp=XXXXXX
All the .mjs
files in the queries
dir return some sort of data from the GitHub api.
Each query is responsible for exporting:
default
: a function that will return data of some shapeargs
: an object that will be passed toyargs
to set the optionstype
: the type of data that this query returns. should be value or array of values fromtypes.mjs
Any query can be run directly by name, or a custom query file can be passed in by path.
Without any other arguments, a query will print its data. A query --template
option can be provided to change how the data is displayed. For example:
# Will return the result of the `repos` query
npx -p @npmcli/stafftools@latest gh repos
# Add --help to see what subcommands are available
npx -p @npmcli/stafftools@latest gh repos --help
# Commands:
# npx -p @npmcli/stafftools@latest gh repos clone Clone repos into a directory
# npx -p @npmcli/stafftools@latest gh repos publish-repo Publish repos from their default branch
# npx -p @npmcli/stafftools@latest gh repos pull Checkout and pull default branch of repos
# npx -p @npmcli/stafftools@latest gh repos repo-settings Set common settings on all repos
All the .mjs
files in the workers
dir operate on data returned from a query.
Each worker is reponsible for exporting:
default
: an array of commands to run on the dataargs
: an object that will be passed toyargs
to set the optionstype
: the type of data that this worker operates. should be a value or array of values fromtypes.mjs
or a string that is the name of a query or path to a querysuccess
: a function that will display the success message for each item from the query. can be useful for displaying the url to a pull request, name of a repo, etc
Note that for type
if a worker specifies an exact query by name, then the worker can be run as it's own top level command. For example:
# This worker exports `type = 'template-oss'` so it can
# be run as a single positional command
npx -p @npmcli/stafftools@latest gh template-oss-fix
# The above is equivalent to
npx -p @npmcli/stafftools@latest gh template-oss template-oss-fix
The base directory in which all commands will be run. Defaults to $HOME/projects
.
Number of worker threads to spawn. Defaults to one less than the number of cores avaialble.
An array of relaxed JSON strings to filter the returned data.
For example: `npx -p @npmcli/stafftools@latest gh merge pull-requests --filter 'title: SOME TITLE'.
These commands will all do something on your local machine.
Run npx -p @npmcli/stafftools@latest gh --help
to see a full list of commands.
Clone all repos returned from the query.
Merge all pending release pull requests.
Merge pending release PRs and publish the resulting release.
Fix failing template-oss pull requests.