Notice
This page show a previous version of the articleHow to Install the CakePHP Version of the Tatoeba Web App
NOTE: This is about installing the PHP version (i.e. current version) of Tatoeba.
Downloads
Required tools
- Apache
- PHP
- MySQL
- SVN Client
For those who are on Windows:
- XAMPP will do the trick for Apache/PHP/MySQL.
- TortoiseSVN for the SVN client
For those who are on Macintosh or Linux:
- XAMPP works, too.
Source code
The source code is hosted on a platform called Assembla: https://www.assembla.com/code/tatoeba2/subversion/nodes
Repository URL: https://subversion.assembla.com/svn/tatoeba2/
URL you'll want to checkout: https://subversion.assembla.com/svn/tatoeba2/trunk/
Configuration
Virtual host
You may set up a virtual host. I personally use http://tatoeba.dev/ as my local URL.
To find out how to set up a virtual host on a Macintosh using XAMPP see the following page. http://f6design.com/journal/2012/03/11/configuring-virtualhosts-in-xampp-on-mac/
On Windows 7 using XAMPP: http://austinpassy.com/tutorials/setting-up-virtual-hosts-wordpress-multisite-with-xampp-on-windows-7/
TODO More details on how to do that.
mod_rewrite
You need to have mod_rewrite enabled, it's necessary for CakePHP.
TODO More details on how to do that.
app/config/core.php
In the file app/config/core.php
, put into comments the part about XCache.
/*
Cache::config('default', array(
'engine' => 'Xcache', //[required]
'duration'=> 3600, //[optional]
'probability'=> 100, //[optional]
'prefix' => Inflector::slug(APP_DIR) . '_', //[optional] prefix every cache file with this string
'user' => 'user', //user from xcache.admin.user settings
'password' => 'password', //plaintext password (xcache.admin.pass)
));
Cache::config('_cake_core_', array(
'engine' => 'Xcache', //[required]
'duration'=> 3600, //[optional]
'probability'=> 100, //[optional]
'prefix' => Inflector::slug(APP_DIR) . '_', //[optional] prefix every cache file with this string
'user' => 'user', //user from xcache.admin.user settings
'password' => 'password', //plaintext password (xcache.admin.pass)
));
*/
And uncomment the line to use the "File" cache engine:
Cache::config('default', array('engine' => 'File'));
app/config/database.php
In the file app/config/database.php
, set your login, password and database in the $default array.
var $default = array(
'driver' => 'mysql',
'persistent' => false,
'host' => 'localhost',
'login' => 'root',
'password' => 'somepassword',
'database' => 'tatoeba',
'prefix' => '',
'encoding' => 'utf8'
);
app/models/sentence.php
Tatoeba uses some other external tools that you won't necessarily need. These tools are:
- the search engine (Sphinx)
- the tools for romanization
If you're not going to work on the search or on the romanization and don't want to install these tools, you will have to uncomment a few things in the Sentence model (app/models/sentence.php
).
line 274: uncomment "return array(1)"
public function getSeveralRandomIds($lang = 'und', $numberOfIdWanted = 10)
{
// Uncomment the line below if you don't have sphinx installed.
return array(1);`
line 847: uncomment "return false"
public function generateMetas(&$sentenceArray)
{
// Uncomment the line below you don't have the Chinese
// romanization tools installed.
return false;`
Make the following directory writable.
/app/tmp/cache/
For XAMPP (at least on a Mac)
You'll need to up the default thread_stack from 64K to 256K. (I tried 128K, but that wasn't enough.)
/Applications/XAMPP/xamppfiles/etc/my.cnf
thread_stack = 256K
Database
Now you need to create the database, and import the necessary things. The scripts you will need are in the docs/database
folder.
First, create the database. Make sure the name you use here is the name you've set in app/core/database.php. I'll name it tatoeba
.
CREATE DATABASE tatoeba
USE tatoeba
Then execute the following scripts.
This will create all the tables (they will be empty).
\. docs/database/database_20130406.sql
These will create a minimal user base (one user in each group), and the associated access rights for each user.
\. docs/database/import/groups.sql \. docs/database/import/users.sql \. docs/database/import/acos.sql \. docs/database/import/aros.sql \. docs/database/import/aros_acos.sql
This will import the list of countries. It's used in profile.
\. docs/database/import/countries.sql
After you start adding sentences, you will get some errors related to the fact that the table langStats is empty. This table contains lists the different languages in which the sentences are and the number of sentences for each language. So after adding your first sentences, and also everytime you will add sentences in a language that wasn't present before, you will need to execute the following script to update the langStats table:
\. docs/database/scripts/create_fill_langStats.sql
You can fill your database with the exported CSV files. For example, adapt and use the following commands to add sentences:
cat sentences.csv | while read -r id lang text; do echo "insert into sentences (id, lang, text) values ('$id', '$lang', '${text//\'/\'}');"; done | sudo mysql -u root tatoeba_database
cat links.csv | while read -r id1 id2; do echo "insert into sentences_translations (sentence_id, translation_id) values ($id1, $id2);"; done | sudo mysql -u root tatoeba_database
Expect this to take some time (dozens of minutes) and fill some disk space (several gigabytes).
TODO Would probably be nice to have some data for sentences, comments, wall messages as well. Although they can be created manually once logged in.
Logging in
Now you should be able to go to your local Tatoeba URL (http://tatoeba.dev/ in my case), and be able to log in.
The default usernames are:
- admin
- corpus_maintainer
- advanced_contributor
- contributor
- inactive
- spammer
The default password for each user is '123456'.