-
Notifications
You must be signed in to change notification settings - Fork 204
Setting up Journey
This page will show you how to set up Journey. Please read all steps before using Journey in production.
NOTE: If you'd like to set up Journey on a linux server, head over to Installing Journey on Ubuntu Server for a step-by-step tutorial.
Go to https://github.com/kabukky/journey/releases and download to the latest Journey release package for your platform. Then extract the zip file anywhere you like (e.g. in you users home folder).
In your Terminal, navigate to your Journey folder (e.g. /home/youruser/journey/) and start Journey by typing
./journey
when using Linux, Mac OS X, or another Unix
or
journey.exe
when using Windows. Alternatively, you can just double-click the executable.
Journey is now running.
To visit your Journey blog, open
http://127.0.0.1:8084
in your browser. You probably haven't written any blog posts to display yet. Let's change that.
Open
http://127.0.0.1:8084/admin
in your browser. Fill out the information to create your Journey admin account. In the next step, log in using the user name and password you just provided.
From the admin area you can:
- create, edit, and delete blog posts
- edit your blog settings
- edit your user settings
NOTE: Journey needs to be restarted for the config.json to take effect. Stop Journey by using Ctrl+C in your terminal or closing the terminal window, then start it again. Journey will load its configuration from the config.json.
By editing the "config.json" file in your Journey root directory, you'll change the following settings:
"HttpHostAndPort"
This will change the port the Journey HTTP server is listening on. If you don't want to bind to a particular ip address, writing just ":port number" as the value is fine (e.g. ":8084")
NOTE: If you want to change the port to 80 (HTTP default) Journey will probably need root privileges. There are at least three possibilities to run Journey and bind to a lower port: 1) run Journey as root (bad idea!), 2) use something like setcap (sudo setcap 'cap_net_bind_service=+ep' /path/to/journey/executable) to grant Journey root privileges only for binding (good idea!), or 3) set your firewall to redirect from port 80 to your higher Journey port (good idea!).
"HttpsHostAndPort"
This will change the port the Journey HTTPS server is listening on. If you don't want to bind to a particular ip address, writing just ":port number" as the value is fine (e.g. ":8085")
NOTE: If you want to change the port to 443 (HTTPS default) Journey will probably need root privileges. There are at least three possibilities to run Journey and bind to a lower port: 1) run Journey as root (bad idea!), 2) use something like setcap (sudo setcap 'cap_net_bind_service=+ep' /path/to/journey/executable) to grant Journey root privileges only for binding (good idea!), or 3) set your firewall to redirect from port 443 to your higher Journey port (good idea!).
"HttpsUsage"
This will change the HTTPS setting of your Journey blog. There are three possible values:
- "None"
- Your Journey blog and admin area will only be accessible by HTTPS, NO HTTPS support is available.
- "AdminOnly"
- Your admin area will ONLY be accessible by HTTPS (HTTP connections will be redirected to HTTPS), your Journey blog will be accessible by both HTTP and HTTPS.
- "All"
- Your Journey blog and admin area will ONLY be accessible by HTTPS (HTTP connections will be redirected to HTTPS).
NOTE: For a minimum of security, "HttpsUsage" should always be set to at least "AdminOnly" to ensure your login credentials and cookies are being sent using an encrypted connection.
When HTTPS is enabled ("HttpsUsage" is not set to "None"), you have to provide files containing a certificate and matching private key for the server.
Those files have to be placed in the content/https folder (e.g. /home/youruser/journey/content/https) as cert.pem and key.pem.
If HTTPS is enabled and the cert.pem and cert.key files are not present in this directory, the application will generate new cert.pem and cert.key files upon startup.
Replace those files with your own as soon as possible and don't use them in production.
"Url"
This will change the url of your Journey blog. Change this to the host name the blog is supposed to be reachable under (e.g. "www.myblog.com").
The "HttpUrl" setting is used to generate links to the blog (rss feeds and @blog.url helper).
"HttpsUrl"
This will change the HTTPS url of your Journey blog. Change this to the host name the blog is supposed to be reachable under (e.g. "www.myblog.com"). On a production server, this is usually set to the same value as Url. It will probably only differ when you do not use the standard HTTPS port (443).
The "HttpsUrl" setting is used to redirect incoming HTTP connections to HTTPS.
The Promenade theme is included by default to make Journey work out of the box. However, it is only intended to be used on a one author, personal website.
For a fully fledged, multiple author blog experience try the Casper theme from the makers of Ghost.
Download it and place the Casper directory in the content/themes folder of your Journey installation (e.g. /home/youruser/journey/content/themes). Then select Casper from your admin panel under Settings/Blog.
After that, try some other themes! There's a whole world of Ghost themes out there. Find the one you like best.
Finally, you can always write your own theme and use it with Journey. Start by visiting http://themes.ghost.org and by reading one of the many tutorials that show you how to create a Ghost theme!