2014-11-10 16:25:22 +01:00
# unleash-server
[data:image/s3,"s3://crabby-images/4199b/4199bb98db4b92da126ad23b6c1c62d2a427b06e" alt="Build Status "](https://travis-ci.org/finn-no/unleash) [data:image/s3,"s3://crabby-images/c8ab6/c8ab6f6f9eef76799d57d6c681296e04a0665df9" alt="Code Climate "](https://codeclimate.com/github/finn-no/unleash) [data:image/s3,"s3://crabby-images/f4b48/f4b486636b56a871898d3b46750a9516f8b2475a" alt="Coverage Status "](https://coveralls.io/r/finn-no/unleash?branch=master) [data:image/s3,"s3://crabby-images/c1d77/c1d7743567009ae78cdc329be33c8654fd54eecc" alt="Dependency Status "](https://david-dm.org/finn-no/unleash) [data:image/s3,"s3://crabby-images/7b197/7b1973b195aad9b215be302ebb1f26aaa490e820" alt="devDependency Status "](https://david-dm.org/finn-no/unleash#info=devD)
2014-11-06 09:29:03 +01:00
2014-10-31 16:35:35 +01:00
unleash-server is a place to ask for the status of features.
2014-09-29 14:50:46 +02:00
2014-11-10 16:39:17 +01:00
## Clients
In order to make use of unleash you will probably need a client implementation.
Known client implementations:
- [unleash-client-java ](https://github.com/finn-no/unleash-client-java )
## Development
2014-10-31 16:35:35 +01:00
### Create a local unleash-db on postgres
2014-10-31 13:03:54 +01:00
2014-10-31 16:35:35 +01:00
```bash
$ psql postgres < < SQL
CREATE USER unleash_user WITH PASSWORD 'passord';
CREATE DATABASE unleash;
GRANT ALL PRIVILEGES ON DATABASE unleash to unleash_user;
SQL
```
2014-11-10 16:25:22 +01:00
Then set DATABASE_URI env var:
2014-10-31 16:35:35 +01:00
```
export DATABASE_URL=postgres://unleash_user:passord@localhost:5432/unleash
```
2014-11-10 16:39:17 +01:00
### Commands
2014-10-31 16:35:35 +01:00
```
// Install dependencies
npm install
// Make sure DATABASE_URL is set and run migrations in your local DB
2014-11-10 16:39:17 +01:00
export DATABASE_URL=postgres://unleash_user:passord@localhost:5432/unleash
2014-10-31 16:35:35 +01:00
./node_modules/.bin/db-migrate up
// Start server in dev-mode:
2014-11-12 13:14:07 +01:00
npm run dev
2014-10-31 16:35:35 +01:00
// Admin dashboard
http://localhost:4242
// Feature API:
http://localhost:4242/features
// Execute tests:
npm test
```
2014-11-10 16:39:17 +01:00
### Making a schema change
2014-10-31 16:35:35 +01:00
1. Create `migrations/sql/NNN-your-migration-name.up.sql` with your change in SQL.
2. Create `migrations/sql/NNN-your-migration-name.down.sql` with the rollback of your change in SQL.
2014-11-10 15:58:11 +01:00
3. Run `db-migrate create your-migration-name` and edit the generated file to have this line: `module.exports = require('../lib/migrationRunner').create('NNN-your-migration-name');`
2014-11-13 20:00:34 +01:00
4. Run `db-migrate up` .
2014-10-31 16:35:35 +01:00
5. Generate LB artifact using `scripts/generate-liquibase-artifact` (TODO: make this internal)