From 1aec298314454b67fbc18738c3ffa6f12a14dd59 Mon Sep 17 00:00:00 2001 From: Dries Buytaert Date: Mon, 27 Jul 2009 19:42:56 +0000 Subject: - Patch #349508 by Josh Waihi: make sure that the database is installed using UTF-8 on PostgreSQL. --- includes/database/pgsql/install.inc | 33 ++++++++++++++++++++++++++++++++- 1 file changed, 32 insertions(+), 1 deletion(-) (limited to 'includes/database/pgsql') diff --git a/includes/database/pgsql/install.inc b/includes/database/pgsql/install.inc index b301cb672..222d7e734 100644 --- a/includes/database/pgsql/install.inc +++ b/includes/database/pgsql/install.inc @@ -9,10 +9,41 @@ // PostgreSQL specific install functions -class DatabaseInstaller_pgsql extends DatabaseInstaller { +class DatabaseTasks_pgsql extends DatabaseTasks { protected $pdoDriver = 'pgsql'; + + public function __construct() { + $this->tasks[] = array( + 'function' => 'checkEncoding', + 'arguments' => array(), + ); + } + public function name() { return 'PostgreSQL'; } + + /** + * Check encoding is UTF8. + */ + protected function checkEncoding() { + try { + if (db_query('SHOW server_encoding')->fetchField() == 'UTF8') { + $this->pass(st('Database is encoded in UTF-8')); + } + else { + $replacements = array( + '%encoding' => 'UTF8', + '%driver' => $this->name(), + '!link' => 'INSTALL.pgsql.txt' + ); + $text = 'The %driver database must use %encoding encoding to work with Drupal.'; + $text .= 'Please recreate the database with %encoding encoding. See !link for more details.'; + $this->fail(st($text, $replacements)); + } + } catch (Exception $e) { + $this->fail(st('Drupal could not determine the encoding of the database was set to UTF-8')); + } + } } -- cgit v1.2.3