Skip to content

Commit

Permalink
Merge pull request #2 from keystonejs/master
Browse files Browse the repository at this point in the history
Pulling from KJS Master
  • Loading branch information
Nathan Simpson authored Aug 1, 2018
2 parents 9e6d947 + 1297080 commit af6e0a4
Show file tree
Hide file tree
Showing 12 changed files with 240 additions and 201 deletions.
46 changes: 25 additions & 21 deletions docs/Getting Started/Setting-Up/part-1.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,39 +2,42 @@

## Introduction

If you want to jump right in to a working Keystone codebase, check out our [quick start guide](/getting-started/yo-generator), which walks you through using our generator to get a Keystone codebase up and running quickly. This tutorial will walk you through setting up a project, looking at what the core parts of Keystone are and how to set them up.
If you want to jump right in to a working Keystone codebase, check out the [Quick Start](/getting-started/yo-generator) guide which walks you through using our generator to get a Keystone codebase up and running quickly.

This guide assumes you are familiar with using npm to install packages, and javascript as a language.
This Setting Up tutorial will walk you through setting up a project from scratch, including introducing and configuring the core parts of Keystone.

We're going to be tackling this in three parts.
This guide assumes you are familiar with [using `npm`](https://docs.npmjs.com/getting-started/what-is-npm) to install packages and JavaScript as a programming language.

Part 1 (this one here) will focus on installation and setting up our `keystone.js` file, which launch our app.
We're going to be tackling setting up from scratch in four parts:

[Part 2](/getting-started/setting-up/part-2) will detail building Keystone models and setting up your database.
- **Part 1: Initial Setup** (the page you are reading) starts with installation and setting up a `keystone.js` file to launch your application.

[Part 3](/getting-started/setting-up/part-3) will go through setting up routes with Keystone to serve both database information as well as website pages.
- [Part 2: Data Model Setup](/getting-started/setting-up/part-2) walks you through building your first data model.

[Part 4](/getting-started/setting-up/part-4) will get a us a `POST` endpoint which we can use to post data to.
- [Part 3: Routing](/getting-started/setting-up/part-3) introduces setting up routes with Keystone to serve website pages.

Before we start, make sure you have [node](nodejs.org) and [mongo](https://www.mongodb.com/download-center?jmp=nav#community) installed.
- [Part 4: Adding data from a form](/getting-started/setting-up/part-4) demonstrates how to create a `POST` endpoint for submitting data.

Before getting started, make sure you have [Node.js](nodejs.org) and [MongoDB](https://www.mongodb.com/download-center?jmp=nav#community) installed.

## Installation
Start by creating a new directory and then from within it run `npm init`. This will set us up with a `package.json` for you with the ability to set up some default options.

Start by creating a new directory and then from within it run `npm init`. Follow the prompts to create a default `package.json`.

Next, install Keystone with `npm install --save keystone`.

At this point, we should have a `node_modules` directory and Keystone should have been added to the `package.json`.
At this point, you should have a `node_modules` directory and Keystone should have been added to the `package.json`.

## Initial Setup

Create a new file, `keystone.js` and we're ready to start configuring Keystone.
Create a new file, `keystone.js`, and you'll be ready to start configuring Keystone.

Your `keystone.js` file is the launch file for Keystone, which will connect Keystone to your database, start the database connection, and start your server running. This is where we will be adding configuration options to Keystone as well, which allow us to change how Keystone is running.
`keystone.js` file is the launch file for Keystone: it defines general configuration options, initialises Keystone, and starts your application server.

The minimum file we need to start Keystone running is:

```javascript
var keystone = require('Keystone');
var keystone = require('keystone');

keystone.init({
'cookie secret': 'secure string goes here',
Expand All @@ -43,29 +46,30 @@ keystone.init({
keystone.start();
```

First we require Keystone, then we run `keystone.init()`. This function sets up Keystone's initial starting values. Here we are only providing it a cookie secret, however as we build up our application we are going to come back and add more options here. If you want to check out the full list of options, you can find them [here](/documentation/configuration).
Your `keystone.js` needs to require `keystone` and then run the `keystone.init()` function to set up Keystone's initial values.

A `cookie secret` is the only option that is technically required to launch Keystone, however we'll be fleshing this out as we complete our setup.
In this example we are only providing a `cookie secret`. Technically this is the only non-default option that is required to launch Keystone, however as you complete this tutorial you will be adding more options.

Finally, we call `keystone.start()`, which kicks off our Keystone app.
Finally, we call `keystone.start()`, which kicks off the Keystone app.

We can now check this runs. Run `node keystone.js` and you should be greeted with:
You can now check this runs. Run `node keystone.js` and you should be greeted with:

```sh
------------------------------------------------
KeystoneJS Started:
KeystoneJS v4.0.0 started:
Keystone is ready on http://0.0.0.0:3000
------------------------------------------------
```

You should get a 404 page. That's ok! That will be resolved in [part 3](/getting-started/setting-up/part-3) of this guide. In [Part 2](/getting-started/setting-up/part-2) we are going to focus on getting the database connected, and the admin UI up and running. You can do these two in either order.
You should get a 404 page. That's expected since there are no pages set up yet.

## Next Steps
Check out [part 2](/getting-started/setting-up/part-2) of this guide, which walks you through setting up your database, or if you want to read more about any of the parts we set up, you can check out these links:

This tutorial continues in [Part 2: Data Model Setup](/getting-started/setting-up/part-2), which walks you through setting up your first data model.


## Learn more about:

- [keystone.init](/api/methods/init)
- [keystone.start](/api/methods/start)
- [keystone setup configuration](/documentation/configuration)
- [Keystone Setup Options](/documentation/configuration)
Loading

0 comments on commit af6e0a4

Please sign in to comment.