Turn your audience into a business. Publishing, memberships, subscriptions and newsletters.
Go to file
Adam Howard 00199cee67 Refactor the initial boot of Ghost, allowing Ghost updates to keep current configuration intact.
Extracts all express-server-related code in index.js to core/server.js, leaving index.js purely for booting up Ghost's core components in a sensible order.

Aside from the project's tidiness, this means that we can perform asynchronous configuration loading/checks before requiring any modules that read the config.
2013-09-12 15:38:11 +01:00
content Added blog cover image 2013-09-09 18:13:19 +01:00
core Refactor the initial boot of Ghost, allowing Ghost updates to keep current configuration intact. 2013-09-12 15:38:11 +01:00
.afignore App restructure - closes #245 2013-07-11 20:23:34 +01:00
.gitignore Refactor the initial boot of Ghost, allowing Ghost updates to keep current configuration intact. 2013-09-12 15:38:11 +01:00
.gitmodules switching git submodule back to using ssh 2013-05-18 20:31:15 +01:00
.travis.yml Added CasperJS Functional Test to Build 2013-08-26 16:28:41 -05:00
config.example.js Refactor the initial boot of Ghost, allowing Ghost updates to keep current configuration intact. 2013-09-12 15:38:11 +01:00
config.js Clean up config (drop 'env') 2013-09-12 15:25:58 +01:00
CONTRIBUTING.md Updated README.md and CONTRIBUTING.md 2013-08-29 12:12:04 +01:00
Gruntfile.js Added redirect to get rid of /page/1/ 2013-09-09 18:32:44 +01:00
index.js Refactor the initial boot of Ghost, allowing Ghost updates to keep current configuration intact. 2013-09-12 15:38:11 +01:00
LICENSE.txt Standardising license text. 2013-09-01 17:35:31 +02:00
package.json bumping bookshelf & knex deps 2013-09-10 09:48:17 +01:00
README.md Updated README.md and CONTRIBUTING.md 2013-08-29 12:12:04 +01:00

Ghost Build Status

Ghost is a free, open, simple blogging platform that's available to anyone who wants to use it. Lovingly created and maintained by John O'Nolan + Hannah Wolfe + an amazing group of contributors.

Visit the project's website at http://tryghost.org!

Getting Started

There are two main ways to get started with Ghost:

  1. Working from a VIP Release - these are pre-built zip packages found on vip.tryghost.org. Installation instructions are below.
  2. Working from the GitHub repo - instructions can be found in CONTRIBUTING.md

Installing from a VIP Release

Please Note: VIP Releases are pre-built packages, GitHub releases (tags) are not. To install from GitHub you need to follow the contributing guide.

  1. Once you've downloaded one of the VIP packages, unzip it, and place the directory wherever you would like to run the code
  2. Fire up a terminal (or node command prompt in Windows) and change directory to the root of the Ghost application (where config.js and index.js are)
  3. run npm install to install the node dependencies (if you get errors to do with SQLite, please see the SQLite3 instructions below this list)
  4. To start ghost, run npm start
  5. Visit http://localhost:2368/ in your web browser

Updating with the latest changes

Warning: The Ghost file system contains your database and config. Be sure to back these up first.

  1. Make a backup of your data!
  2. Update the files by pasting new files over the top of old ones. If prompted by your OS or FTP client to 'merge' or 'replace' always choose merge.
  3. Run npm install
  4. Run npm update
  5. Restart the application
  6. Log out and log back in again.

SQLite3 Install Instructions

Only needed if you experienced errors in Step 3 above - Skip this otherwise

Ghost depends upon SQLite3, which has to be built for each OS. NPM is as smart as it can be about this, and as long as your machine has all the pre-requisites for compiling/building a C++ program, the npm install still works.

For Mac users: The easiest way to do this is to download/install XCode from the App Store (free). This will automatically install all the tools you need - you don't need to open the app.

For Everyone else: if you don't have the required pre-requisites, you will need to either get them, or as a shortcut, obtain a precompiled SQLite3 package for your OS. We have created some of these here.

The pre-compiled package should be downloaded, extracted and placed in the node_modules folder, such that it lives in node_modules/sqlite3, if you have a partial install of the SQLite3 package, replace it with the files you downloaded from github. Be sure that all the SQLite3 files and folders live directly in node_modules/sqlite3 - there should note be a node_modules/sqlite3/sqlite3 folder.

Logging in For The First Time

Once you have the Ghost server up and running, you should be able to navigate to http://localhost:2368/ghost from a web browser, where you will be prompted for a login.

  1. Click on the "register new user" link
  2. Enter your user details (careful here: There is no password reset yet!)
  3. Return to the login screen and use those details to log in.

Note - this is still very alpha. Not everything works yet.

Versioning

For transparency and insight into our release cycle, and for striving to maintain backward compatibility, Ghost will be maintained according to the Semantic Versioning guidelines as much as possible.

Releases will be numbered with the following format:

<major>.<minor>.<patch>-<build>

Constructed with the following guidelines:

  • A new major release indicates a large change where backwards compatibility is broken.
  • A new minor release indicates a normal change that maintains backwards compatibility.
  • A new patch release indicates a bugfix or small change which does not affect compatibility.
  • A new build release indicates this is a pre-release of the version.

Reporting Bugs and Contributing Code

Want to report a bug, request a feature, or help us build Ghost? Check out our in depth guide to Contributing to Ghost. We need all the help we can get!

Community

Keep track of Ghost development and Ghost community activity.

Copyright (C) 2013 The Ghost Foundation - Released under the MIT Lincense.

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.