Skip to content
thecatwasnot edited this page Nov 17, 2011 · 28 revisions

Setting up the OTW archive software on Linux

(Please note: We do not expect volunteer coders to get through this on their own. We offer a much simpler setup and beginner friendly tutorials for our coders.)

This guide is intended for people who who want to set up the archive software for development purposes and who are experienced with Linux; i.e. know how to use the package manager and the command line. It was tested on Debian Squeeze; package names might differ sligthly for other Linux distributions.

Getting the source code

First of all, we need to get the sourcecode; it is located at Github and managed by a version control system which is called git. To download the sourcecode, you need to install a git client. As root, execute

aptitude install git

Now you can download (check out) the source code by typing in the command line (as a normal user)

git clone git://github.com/otwcode/otwarchive.git otwarchive-read-only

You will see what files will be downloaded, it will take a while until the whole repository is completely downloaded to your hard drive. When the command is finished, you will have a directory otwarchive-read-only which contains the source code. If you want, you can already look around!

Getting the required software to run the archive

Now for the interesting part: Getting the archive to run on our own machine! We will need a full Ruby >= 1.9.1 and MySQL >= 5.0 setup, as well as some additional libraries.

The following packages need to be installed (as root):

aptitude install git ruby1.9.1 ruby1.9.1-dev mysql-server libmysqld-dev libmysqlclient-dev libxml2-dev libxslt-dev

(If your distribution's default Ruby version is 1.9.1 or higher, you can omit the version number and go with whatever your distribution provides. On Debian Squeeze, however, 1.8 is the default and you might not be able to deinstall it if other installed programs depend on it, and 1.9.1 is the latest version. In this case, you have to be careful always to use the right Ruby version, i.e. >= 1.9.1)

(If for some reason your Linux distribution doesn't provide a suitable Ruby version, you'll have to compile Ruby yourself, see Appendix: Compiling Ruby.)

It should ask you for a password you want to use for the MySQL root (not to be confused with the the root of your Linux system), and it will start the MySQL server in the background. From now on, the MySQL server will automatically start at boot time.

The Rails framework will not be installed via the Linux package management, but via Ruby's package management, gem. Still as root, type

gem1.9.1 install rails bundler

(Again, you can omit the version number if your default Ruby version is the right one.)

You might want to create links pointing to the rails and bundler executables, e.g.

ln -s /var/lib/gems/1.9.1/gems/rails-3.0.3/bin/rails /usr/bin/rails
ln -s /var/lib/gems/1.9.1/gems/bundler-1.0.7/bin/bundle /usr/bin/bundle

Adjust the path names to your rails and bundler version number; however, 1.9.1 might still be correct even for Ruby 1.9.2.

(If your default Ruby version is not the right one, you will have to adjust those two files: The first line should then read

#!/usr/bin/env ruby1.9.1

instead of

  #!/usr/bin/env ruby

)

Now change to the otwarchive source directory and install the needed Ruby plugins:

cd otwarchive-read-only
bundle install

Configuring the archive

As normal user, go to the otwarchive-read-only directory. You should see a file config/database.example, open it with an Editor and save it to config/database.yml. At the top of the file there's a line where you should enter the root password you had to choose when installing MySQL; the line should look something like this:

password: secret

Now you need to create the database schema in the database:

rake1.9.1 db:create:all

(Again, you can omit the version number if your default Ruby version is the right one.)

To start with an empty databse, use

rake db:schema:load

(TODO: Can you still use the seed data?)

To create an admin account, run

script/create_admin.rb

(If you are not using the default Ruby version, you need to edit script/rails beforehand so that the first line points to the right ruby executable:

#!/usr/bin/env ruby1.9.1

)

Starting the archive

Now, still as normal user and in the otwarchive-read-only directory, start the archive

rails server

You should see the following output:

=> Booting WEBrick
=> Rails 3.0.3 application starting in development on http://0.0.0.0:3000
=> Call with -d to detach
=> Ctrl-C to shutdown server
[2010-12-30 12:48:50] INFO  WEBrick 1.3.1
[2010-12-30 12:48:50] INFO  ruby 1.9.2 (2010-08-18) [x86_64-linux]
[2010-12-30 12:48:50] INFO  WEBrick::HTTPServer#start: pid=3789 port=3000

Now open up a browser and visit http://localhost:3000/, you should see the archive's front page! You can login to your new admin account using the URL http://localhost:3000/admin/login. BTW, most of the archive configuration can be found in config/config.yml of which one should make a copy called local.yml, it is quite self-explanatory.

Note that the archive will run in development mode by default. This will give you additional debug information and will cause Rails to reload the source code on every request so that you don't have to restart the archive on code changes. On the downside, it will slow down the archive quite a bit.

If you want to check the mails the archive would send (for example to create new accounts), you can find a copy of each mail in otwarchive-read-only/log/development.log (among lots and lots of other stuff ;-)

If you made it thus far, we would love for you to join us! ;-)

Updating

In the future, the source code will be changed by the developers, and you, of course, want to have those updates, too. Change to the source directory and run the update command to check for new stuff (as normal user):

cd otwarchive-read-only
git pull upstream master

To update your database after you have pulled changes from git, run:

rake1.9.1 db:migrate
rake1.9.1 after 

Appendix: Compiling Ruby

It's preferable to use Ruby packages that come with your Linux distro, but if for some reason those cause problems (too old, bugs, ...), you'll have to compile Ruby yourself.

Download ruby-1.9.2-p0.tar.gz (or whatever the latest version is) from the ruby download page and unpack it:

tar xzfv ruby-1.9.2-p0.tar.gz

Note that Ruby's makefile doesn't come with an uninstall task, so it's not advisable to install Ruby into the default /usr or /usr/local directory, as it would be very hard to remove all Ruby files from there. One possibility is to install it locally into you home directory, which has also the advantage that everything can be done as a normal user (i.e. not as root).

So create a new directory for your final installation (e.g. /home/rebecca/ruby1.9.2-p0), change into the unpacked directory and run configure like this:

./configure --prefix=/home/USERNAME/ruby1.9.2-p0

This ensures that everything (even additional gems) will be installed in the directory you specified, and you can 'uninstall' by simply removing that directory.

Then run

make
make install

If the configure or make command fail, you probably need to install additional packages that are needed to build Ruby. One Debian and Ubuntu, you can run

apt-get build-dep ruby

to install all the packages that are necessary to build your distro's Ruby package, which will most likely also contain the stuff needed for your personal Ruby build. Rerun both make commands.

After the installation has finished, you have to be careful that you use your new installation instead of any previously installed Ruby versions. That means instead of typing ruby, you need to type ~/ruby1.9.2-p0/bin/ruby, instead of gem you need to type ~/ruby1.9.2-p0/bin/gem etc.

To make things a little easier, you can create links in the ~/bin directory, e.g.

ln -s ~/ruby1.9.2-p0/bin/ruby ~/bin/ruby1.9.2
ln -s ~/rake1.9.2-p0/bin/ruby ~/bin/rake1.9.2
ln -s ~/gem1.9.2-p0/bin/ruby ~/bin/gem1.9.2

Now, if you have ~/bin in your $PATH environment variable, you can just type ruby1.9.2 wherever you are, and you can still access your original Ruby installation by just typing ruby.

Now you can proceed with the above installation of the archive software, Rails etc. Just follow the advice about non-default Ruby versions. The executable for rails and bundle will end up in in ~/ruby1.9.2-p0/bin/rails and ~/ruby1.9.2-p0/bin/bundle.