Skip to content
This repository has been archived by the owner on Jun 21, 2019. It is now read-only.

Latest commit

 

History

History
70 lines (53 loc) · 5.18 KB

README.md

File metadata and controls

70 lines (53 loc) · 5.18 KB

Teacherbot

A collection of GitHub Apps built with Probot to assist trainers using GitHub repositories in the classroom.

Features

If you are using GitHub repositories in the classroom, Teacherbot would like to be your configurable helper. It is designed to make working with large groups of students easier. Here are the features it includes "out of the box":

add-collabs

  • Adding collaborators: Teacherbot will automatically add any GitHub user that opens an issue in the target repository to the list of collaborators in that repository. Teacherbot will comment on the issue to let the user know they have been added. These comments are configurable and can be used to welcome the user and tell them next steps.
  • Commenting after a pull request is merged or closed: after your students have merged (or closed) their pull requests, you may want to give them some next steps. Again, these comments are configurable. We use them to remind learners to delete their branch, but the sky is the limit.
  • Checking a single file path: when students open a pull request, Teacherbot can check the directory the file is in. It then reports a status. The name, success and failure message, and target URL for more information is configurable.
  • Checking a single file extension: the extension of a single file can be configured and checked by Teacherbot. A commit status is reported back to the pull request with a configurable name, success and failure message, and target URL for troubleshooting.
  • Reopening issues closed by a stranger: working with large groups of newbies sometimes creates chaos. When a student closes another student's issue, Teacherbot can reopen the closed issue so the original author has the chance to maintain it. The behavior can be configured with a specific message, and a whitelisted team of people that can close issues.

Getting started

  1. Install this app
  2. You can use the default responses (found in index.js), but if you'd like to specify your own, create a file inside a .github folder, named teacherbot.yml and include the following text:
addCollaborators:
  newCollaboratorMessage: "This message will appear when someone opens a new issue, and is not already a collaborator."
  existingCollaboratorMessage: "This message appears when someone is already a collaborator and they open a new issue."
remindMerge:
  merged: "This message appears after Pull Request is merged."
  unmerged: "This message appears after Pull Request is closed without merging."
checkPath:
  name: "The name for the status check"
  path: "the_path_to_check"
  detailsURL: "https://link.to/more/details"
  success: "The message to display when the status check succeeds."
  failure: "The message to display when the status check fails."
checkExtension:
  name: "The name for the status check"
  extension: "the_extension_to_check"
  detailsURL: "https://link.to/more/details"
  success: "The message to display when the status check succeeds."
  failure: "The message to display when the status check fails."
reopenClosedIssues:
  message: "The message displayed when reopening new issues."
  whitelistedTeamID: <the GitHub Team ID to be whitelisted, should be a number>

Permissions

Teacherbot automatically asks for the permissions it needs when you install it. But if you're curious why, here's the lowdown:

Running your own instance of this app

See docs/deploy.md if you would like to run your own instance of this plugin.

Getting Help and Contributing

Just open a new issue in this repo if you find a bug, have a suggestion, or would like to chat about contributing. We also welcome pull requests.

Made with ❤️ by :octocat:s and friends

This Probot plugin is made by the friendly :octocat:s from GitHub Professional Services with help from the open source community. This plugin is used during the training engagements that we provide.