This repository has been archived by the owner on Oct 6, 2022. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 30
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #60 from christriddle/master
Improved readme
- Loading branch information
Showing
2 changed files
with
55 additions
and
33 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,66 +1,75 @@ | ||
hobknob | ||
![Alt OpenTable](http://www.opentable.com/img/common/opentable_logo_reg.png)Hobknob | ||
====================== | ||
|
||
Hobknob is a feature toggle front-end built on top of [etcd](https://github.com/coreos/etcd). It allows users to create, maintain and toggle feature toggles and keeps an audit of all changes. | ||
[<img src="http://standards-badges.herokuapp.com/image?serviceStatusEndpoint=0&logSchema=0&githubReadme=1">](http://standards-badges.herokuapp.com/?serviceStatusEndpoint=0&logSchema=0&githubReadme=1) | ||
|
||
The benefit of using etcd as a data store is that there is no need to write an additional API to query for toggles, or a eventing system to update consumers, as it is baked into etcd. Etcd has its own implementation using [long polling](https://github.com/coreos/etcd/blob/master/Documentation/api.md#waiting-for-a-change). | ||
Hobknob is a feature toggle front-end built on top of [etcd](https://github.com/coreos/etcd). | ||
It allows users to create, maintain, and set feature toggles. It will also keep an audit of all changes. | ||
|
||
###Screenshots | ||
Etcd is a good fit for feature toggles. It has a good http API to query the state of the toggle, and an eventing system to notify consumers of changes. | ||
More information on etcd can be found here: [etcd](https://github.com/coreos/etcd). | ||
|
||
##### Application View | ||
![New Toggle](screenshots/ApplicationView.png) | ||
##### Toggle View | ||
![New Toggle](screenshots/ToggleView.png) | ||
## Screenshots | ||
|
||
###Running the app locally | ||
The quickest way to run the app locally is to use Vagrant. If you don't have Vagrant you should install it from [here](http://www.vagrantup.com/). | ||
### Application View | ||
![Application View](screenshots/ApplicationView.png) | ||
|
||
### Toggle View | ||
![Toggle View](screenshots/ToggleView.png) | ||
|
||
#####Running using Vagrant | ||
`vagrant-up` will spin up a vagrant instance and install etcd and the app in a Docker container with the application running on port 3006 | ||
### Running the application | ||
|
||
#####Running manually | ||
The application is written against NodeJS version 0.10.26. This should be installed prior to trying to run the application. After checkout you should install dependencies using npm. | ||
## Vagrant | ||
The quickest way to run the app locally is to use Vagrant. If you don't have Vagrant you should install it from [here](http://www.vagrantup.com/). | ||
`vagrant-up` will spin up a vagrant instance and install etcd and Hobknob, which are exposed on ports 4001 and 3006 respectfully. | ||
Hobknob itself is deployed in a Docker container inside of the vagrant instance. | ||
|
||
Hobknob relies on you having a local install of etcd. To get it running look at [the docs](https://github.com/coreos/etcd#building) it's incredibly easy to get running. Make sure you start it up with the -cors flag: | ||
## Manual | ||
The application is dependant on NodeJS version 0.10.26. This can be downloaded [here](http://nodejs.org/download/). | ||
|
||
### etcd | ||
A local (or development) installation of Hobknob is configured to use a locally running etcd instance. A useful guide is available [here](https://github.com/coreos/etcd#building). | ||
Or, here is a simple way to etcd up and running on a Mac: | ||
|
||
```sh | ||
$ ./bin/etcd -cors http://127.0.0.1:3006 | ||
$ curl -L https://github.com/coreos/etcd/releases/download/v0.4.6/etcd-v0.4.6-darwin-amd64.zip | tar xvz | ||
$ cd etcd-v0.4.6-darwin-amd64 | ||
$ ./etcd | ||
``` | ||
|
||
### Hobknob | ||
|
||
The following will checkout and run Hobknob (accessible http://127.0.0.1:3006/). | ||
|
||
```sh | ||
# Clone the app | ||
$ git clone [email protected]:opentable/hobknob.git | ||
$ cd hobknob | ||
|
||
# Install npm | ||
$ sudo npm install -y | ||
|
||
# Install bower dependencies | ||
$ npm install -g bower | ||
$ bower install | ||
|
||
# Prepare config (this is a temporary measure) | ||
$ npm install | ||
$ grunt | ||
$ npm start | ||
``` | ||
|
||
# Run the app | ||
$ node server/dev-app.js | ||
# Preparing the config | ||
|
||
To generate the client-side config, you need to run the following command (until we find a better solution): | ||
```sh | ||
$ grunt | ||
``` | ||
|
||
You can then access the site on http://127.0.0.1:3006 | ||
|
||
###Testing with Protractor | ||
## Testing with Protractor | ||
We've integrated protractor for end-to-end testing. To start these tests run: | ||
|
||
```sh | ||
# Make sure you have the app running first | ||
$ npm test | ||
``` | ||
|
||
### Configuring Authentication | ||
## Configuring Authentication | ||
By default Hobknob ships with authentication disabled. This is configurable by changing the config/config.json config file. | ||
|
||
#### Turning on Google OAuth | ||
### Turning on Google OAuth | ||
First you must generate a google oauth client Id and client secret. To do this visit the [Google Developer Console](https://console.developers.google.com/project) and create a new project. Select this project once created and go into the section "APIs and auth" in the left hand menu. From here you can create a new oath client Id. | ||
|
||
To use oath in Hobknob add the following to your config (config/confg.json). | ||
|
@@ -78,11 +87,24 @@ To use oath in Hobknob add the following to your config (config/confg.json). | |
``` | ||
|
||
This configuration is shared with Angular so you need to run the following: | ||
```sh | ||
$ grunt | ||
``` | ||
|
||
### Access Control List | ||
When authentication is enabled, you can control who is allowed to add, update, or delete toggles per application. | ||
|
||
The creator of an application is automatically an owner of that application. Application owners can add other owners via the Owners panel in the Application View. | ||
|
||
![Application Owners](screenshots/ApplicationOwners.png) | ||
|
||
If in an emergency, you need to be added to an application's ACL, you can use this command: | ||
|
||
``` | ||
grunt | ||
curl -L -X PUT http://<etcd_host>:<etcd_port>/v2/keys/v1/toggleAcl/<application-name>/<email> -d value=<email> | ||
``` | ||
|
||
### Configuring Session | ||
## Configuring Session | ||
By default session is stored in-memory using the expressjs connect middleware. For a single machine environment this is fine. When you have multiple load balanced machines you probably want to use some kind of shared stored. Hobknob currently supports [Redis](https://github.com/visionmedia/connect-redis) or [etcd](https://github.com/opentable/connect-etcd) connect middleware. | ||
|
||
Configuring session is simple. Just npm install the module you want to use. For example, to use etcd to store session simple use: | ||
|
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.