-
Notifications
You must be signed in to change notification settings - Fork 510
Linux Setup
(Please note: We do not expect all volunteer coders to get through this on their own. We offer a much simpler setup and beginner friendly tutorials for our coders - just [http://transformativeworks.org/contact/volunteers%20and%20recruiting contact us] for help.)
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.
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!
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
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
If you have stuck to default settings, it won't be necessary, but if you run into difficulties you may need to specify the socket in this file as well. 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? rake db:otwseed used to work, but we haven't tried it in a while)
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
)
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! ;-)
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
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
.
If you have any questions regarding code development, please don't hesitate to send an email to [email protected] and we will try to get back to you as soon as possible!
- Home
- Set Up Instructions
- Docker (All platforms)
- Gitpod (Cloud-based development)
- Linux
- OS X
- Creating Development Data
- Writing and Tracking Code
- Automated Testing
- Architecture
-
Getting Started Guide
- Getting Set Up
- Your First Pull Request
- More About Git
- Jira