Sapwood works best when you follow the communicative workflow. This means we have one production server that manages and hosts the content, along with one or more development environments using that content in their own instance.
It makes more sense to first have a production instance running. If you haven't installed your production server yet, refer to that section. If you are just installing a development instance to play around with Sapwood, it will work completely fine in that capacity.
Let's look at how to get a development environment setup.
Any computer will work fine, as long as you can run ruby projects. For the sake of making this article brief, we're going to assume you know how to run a Ruby on Rails application on your machine. This also means that Windows is not the ideal operating system.
You don't need a ton of power or space to run this application, especially since your assets should be served remotely. This is what you will need:
- Ruby 2.1
If you have all the packages required to use the programs listed above, then you should be good to go.
You likely have a directory in which you store your web projects. If you don't, it really doesn't matter where you decide to put the project. Most people create a directory within their home directory, called whatever they prefer --
apps, etc. It's your choice. Go into that directory and then clone the repository from GitHub.
$ cd /path/to/your/codes $ git clone email@example.com:seancdavis/sapwood-classic.git -b release
Note: Notice here we are specifically cloning the
releasebranch of the sapwood repo. This branch tracks the most recent release, down to the patch.
We have a few things to configure before we can be up and running. First, your database.
NOTICE: The communicative workflow is built around sharing your product database. The production setup guide talks about how to open your production database to allow for remote connections.
To get started, copy
Be sure to copy and not rename the database file. It'll be easier to endure updates in the future.
Modify this file to fit your team's settings.
development: adapter: postgresql encoding: unicode pool: 5 host: [prod_ip] port: 5432 username: [db_user] password: [db_pass] database: [db_name]
Next is the application config. Copy
config/sapwood.yml. Add a value for all the blank values, and customize
anything you wish.
DEPRECATION NOTICE: This file is being deprecated in an upcoming release. At that time, settings will be stored in the database.
Get Up and Running
Install the gems using Bundler.
$ bundle install
This is likely where you will run into issues if you don't have all the necessary dependencies. If you can't debug the issue locally, feel free to create an issue if you're stuck.
WARNING: You should not execute any database commands from within development, as they may destructively alter your live app.
Once your bundle is installed, your development is ready to go. Start your rails server and get to work!
While the content will show up immediately (assuming you have a production instance running), you will need to import the git repos as needed. See Working with Git for more information.