The Hasura console is an admin dashboard to manage the connected database and to try out GraphQL APIs. It is a React application bundled with webpack and the state is managed using Redux.
The console is served by GraphQL Engine at `/console` endpoint (when `--enable-console` flag is used). Typically runs in **No Migration Mode** which means that actions on the console are not spitting out migration “yaml” files automatically. Most users will be using the Hasura console in this mode.
2. Hasura CLI:
Served by the Hasura CLI using `hasura console` command, typically runs with migration mode **enabled**. All the changes to schema/hasura metadata will be tracked and spit out on the filesystem as migration yaml files and a metadata yaml file. This allows for easy version controlling of the schema/hasura metadata.
## Contributing to Hasura console
This guide is for setting-up the console for development on your own machine, and how to contribute.
Hasura console can be developed in two modes (`server` or `cli` mode). Both modes require a running instance of GraphQL Engine. The easiest way to get Hasura GraphQL engine instance is by Heroku. You can get it by following the steps given in [this](https://docs.hasura.io/1.0/graphql/manual/getting-started/heroku-simple.html) link. Other methods to install Hasura GraphQL engine are documented [here](https://docs.hasura.io/1.0/graphql/manual/getting-started/index.html).
Hasura GraphQL engine should be running to develop console in this mode. If you have set it up on Heroku, your url will look like `<app-name>.herokuapp.com`, if it's on your local machine, it's probably `http://localhost:8080`.
[Dotenv](https://github.com/motdotla/dotenv) is used for setting environment variables for development. Create a `.env` file in the root directory for console (wherever package.json is). Here's a `.env` file with some environment variable examples :
Note that `CONSOLE_MODE` is set to `server`. In this mode, **migrations** will be disabled and the corresponding functionality on the console will be hidden. If you are looking to add/tweak functionality related to migrations, check out [Development with Hasura CLI](#development-with-hasura-cli-cli-mode).
1.`PORT`: Configure the port where Hasura console will run locally.
2.`NODE_ENV`: `development`
3.`DATA_API_URL`: Configure it with the Hasura GraphQL Engine url. If you are running it on Heroku. Your url will look like <app-name>.herokuapp.com
4.`API_HOST`: Hasura CLI host. Hasura CLI runs on `http://localhost` by default.
5.`API_PORT`: Hasura CLI port. Hasura CLI exposes the API at `9693` by default
6.`ACCESS_KEY`: Set access key if Hasura GraphQL engine is configured to run with ACCESS_KEY
7.`CONSOLE_MODE`: `cli`
8.`URL_PREFIX`: ‘/’ (forward slash)
#### Run Development Server:
This setup requires hasura cli to be running in a different window. Start hasura cli with the same Hasura GraphQL engine url as configured for `DATA_API_URL`.
##### Start Hasura CLI server
```bash
hasura console
```
##### Start development server
```bash
npm run dev
```
### Checkout the console
Visit [http://localhost:3000](http://localhost:3000) to confirm the setup.
![Testing Development Server](../assets/console-readme-assets/test-dev-setup.jpg)