Skip to content

Latest commit

 

History

History
74 lines (55 loc) · 2.32 KB

README.md

File metadata and controls

74 lines (55 loc) · 2.32 KB

Probot: Censor

a GitHub App built with probot that removes sensitive stuff from issues, pull requests and comments

Usage

  1. Configure the GitHub App
  2. Create .github/censor.yml based on the following template
  3. It will start scanning for sensitive information in issues and comments and edit them.

A .github/censor.yml file is required to enable the plugin. The file must specify rules for the bot to scan in the following format:

# An optional generic message to reply after censoring
message: "Hi there, I just edited this for you."
# The required list of rules
rules:
    # A required pattern to scan for. Accepts anything that is a valid JavaScript regular expression
  - pattern: "(private_key|auth_token)=\w+"
    # The text to replace all matches with. Can refer to matching groups with $
    replacement: "$1=🔑"
    # Optional modifiers for the above regular expression. Defaults to "gi"
    modifier: "gi"
    # Optional message to reply to if this rule matches. If empty, no message is sent
    message: "Please **never post your private tokens**."

Development

# Install dependencies
yarn

# Run the bot
yarn start

# Run test watchers
yarn test:watch

We use prettier for auto-formatting and eslint as linter. Both tools can automatically fix a lot of issues for you. To invoke them, simply run:

yarn fix

It is highly recommended to use VSCode and install the suggested extensions. They will configure your IDE to match the coding style, invoke auto formatters every time you save and run tests in the background for you. No need to run the watchers manually.

Deployment

If you would like to run your own instance of this app, see the docs for deployment.

This app requires these Permissions for the GitHub App:

  • Repository contents: Read-only
  • Issues: Read & write
  • Pull requests: Read & write

Also, the following Events need to be subscribed:

  • Issues: Issue opened or edited
  • Pull request: Pull request opened or edited
  • Issue comment: Issue comment created, edited, or deleted