Blame | Letzte Änderung | Log anzeigen | RSS feed
<?php/*** sfMessageSource_MySQL class file.** This program is free software; you can redistribute it and/or modify* it under the terms of the BSD License.** Copyright(c) 2004 by Qiang Xue. All rights reserved.** To contact the author write to {@link mailto:qiang.xue@gmail.com Qiang Xue}* The latest version of PRADO can be obtained from:* {@link http://prado.sourceforge.net/}** @author Wei Zhuo <weizhuo[at]gmail[dot]com>* @version $Id: sfMessageSource_MySQL.class.php 23810 2009-11-12 11:07:44Z Kris.Wallsmith $* @package symfony* @subpackage i18n*//*** sfMessageSource_MySQL class.** Retrieve the message translation from a MySQL database.** See the MessageSource::factory() method to instantiate this class.** MySQL schema:** CREATE TABLE `catalogue` (* `cat_id` int(11) NOT NULL auto_increment,* `name` varchar(100) NOT NULL default '',* `source_lang` varchar(100) NOT NULL default '',* `target_lang` varchar(100) NOT NULL default '',* `date_created` int(11) NOT NULL default '0',* `date_modified` int(11) NOT NULL default '0',* `author` varchar(255) NOT NULL default '',* PRIMARY KEY (`cat_id`)* ) TYPE=InnoDB;** CREATE TABLE `trans_unit` (* `msg_id` int(11) NOT NULL auto_increment,* `cat_id` int(11) NOT NULL default '1',* `id` varchar(255) NOT NULL default '',* `source` text NOT NULL,* `target` text NOT NULL,* `comments` text NOT NULL,* `date_added` int(11) NOT NULL default '0',* `date_modified` int(11) NOT NULL default '0',* `author` varchar(255) NOT NULL default '',* `translated` tinyint(1) NOT NULL default '0',* PRIMARY KEY (`msg_id`)* ) TYPE=InnoDB;** Propel schema (in .xml format):** <database ...>* ...* <table name="catalogue">* <column name="cat_id" type="integer" required="true" primaryKey="true" autoincrement="true" />* <column name="name" type="varchar" size="100" />* <column name="source_lang" type="varchar" size="100" />* <column name="target_lang" type="varchar" size="100" />* <column name="date_created" type="timestamp" />* <column name="date_modified" type="timestamp" />* <column name="author" type="varchar" size="255" />* </table>** <table name="trans_unit">* <column name="msg_id" type="integer" required="true" primaryKey="true" autoincrement="true" />* <column name="cat_id" type="integer" />* <foreign-key foreignTable="catalogue" onDelete="cascade">* <reference local="cat_id" foreign="cat_id"/>* </foreign-key>* <column name="id" type="varchar" size="255" />* <column name="source" type="longvarchar" />* <column name="target" type="longvarchar" />* <column name="comments" type="longvarchar" />* <column name="date_created" type="timestamp" />* <column name="date_modified" type="timestamp" />* <column name="author" type="varchar" size="255" />* <column name="translated" type="integer" />* </table>* ...* </database>** @author Xiang Wei Zhuo <weizhuo[at]gmail[dot]com>* @version v1.0, last update on Fri Dec 24 16:58:58 EST 2004* @package symfony* @subpackage i18n*/class sfMessageSource_MySQL extends sfMessageSource_Database{/*** The datasource string, full DSN to the database.* @var string*/protected $source;/*** The DSN array property, parsed by PEAR's DB DSN parser.* @var array*/protected $dsn;/*** A resource link to the database* @var db*/protected $db;/*** Constructor.* Creates a new message source using MySQL.** @param string $source MySQL datasource, in PEAR's DB DSN format.* @see MessageSource::factory();*/function __construct($source){$this->source = (string) $source;$this->dsn = $this->parseDSN($this->source);$this->db = $this->connect();}/*** Destructor, closes the database connection.*/function __destruct(){@mysql_close($this->db);}/*** Connects to the MySQL datasource** @return resource MySQL connection.* @throws sfException, connection and database errors.*/protected function connect(){$dsninfo = $this->dsn;if (isset($dsninfo['protocol']) && $dsninfo['protocol'] == 'unix'){$dbhost = ':'.$dsninfo['socket'];}else{$dbhost = $dsninfo['hostspec'] ? $dsninfo['hostspec'] : 'localhost';if (!empty($dsninfo['port'])){$dbhost .= ':'.$dsninfo['port'];}}$user = $dsninfo['username'];$pw = $dsninfo['password'];$connect_function = 'mysql_connect';if (!function_exists($connect_function)){throw new RuntimeException('The function mysql_connect() does not exist. Please confirm MySQL is enabled in php.ini');}if ($dbhost && $user && $pw){$conn = @$connect_function($dbhost, $user, $pw);}elseif ($dbhost && $user){$conn = @$connect_function($dbhost, $user);}elseif ($dbhost){$conn = @$connect_function($dbhost);}else{$conn = false;}if (empty($conn)){throw new sfException(sprintf('Error in connecting to %s.', $dsninfo));}if ($dsninfo['database']){if (!@mysql_select_db($dsninfo['database'], $conn)){throw new sfException(sprintf('Error in connecting database, dsn: %s.', $dsninfo));}}else{throw new sfException('Please provide a database for message translation.');}return $conn;}/*** Gets the database connection.** @return db database connection.*/public function connection(){return $this->db;}/*** Gets an array of messages for a particular catalogue and cultural variant.** @param string $variant the catalogue name + variant* @return array translation messages.*/public function &loadData($variant){$variant = mysql_real_escape_string($variant, $this->db);$statement ="SELECT t.id, t.source, t.target, t.commentsFROM trans_unit t, catalogue cWHERE c.cat_id = t.cat_idAND c.name = '{$variant}'ORDER BY id ASC";$rs = mysql_query($statement, $this->db);$result = array();while ($row = mysql_fetch_array($rs, MYSQL_NUM)){$source = $row[1];$result[$source][] = $row[2]; //target$result[$source][] = $row[0]; //id$result[$source][] = $row[3]; //comments}return $result;}/*** Gets the last modified unix-time for this particular catalogue+variant.* We need to query the database to get the date_modified.** @param string $source catalogue+variant* @return int last modified in unix-time format.*/protected function getLastModified($source){$source = mysql_real_escape_string($source, $this->db);$rs = mysql_query("SELECT date_modified FROM catalogue WHERE name = '{$source}'", $this->db);$result = $rs ? intval(mysql_result($rs, 0)) : 0;return $result;}/*** Checks if a particular catalogue+variant exists in the database.** @param string $variant catalogue+variant* @return boolean true if the catalogue+variant is in the database, false otherwise.*/public function isValidSource($variant){$variant = mysql_real_escape_string ($variant, $this->db);$rs = mysql_query("SELECT COUNT(*) FROM catalogue WHERE name = '{$variant}'", $this->db);$row = mysql_fetch_array($rs, MYSQL_NUM);$result = $row && $row[0] == '1';return $result;}/*** Retrieves catalogue details, array($cat_id, $variant, $count).** @param string $catalogue catalogue* @return array catalogue details, array($cat_id, $variant, $count).*/protected function getCatalogueDetails($catalogue = 'messages'){if (empty($catalogue)){$catalogue = 'messages';}$variant = $catalogue.'.'.$this->culture;$name = mysql_real_escape_string($this->getSource($variant), $this->db);$rs = mysql_query("SELECT cat_id FROM catalogue WHERE name = '{$name}'", $this->db);if (mysql_num_rows($rs) != 1){return false;}$cat_id = intval(mysql_result($rs, 0));// first get the catalogue ID$rs = mysql_query("SELECT COUNT(*) FROM trans_unit WHERE cat_id = {$cat_id}", $this->db);$count = intval(mysql_result($rs, 0));return array($cat_id, $variant, $count);}/*** Updates the catalogue last modified time.** @return boolean true if updated, false otherwise.*/protected function updateCatalogueTime($cat_id, $variant){$time = time();$result = mysql_query("UPDATE catalogue SET date_modified = {$time} WHERE cat_id = {$cat_id}", $this->db);if ($this->cache){$this->cache->remove($variant.':'.$this->culture);}return $result;}/*** Saves the list of untranslated blocks to the translation source.* If the translation was not found, you should add those* strings to the translation source via the <b>append()</b> method.** @param string $catalogue the catalogue to add to* @return boolean true if saved successfuly, false otherwise.*/function save($catalogue = 'messages'){$messages = $this->untranslated;if (count($messages) <= 0){return false;}$details = $this->getCatalogueDetails($catalogue);if ($details){list($cat_id, $variant, $count) = $details;}else{return false;}if ($cat_id <= 0){return false;}$inserted = 0;$time = time();foreach ($messages as $message){$count++;$inserted++;$message = mysql_real_escape_string($message, $this->db);$statement = "INSERT INTO trans_unit(cat_id,id,source,date_added) VALUES({$cat_id}, {$count},'{$message}',$time)";mysql_query($statement, $this->db);}if ($inserted > 0){$this->updateCatalogueTime($cat_id, $variant);}return $inserted > 0;}/*** Deletes a particular message from the specified catalogue.** @param string $message the source message to delete.* @param string $catalogue the catalogue to delete from.* @return boolean true if deleted, false otherwise.*/function delete($message, $catalogue = 'messages'){$details = $this->getCatalogueDetails($catalogue);if ($details){list($cat_id, $variant, $count) = $details;}else{return false;}$text = mysql_real_escape_string($message, $this->db);$statement = "DELETE FROM trans_unit WHERE cat_id = {$cat_id} AND source = '{$message}'";$deleted = false;mysql_query($statement, $this->db);if (mysql_affected_rows($this->db) == 1){$deleted = $this->updateCatalogueTime($cat_id, $variant);}return $deleted;}/*** Updates the translation.** @param string $text the source string.* @param string $target the new translation string.* @param string $comments comments* @param string $catalogue the catalogue of the translation.* @return boolean true if translation was updated, false otherwise.*/function update($text, $target, $comments, $catalogue = 'messages'){$details = $this->getCatalogueDetails($catalogue);if ($details){list($cat_id, $variant, $count) = $details;}else{return false;}$comments = mysql_real_escape_string($comments, $this->db);$target = mysql_real_escape_string($target, $this->db);$text = mysql_real_escape_string($text, $this->db);$time = time();$statement = "UPDATE trans_unit SET target = '{$target}', comments = '{$comments}', date_modified = '{$time}' WHERE cat_id = {$cat_id} AND source = '{$text}'";$updated = false;mysql_query($statement, $this->db);if (mysql_affected_rows($this->db) == 1){$updated = $this->updateCatalogueTime($cat_id, $variant);}return $updated;}/*** Returns a list of catalogue as key and all it variants as value.** @return array list of catalogues*/function catalogues(){$statement = 'SELECT name FROM catalogue ORDER BY name';$rs = mysql_query($statement, $this->db);$result = array();while($row = mysql_fetch_array($rs, MYSQL_NUM)){$details = explode('.', $row[0]);if (!isset($details[1])){$details[1] = null;}$result[] = $details;}return $result;}}