Version at: 07/04/2013, 13:40 vs. version at: 07/04/2013, 13:41
11NOTE: This is about installing the PHP version (i.e. current version) of Tatoeba.
22
33# Downloads
44
55## Required tools
66
77* Apache
88* PHP
99* MySQL
1010* SVN Client
1111
1212For those who are on Windows:
1313
1414* [XAMPP](http://www.apachefriends.org/en/xampp-windows.html) will do the trick for Apache/PHP/MySQL.
1515* [TortoiseSVN](http://tortoisesvn.net/downloads.html) for the SVN client
1616
1717## Source code
1818
1919The source code is hosted on a platform called Assembla:
2020[https://www.assembla.com/code/tatoeba2/subversion/nodes](https://www.assembla.com/code/tatoeba2/subversion/nodes)
2121
2222Repository URL:
2323[https://subversion.assembla.com/svn/tatoeba2/](https://subversion.assembla.com/svn/tatoeba2/)
2424
2525URL you'll want to checkout:
2626[https://subversion.assembla.com/svn/tatoeba2/trunk/](https://subversion.assembla.com/svn/tatoeba2/trunk/)
2727
2828
2929# Configuration
3030
3131## Virtual host
3232
3333You may set up a virtual host. I personally use http://tatoeba.dev/ as my local URL.
3434
3535**TODO** More details on how to do that.
3636
3737
3838## mod_rewrite
3939
4040You need to have mod_rewrite enabled, it's necessary for CakePHP.
4141
4242**TODO** More details on how to do that.
4343
4444
4545## app/core/config.php
4646
4747In the file app/core/config.php, put into comments the part about XCache.
48
4849`/*
4950Cache::config('default', array(
5051    'engine' => 'Xcache', //[required]
5152    'duration'=> 3600, //[optional]
5253    'probability'=> 100, //[optional]
5354    'prefix' => Inflector::slug(APP_DIR) . '_', //[optional] prefix every cache file with this string
5455    'user' => 'user', //user from xcache.admin.user settings
5556 'password' => 'password', //plaintext password (xcache.admin.pass)
5657));
5758 Cache::config('_cake_core_', array(
5859    'engine' => 'Xcache', //[required]
5960    'duration'=> 3600, //[optional]
6061    'probability'=> 100, //[optional]
6162    'prefix' => Inflector::slug(APP_DIR) . '_', //[optional] prefix every cache file with this string
6263    'user' => 'user', //user from xcache.admin.user settings
6364 'password' => 'password', //plaintext password (xcache.admin.pass)
6465));
6566*/`
6667
6768And uncomment the line to use the "File" cache engine:
6869
6970`Cache::config('default', array('engine' => 'File'));`
7071
7172
7273
7374## app/core/database.php
7475
7576In the file app/core/database.php, set your login, password and database in the $default array.
77
7678`
7779var $default = array(
7880    'driver' => 'mysql',
7981    'persistent' => false,
8082    'host' => 'localhost',
8183    'login' => 'root',
8284    'password' => 'somepassword',
8385    'database' => 'tatoeba',
8486    'prefix' => '',
8587    'encoding' => 'utf8'
8688);
8789`
8890
8991## app/models/sentence.php
9092
9193Tatoeba uses some other external tools that you won't necessarily need. These tools are:
9294
9395* the search engine (Sphinx)
9496* the tools for romanization
9597
9698If 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).
9799
98100line 274: uncomment "return array(1)"
99101`public function getSeveralRandomIds($lang = 'und', $numberOfIdWanted = 10)
100102{
101103 // Uncomment the line below if you don't have sphinx installed.
102104 return array(1);`
103105
104106line 847: uncomment "return false"
105107`public function generateMetas(&$sentenceArray)
106108{
107109 // Uncomment the line below you don't have the Chinese
108110 // romanization tools installed.
109111 return false;`
110112    
111113    
112114# Database
113115
114116Now you need to create the database, and import the necessary things.
115117
116118First, 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 tateoba.
117119`CREATE DATABASE tatoeba`
118120`USE tatoeba`
119121
120122Then execute the following scripts.
121123
1221241. This will create all the tables (they will be empty).
123125`\. docs/database/database_20130406.sql`
124126
1251272. These will create a minimal user base (one user in each group), and the associated access rights for each user.
126128`\. docs/database/import/groups.sql
127129\. docs/database/import/users.sql
128130\. docs/database/import/acos.sql
129131\. docs/database/import/aros.sql
130132\. docs/database/import/aros_acos.sql`
131133
1321343. This will import the list of countries. It's used in profile.
133135`\. docs/database/import/countries.sql`
134136
135137**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.
136138
137139
138140# Logging in
139141
140142Now you should be able to go to your local Tatoeba URL (http://tatoeba.dev/ in my case), and be able to log in.
141143
142144The default usernames are:
143145
144146* admin
145147* corpus_maintainer
146148* advanced_contributor
147149* contributor
148150* inactive
149151* spammer
150152
151153The default password for each user is '123456'.
diff view generated by jsdifflib

Version at: 07/04/2013, 13:40

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](http://www.apachefriends.org/en/xampp-windows.html) will do the trick for Apache/PHP/MySQL.
* [TortoiseSVN](http://tortoisesvn.net/downloads.html) for the SVN client

## Source code

The source code is hosted on a platform called Assembla:
[https://www.assembla.com/code/tatoeba2/subversion/nodes](https://www.assembla.com/code/tatoeba2/subversion/nodes)

Repository URL:
[https://subversion.assembla.com/svn/tatoeba2/](https://subversion.assembla.com/svn/tatoeba2/)

URL you'll want to checkout:
[https://subversion.assembla.com/svn/tatoeba2/trunk/](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.

**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/core/config.php

In the file app/core/config.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/core/database.php

In the file app/core/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;`
	
	
# Database

Now you need to create the database, and import the necessary things.

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 tateoba.
`CREATE DATABASE tatoeba`
`USE tatoeba`

Then execute the following scripts.

1. This will create all the tables (they will be empty).
`\. docs/database/database_20130406.sql`

2. 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`

3. This will import the list of countries. It's used in profile.
`\. docs/database/import/countries.sql`

**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'.

version at: 07/04/2013, 13:41

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](http://www.apachefriends.org/en/xampp-windows.html) will do the trick for Apache/PHP/MySQL.
* [TortoiseSVN](http://tortoisesvn.net/downloads.html) for the SVN client

## Source code

The source code is hosted on a platform called Assembla:
[https://www.assembla.com/code/tatoeba2/subversion/nodes](https://www.assembla.com/code/tatoeba2/subversion/nodes)

Repository URL:
[https://subversion.assembla.com/svn/tatoeba2/](https://subversion.assembla.com/svn/tatoeba2/)

URL you'll want to checkout:
[https://subversion.assembla.com/svn/tatoeba2/trunk/](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.

**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/core/config.php

In the file app/core/config.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/core/database.php

In the file app/core/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;`
	
	
# Database

Now you need to create the database, and import the necessary things.

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 tateoba.
`CREATE DATABASE tatoeba`
`USE tatoeba`

Then execute the following scripts.

1. This will create all the tables (they will be empty).
`\. docs/database/database_20130406.sql`

2. 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`

3. This will import the list of countries. It's used in profile.
`\. docs/database/import/countries.sql`

**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'.

Note

The lines in green are the lines that have been added in the new version. The lines in red are those that have been removed.