diff --git a/.eslintignore b/.eslintignore index d1c1dbe227..e88a1d1af6 100644 --- a/.eslintignore +++ b/.eslintignore @@ -1,2 +1,9 @@ node_modules bundle.js +website/blog +website/build +website/node_modules +website/i18n/*.js +website/translated_docs +website/core +website/pages diff --git a/.gitignore b/.gitignore index f67a381ed1..e9a64d5f5d 100644 --- a/.gitignore +++ b/.gitignore @@ -43,3 +43,11 @@ typings # We use yarn.lock package-lock.json + +# Website stuff +/website/build +/website/backers.json +/website/node_modules +/website/yarn.lock +/website/translated_docs +/website/i18n/* \ No newline at end of file diff --git a/.travis.yml b/.travis.yml index 3f7ff007d5..dcdf1b6eeb 100644 --- a/.travis.yml +++ b/.travis.yml @@ -14,7 +14,8 @@ before_script: - greenkeeper-lockfile-update script: yarn run test:coverage after_script: greenkeeper-lockfile-upload -after_success: yarn run test:coverage-report +after_success: +- yarn run test:coverage-report notifications: slack: secure: MroremSKwtQkwPbrXjgs9hIqKTCDKk7bAIXXzjcS6wXC9uRaFgwFaW8oO3vBxtWa4BL44EQBLE/rboWgqFER62+XgXNgEqGZqrcJHJvby4r+dUNMPI64OZvWdIiydIYxLo8C1C4x5PqBup0xuLq8h/SBnNvA2NLgkjuvzOi+v/Q= @@ -22,3 +23,13 @@ addons: postgresql: '9.4' cache: yarn: true +deploy: + # deploy doc on master to production + - provider: script + script: + - git config --global user.name "${GH_NAME}" + - git config --global user.email "${GH_EMAIL}" + - echo "machine github.com login ${GH_NAME} password ${GH_TOKEN}" > ~/.netrc + - cd website && npm install && GIT_USER="${GH_NAME}" npm run publish-gh-pages + on: + branch: master \ No newline at end of file diff --git a/docs/activation-strategies.md b/docs/activation-strategies.md index 3e1c16406f..d3bea98178 100644 --- a/docs/activation-strategies.md +++ b/docs/activation-strategies.md @@ -1,4 +1,8 @@ -# Activation Strategies +--- +id: activation_strategy +title: Activation Strategies +--- + It is powerful to be able to turn a feature on and off instantaneously, without redeploying the application. The next level of control comes when you are able to enable a feature for specific users or enable it for a small subset of the users. We achieve this level of control with the help of activation strategies. The most simple strategy is the “default” strategy, which basically means that the feature should be enabled to everyone. diff --git a/docs/api/admin/events-api.md b/docs/api/admin/events-api.md index aece9ffdb1..48f12cd014 100644 --- a/docs/api/admin/events-api.md +++ b/docs/api/admin/events-api.md @@ -1,3 +1,8 @@ +--- +id: events +title: /api/admin/events +--- + # Events API `GET: http://unleash.host.com/api/admin/events` diff --git a/docs/api/admin/feature-toggles-api.md b/docs/api/admin/feature-toggles-api.md index 744983474b..cc4f6e5474 100644 --- a/docs/api/admin/feature-toggles-api.md +++ b/docs/api/admin/feature-toggles-api.md @@ -1,3 +1,8 @@ +--- +id: features +title: /api/admin/features +--- + ### Fetching Feature Toggles `GET: http://unleash.host.com/api/admin/features` diff --git a/docs/api/admin/metrics-api.md b/docs/api/admin/metrics-api.md index f9e1e316e1..feca5bbcfc 100644 --- a/docs/api/admin/metrics-api.md +++ b/docs/api/admin/metrics-api.md @@ -1,3 +1,8 @@ +--- +id: metrics +title: /api/admin/metrics +--- + # This document describes the metrics endpoint for admin ui diff --git a/docs/api/admin/strategies-api.md b/docs/api/admin/strategies-api.md index 3ba64e5952..0e4f17b432 100644 --- a/docs/api/admin/strategies-api.md +++ b/docs/api/admin/strategies-api.md @@ -1,4 +1,7 @@ -## Strategies API +--- +id: strategies +title: /api/admin/strategies +--- ### Fetch Strategies `GET: http://unleash.host.com/api/admin/strategies` diff --git a/docs/api/client/feature-toggles-api.md b/docs/api/client/feature-toggles-api.md index bf0847d9fd..b92db8068c 100644 --- a/docs/api/client/feature-toggles-api.md +++ b/docs/api/client/feature-toggles-api.md @@ -1,3 +1,8 @@ +--- +id: features +title: /api/client/features +--- + ### Fetching Feature Toggles `GET: http://unleash.host.com/api/client/features` diff --git a/docs/api/client/metrics-api.md b/docs/api/client/metrics-api.md index d1428b0c93..5027859977 100644 --- a/docs/api/client/metrics-api.md +++ b/docs/api/client/metrics-api.md @@ -1,8 +1,11 @@ -# This document describes the client metrics endpoints +--- +id: metrics +title: /api/client/metrics +--- ### Send metrics -`POST http://unleash.host.com/api/client/metrics` +`POST: http://unleash.host.com/api/client/metrics` Register a metrics payload with a timed bucket. diff --git a/docs/api/client/register-api.md b/docs/api/client/register-api.md index da3a3769d2..4ef26ffeef 100644 --- a/docs/api/client/register-api.md +++ b/docs/api/client/register-api.md @@ -1,4 +1,7 @@ -# This document describes the client registration endpoints +--- +id: register +title: /api/client/register +--- ### Client registration diff --git a/docs/api/index.md b/docs/api/index.md index 1c035ce28a..306d7e579e 100644 --- a/docs/api/index.md +++ b/docs/api/index.md @@ -1,4 +1,7 @@ -# API Documentation +--- +id: index +title: API Documentation +--- ## Client API This describes the API provided to unleash-clients. diff --git a/docs/api/internal-backstage-api.md b/docs/api/internal-backstage-api.md index ab11889779..2d8b57974f 100644 --- a/docs/api/internal-backstage-api.md +++ b/docs/api/internal-backstage-api.md @@ -1,3 +1,8 @@ +--- +id: internal +title: /internal-backstage/prometheus +--- + # Internal Backstage API `GET http://unleash.host.com/internal-backstage/prometheus` diff --git a/docs/client-specification.md b/docs/client-specification.md index 9fa461082f..67831b1e75 100644 --- a/docs/client-specification.md +++ b/docs/client-specification.md @@ -1,3 +1,9 @@ +--- +id: client_specification +title: Client Specification +--- + + # Client Specification 1.0 This document attempts to guide developers in implementing a Unleash Client SDK. diff --git a/docs/database-backup.md b/docs/database-backup.md index 0ddeab59da..d4dd930f35 100644 --- a/docs/database-backup.md +++ b/docs/database-backup.md @@ -1,4 +1,8 @@ -# Database backups +--- +id: database_backup +title: Database Backup +--- + When upgrading to a new major version of Unleash it is advised to do a full database backup to ease rollback in case of failures. diff --git a/docs/database-schema.md b/docs/database-schema.md index 16c10a0408..e959678db0 100644 --- a/docs/database-schema.md +++ b/docs/database-schema.md @@ -1,4 +1,8 @@ -# Schema +--- +id: database_schema +title: Database Schema +--- + This document describes our current database schema used in PostgreSQL. We use db-migrate to migrate (create tables, add columns etc) the database. diff --git a/docs/developer-guide.md b/docs/developer-guide.md index 6932cbcdc0..edbdb5befe 100644 --- a/docs/developer-guide.md +++ b/docs/developer-guide.md @@ -1,4 +1,8 @@ -# Developer Guide +--- +id: developer_guide +title: Developer guide +--- + ## PostgreSQL To run and develop unleash you need to have PostgreSQL database (PostgreSQL v.9.5.x or newer) locally. diff --git a/docs/getting-started.md b/docs/getting-started.md index e73b70aa0a..0c777802b1 100644 --- a/docs/getting-started.md +++ b/docs/getting-started.md @@ -1,4 +1,7 @@ -# Getting stated +--- +id: getting_started +title: Getting Started +--- ## Requirements diff --git a/docs/migration-guide.md b/docs/migration-guide.md index 4cedc82c80..0121cf5526 100644 --- a/docs/migration-guide.md +++ b/docs/migration-guide.md @@ -1,4 +1,8 @@ -# Migrations guide +--- +id: migration_guide +title: Migration Guide +--- + Generally the intention is that `unleash-server` should always provide support for clients one lower major version. This should make possible to upgrade `unleash` gradually. diff --git a/docs/securing-unleash.md b/docs/securing-unleash.md index c6841c1fd3..f9ca33658d 100644 --- a/docs/securing-unleash.md +++ b/docs/securing-unleash.md @@ -1,4 +1,8 @@ -# Securing Unleash +--- +id: securing_unleash +title: Securing Unleash +--- + The Unleash API is split in two different paths: `/api/client` and `/api/admin`. This makes it easy to have different authentication strategy for the admin interface and the client-api used by the applications integrating with Unleash. diff --git a/docs/unleash-context.md b/docs/unleash-context.md index 4a91dd1ab0..8a6fe07379 100644 --- a/docs/unleash-context.md +++ b/docs/unleash-context.md @@ -1,4 +1,8 @@ -# Unleash Context +--- +id: unleash_context +title: Unleash Context +--- + In order to standardise a few activation strategies we also needed to standardise a unleash context, which contains some fields that varies diff --git a/website/README.md b/website/README.md new file mode 100644 index 0000000000..b7490fdf7a --- /dev/null +++ b/website/README.md @@ -0,0 +1,145 @@ +The Unleash website was created with [Docusaurus](https://docusaurus.io/). + +It's hosted on https://unleash.github.io/ + +# What's In This Document + +* [Get Started in 5 Minutes](#get-started-in-5-minutes) +* [Directory Structure](#directory-structure) +* [Editing Content](#editing-content) +* [Adding Content](#adding-content) +* [Full Documentation](#full-documentation) + +# Get Started in 5 Minutes + +1. Make sure all the dependencies for the website are installed: + +```sh +# Install dependencies +$ npm install +``` +2. Run your dev server: + +```sh +# Start the site +$ npm run start +``` + +## Directory Structure + +Your project file structure should look something like this + +``` +unleash/ + docs/ + doc-1.md + doc-2.md + doc-3.md + website/ + core/ + pages/ + static/ + css/ + img/ + package.json + sidebar.json + siteConfig.js +``` + +# Editing Content + +## Editing an existing docs page + +Edit docs by navigating to `docs/` and editing the corresponding document: + +`docs/doc-to-be-edited.md` + +```markdown +--- +id: page-needs-edit +title: This Doc Needs To Be Edited +--- + +Edit me... +``` + +For more information about docs, click [here](https://docusaurus.io/docs/en/navigation) + +# Adding Content + +## Adding a new docs page to an existing sidebar + +1. Create the doc as a new markdown file in `/docs`, example `docs/newly-created-doc.md`: + +```md +--- +id: newly-created-doc +title: This Doc Needs To Be Edited +--- + +My new content here.. +``` + +1. Refer to that doc's ID in an existing sidebar in `website/sidebar.json`: + +```javascript +// Add newly-created-doc to the Getting Started category of docs +{ + "docs": { + "Getting Started": [ + "quick-start", + "newly-created-doc" // new doc here + ], + ... + }, + ... +} +``` + +For more information about adding new docs, click [here](https://docusaurus.io/docs/en/navigation) + +## Adding items to your site's top navigation bar + +1. Add links to docs, custom pages or external links by editing the headerLinks field of `website/siteConfig.js`: + +`website/siteConfig.js` +```javascript +{ + headerLinks: [ + ... + /* you can add docs */ + { doc: 'my-examples', label: 'Examples' }, + /* you can add custom pages */ + { page: 'help', label: 'Help' }, + /* you can add external links */ + { href: 'https://github.com/facebook/Docusaurus', label: 'GitHub' }, + ... + ], + ... +} +``` + +For more information about the navigation bar, click [here](https://docusaurus.io/docs/en/navigation) + +## Adding custom pages + +1. Docusaurus uses React components to build pages. The components are saved as .js files in `website/pages/en`: +1. If you want your page to show up in your navigation header, you will need to update `website/siteConfig.js` to add to the `headerLinks` element: + +`website/siteConfig.js` +```javascript +{ + headerLinks: [ + ... + { page: 'my-new-custom-page', label: 'My New Custom Page' }, + ... + ], + ... +} +``` + +For more information about custom pages, click [here](https://docusaurus.io/docs/en/custom-pages). + +# Full Documentation + +Full documentation can be found on the [website](https://docusaurus.io/). diff --git a/website/core/Footer.js b/website/core/Footer.js new file mode 100644 index 0000000000..282cb8382a --- /dev/null +++ b/website/core/Footer.js @@ -0,0 +1,86 @@ +/** + * Copyright (c) 2017-present, Facebook, Inc. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +const React = require('react'); + +class Footer extends React.Component { + docUrl(doc, language) { + const baseUrl = this.props.config.baseUrl; + return `${baseUrl}docs/${language ? `${language}/` : ''}${doc}`; + } + + pageUrl(doc, language) { + const baseUrl = this.props.config.baseUrl; + return baseUrl + (language ? `${language}/` : '') + doc; + } + + render() { + return ( + + ); + } +} + +module.exports = Footer; diff --git a/website/package.json b/website/package.json new file mode 100644 index 0000000000..04776b1e7a --- /dev/null +++ b/website/package.json @@ -0,0 +1,14 @@ +{ + "scripts": { + "examples": "docusaurus-examples", + "start": "docusaurus-start", + "build": "docusaurus-build", + "publish-gh-pages": "docusaurus-publish", + "write-translations": "docusaurus-write-translations", + "version": "docusaurus-version", + "rename-version": "docusaurus-rename-version" + }, + "devDependencies": { + "docusaurus": "^1.5.1" + } +} diff --git a/website/pages/en/help.js b/website/pages/en/help.js new file mode 100755 index 0000000000..512e335a99 --- /dev/null +++ b/website/pages/en/help.js @@ -0,0 +1,58 @@ +/** + * Copyright (c) 2017-present, Facebook, Inc. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +const React = require('react'); + +const CompLibrary = require('../../core/CompLibrary.js'); + +const Container = CompLibrary.Container; +const GridBlock = CompLibrary.GridBlock; + +const siteConfig = require(`${process.cwd()}/siteConfig.js`); + +function docUrl(doc, language) { + return `${siteConfig.baseUrl}docs/${language ? `${language}/` : ''}${doc}`; +} + +class Help extends React.Component { + render() { + const language = this.props.language || ''; + const supportLinks = [ + { + content: `Learn more using the [documentation on this site.](${docUrl( + 'doc1.html', + language, + )})`, + title: 'Browse Docs', + }, + { + content: 'Ask questions about the documentation and project', + title: 'Join the community', + }, + { + content: "Find out what's new with this project", + title: 'Stay up to date', + }, + ]; + + return ( +
This project is maintained by a dedicated group of people.
++ Unleash is a feature toggle system, that gives you a great overview over all feature toggles across + all your applications and services. It comes with official client implementations for Java, Node.js, Go, Ruby and Python. +
++ The main motivation for doing feature toggling is to decouple the process for deploying code to production + and releasing new features. This helps reducing risk, and allow us to easily manage which features to enable +
++ Unleash has offical SDK's for Java, Node.js, Go, Ruby and Python. And we will be happy to add implementations in other langugages written by you! These libraries makes it very easy to use Unleash in you application. +
+ +This project is used by all these people
+This project is used by many folks
+Are you using this project?
+ + Add your company + +