Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/appfolio/ladle

Serves stew to stewards
https://github.com/appfolio/ladle

Last synced: about 2 months ago
JSON representation

Serves stew to stewards

Awesome Lists containing this project

README

        

[![Circle CI](https://circleci.com/gh/appfolio/ladle.svg?style=svg)](https://circleci.com/gh/appfolio/ladle)
[![Code Climate](https://codeclimate.com/github/appfolio/ladle/badges/gpa.svg)](https://codeclimate.com/github/appfolio/ladle)
[![Coverage Status](https://coveralls.io/repos/appfolio/ladle/badge.svg?branch=master&service=github)](https://coveralls.io/github/appfolio/ladle?branch=master)
[![Codacy Badge](https://api.codacy.com/project/badge/grade/dc9336ede6bf47c688db97a5ff81c07c)](https://www.codacy.com/app/donnie-tognazzini/ladle)

Archived. Consider using [code_ownership](https://github.com/rubyatscale/code_ownership)

**Table of Contents** *generated with [DocToc](https://github.com/thlorenz/doctoc)*

- [Ladle](#ladle)
- [Usage](#usage)
- [Advanced](#advanced)
- [Architecture](#architecture)
- [Authentication](#authentication)
- [Observing Repositories](#observing-repositories)
- [Development](#development)
- [Deployment](#deployment)
- [Heroku](#heroku)
- [GitHub Application](#github-application)
- [Email Notifications](#email-notifications)
- [Restricted Access](#restricted-access)

# Ladle

An application for assisting in Appfolio's implementation of code stewardship. Stewards are folks that look after a section of code. Stewardship is opt-in and open to anyone.

## Usage

To opt-in, add your GitHub username to a `stewards.yml` file anywhere in the directory structure of a repository monitored by Ladle; for example:

_in app/stewards.yml:_
```yaml
stewards:
- dhh
```

This entry states that `dhh` is a steward of everything under _app/_.

To get notifications anytime any Pull Requests are opened that modify files in _app/_, login to Ladle using your the GitHub user you used in the `stewards.yml` file.

To remove notifications remove your name from the `stewards.yml` file.

### Advanced

Stewards file entries may include per user glob patterns for declaring more detailed targeting. For example:

_in app/stewards.yml:_
```yaml
stewards:
- ykatz
- github_username: dhh
include:
- models/*.rb
- controllers/*.rb
exclude: models/django/*.rb
```

The above file specifies that `dhh` is a steward of everything under _app/_ matching the `include:` key and not matching the `exclude:` key, while `ykatz` is a steward of everything under _app/_.

## Architecture

### Authentication

Users are authenticated using [omniauth-github](https://github.com/intridea/omniauth-github). The GitHub [scopes](https://developer.github.com/v3/oauth/#scopes) requested as part of authentication are necessary for Ladle to notify the user. Access is restricted to the [list of configured organizations.](#restricted-access)

### Observing Repositories

Repositories are observed via GitHub [webhooks](https://developer.github.com/v3/repos/hooks/). The code for repositories is accessed via an authorization token associated with a user of the repository.

Currently, repositories are added manually via the below. In the future, we could build a flow within Ladle for this.

1. Login to Ladle using the GitHub user you want to use to access the repository. The authentication process will create a token that can be used for login, but not for accessing the contents of repositories.

2. Create a [Personal Access Token](https://help.github.com/articles/creating-an-access-token-for-command-line-use/) for the user that will be used to access the repository.

3. Via the [Rails console on Heroku](https://devcenter.heroku.com/articles/getting-started-with-rails4#console), save the token created in the previous step for the user from step 1:

```ruby
user = User.find_by_github_username('dhh')
user.token = ''
user.save!
```
4. Create a [webhook](https://developer.github.com/webhooks/creating/) on the repository listening for the `pull_request` event and using `/github_events/payload` as the payload URL.

5. Via the [Rails console on Heroku](https://devcenter.heroku.com/articles/getting-started-with-rails4#console) create a new `Repository` model:

```ruby
Repository.create!(name: 'dhh/f-bombs',
webhook_secret: '',
access_via: User.find_by_github_username('dhh'))
```

## Development

See [development.md](development.md).

## Deployment

This section describes how Ladle is configured and deployed.

### Heroku

Ladle is built to be deployed on Heroku.

### GitHub Application

Ladle runs as a GitHub Application. The following ENV variables must be set:

- `GH_APPLICATION_ID`
- `GH_APPLICATION_SECRET`
- `TOKEN_KEY` # for encrypting OAuth tokens in the DB

### Email Notifications

Ladle uses SendGrid for sending email notifications to stewards. The following ENV variables must be set:

- `SENDGRID_USERNAME`
- `SENDGRID_PASSWORD`
- `MAILER_HOST`

### Restricted Access

Access to a deployed instance is permitted only if the user has access to an organization in the `ALLOWED_ORGANIZATIONS` ENV variable.