Exemple #1
0
 public function testAutomaticaly()
 {
     I18n::SetDefault("en");
     I18n::load("en");
     $res = I18n::get_answer_from_google("Bienvenue, veuillez vous identifier\nContacter le créateur de l'application", "fr");
     $this->assertEquals($res[0], "Welcome, please log");
     $this->assertEquals($res[1], "Contact the creator of the application");
 }
Exemple #2
0
 function __($text, $lgfrom = "auto")
 {
     //return $text;
     if ($lgfrom === "auto") {
         $lgfrom = I18n::GetDefault();
     }
     $calledFrom = debug_backtrace();
     //return "<span id=\"".sha1($text)."\" lang=\"".$_LG->Get()."\">".$_LG->_($text,$lgfrom,$calledFrom[0]['file'],$calledFrom[0]['line'])."</span>";
     $file = str_replace(ROOT . "/", '', $calledFrom[0]['file']);
     $var = I18n::_($text, $lgfrom, $file, $calledFrom[0]['line']);
     //debug(I18n::$_translations);
     if (preg_match_all('#\\[(\\w+)]#', $var, $m)) {
         //print_r( $m );
     }
     if (count($m[1]) > 0) {
         $replace_with = array();
         foreach ($m[1] as $species) {
             $scientific_name = str_replace("_", " ", $species);
             $sql = "SELECT b.text \r\n\t\t\t\tFROM species_main a\r\n\t\t\t\tinner JOIN scientific_name_translation b ON a.id = b.id_species_main AND b.id_species_sub = 0 and b.is_valid=1\r\n\t\t\t\tINNER JOIN language c ON c.iso3 = b.language AND c.iso = '" . I18n::Get() . "'\r\n\t\t\twhere a.scientific_name ='" . $scientific_name . "'";
             $res = I18n::getDb()->sql(I18n::DATABASE)->sql_query($sql);
             if (I18n::getDb()->sql(I18n::DATABASE)->sql_num_rows($res) == 1) {
                 $ob = I18n::getDb()->sql(I18n::DATABASE)->sql_fetch_object($res);
                 $replace_with[] = $ob->text . " (" . $scientific_name . ")";
             } else {
                 $replace_with[] = $scientific_name;
             }
         }
         $var = str_replace($m[0], $replace_with, $var);
     }
     return $var;
 }
 function stop($param)
 {
     $id_daemon = $param[0];
     $id_daemon = 1;
     $db = $this->di['db']->sql(DB_DEFAULT);
     $this->view = false;
     $this->layout_name = false;
     $sql = "SELECT * FROM daemon_main where id ='" . $id_daemon . "'";
     $res = $db->sql_query($sql);
     if ($db->sql_num_rows($res) !== 1) {
         $msg = I18n::getTranslation(__("Impossible to find the daemon with the id : ") . "'" . $id_daemon . "'");
         $title = I18n::getTranslation(__("Error"));
         set_flash("error", $title, $msg);
         header("location: " . LINK . $this->url);
         exit;
     }
     $ob = $db->sql_fetch_object($res);
     if ($this->isRunning($ob->pid)) {
         $msg = I18n::getTranslation(__("The daemon with pid : '" . $ob->pid . "' successfully stopped "));
         $title = I18n::getTranslation(__("Success"));
         set_flash("success", $title, $msg);
         $cmd = "kill " . $ob->pid;
         shell_exec($cmd);
         //shell_exec("echo '[" . date("Y-m-d H:i:s") . "] DAEMON STOPPED !' >> " . $ob->log_file);
         $this->logger->info(Color::getColoredString('Stopped daemon with the pid : ' . $ob->pid, "white", "red"));
     } else {
         if (!empty($pid)) {
             $this->logger->info(Color::getColoredString('Impossible to find the daemon with the pid : ' . $pid, "yellow"));
         }
         $msg = I18n::getTranslation(__("Impossible to find the daemon with the pid : ") . "'" . $ob->pid . "'");
         $title = I18n::getTranslation(__("Daemon was already stopped or in error"));
         set_flash("caution", $title, $msg);
     }
     sleep(1);
     if (!$this->isRunning($ob->pid)) {
         $sql = "UPDATE daemon_main SET pid ='0' WHERE id = '" . $id_daemon . "'";
         $db->sql_query($sql);
     } else {
         $this->logger->info(Color::getColoredString('Impossible to stop daemon with pid : ' . $pid, "white", "red"));
         throw new Exception('PMACTRL-876 : Impossible to stop daemon with pid : "' . $ob->pid . '"');
     }
     header("location: " . LINK . $this->url);
 }
 function stop($param)
 {
     $id_cleaner = $param[0];
     $db = $this->di['db']->sql(DB_DEFAULT);
     $this->view = false;
     $this->layout_name = false;
     $sql = "SELECT * FROM cleaner_main where id ='" . $id_cleaner . "'";
     $res = $db->sql_query($sql);
     if ($db->sql_num_rows($res) !== 1) {
         $msg = I18n::getTranslation(__("Impossible to find the cleaner with the id : ") . "'" . $id_cleaner . "'");
         $title = I18n::getTranslation(__("Error"));
         set_flash("error", $title, $msg);
         header("location: " . LINK . "cleaner/index");
         exit;
     }
     $ob = $db->sql_fetch_object($res);
     if ($this->isRunning($ob->pid)) {
         $msg = I18n::getTranslation(__("The cleaner with pid : '" . $ob->pid . "' successfully stopped "));
         $title = I18n::getTranslation(__("Success"));
         set_flash("success", $title, $msg);
         $cmd = "kill " . $ob->pid;
         shell_exec($cmd);
         shell_exec("echo '[" . date("Y-m-d H:i:s") . "] CLEANER STOPED !' >> " . $ob->log_file);
     } else {
         $msg = I18n::getTranslation(__("Impossible to find the cleaner with the pid : ") . "'" . $ob->pid . "'");
         $title = I18n::getTranslation(__("Cleaner was already stopped or in error"));
         set_flash("caution", $title, $msg);
     }
     sleep(1);
     if (!$this->isRunning($ob->pid)) {
         $sql = "UPDATE cleaner_main SET pid ='0' WHERE id = '" . $id_cleaner . "'";
         $db->sql_query($sql);
     } else {
         throw new Exception('PMACTRL-875 : Impossible to stop cleaner with pid : "' . $ob->pid . '"');
     }
     header("location: " . LINK . "cleaner/index");
 }
Exemple #5
0
<?php

use Glial\I18n\I18n;
use Glial\Synapse\FactoryController;
echo "<!DOCTYPE html>\n";
echo "<html lang=\"" . I18n::Get() . "\">";
echo "<head>\n";
echo "<!--\n";
echo SITE_LOGO;
echo "Powered by Esysteme (www.esysteme.com)\n";
echo "-->";
echo "<meta charset=utf-8 />\n";
echo "<meta name=\"Keywords\" content=\"\" />\n";
echo "<meta name=\"Description\" content=\"\" />\n";
echo "<meta name=\"Author\" content=\"Aurelien LEQUOY\" />\n";
echo "<meta name=\"robots\" content=\"index,follow,all\" />\n";
echo "<meta name=\"generator\" content=\"GLIALE 1.1\" />\n";
echo "<meta name=\"runtime\" content=\"[PAGE_GENERATION]\" />\n";
echo "<link rel=\"shortcut icon\" href=\"favicon.ico\" />";
echo "<title>" . strip_tags($GLIALE_TITLE) . " - " . SITE_NAME . " " . SITE_VERSION . "</title>\n";
?>
<link href="" rel="icon" type="image/x-icon">
<link rel="stylesheet" type="text/css" href="<?php 
echo CSS;
?>
bootstrap.css">
<link rel="stylesheet" type="text/css" href="<?php 
echo CSS;
?>
autocomplete.css" />
<link rel="stylesheet" type="text/css" href="<?php 
Exemple #6
0
 public function authenticate($check_post = true)
 {
     if ($_SERVER['REQUEST_METHOD'] == "POST" && $check_post) {
         if (empty($_POST[self::$_tableName][self::$_login])) {
             return false;
         }
         if (empty($_POST[self::$_tableName][self::$_passwd])) {
             return false;
         }
         if (empty($_POST[self::$_tableName][self::$_login]) || empty($_POST[self::$_tableName][self::$_passwd])) {
             return true;
         }
         $Identity = self::$_dbLink->sql_real_escape_string($_POST[self::$_tableName][self::$_login]);
         $Credential = self::$_dbLink->sql_real_escape_string($_POST[self::$_tableName][self::$_passwd]);
         $hash_password = $this->hash_password($Identity, $Credential);
         if (LDAP_CHECK) {
             if ($ldap = $this->checkLdap($Identity, $Credential)) {
                 $sql = "select * from " . self::$_tableName . " where " . self::$_login . " = '" . $Identity . "'";
                 $res = self::$_dbLink->sql_query($sql);
                 $data = array();
                 if (self::$_dbLink->sql_num_rows($res) === 1) {
                     $ob = self::$_dbLink->sql_fetch_object($res);
                     $this->_user = $ob;
                     $data[self::$_tableName]['id'] = $ob->id;
                     $data[self::$_tableName][self::$_passwd] = $hash_password;
                     $data[self::$_tableName]['date_last_login'] = date('Y-m-d H:i:s');
                     $data[self::$_tableName]['date_last_connected'] = date('Y-m-d H:i:s');
                 } elseif (self::$_dbLink->sql_num_rows($res) === 0) {
                     $data[self::$_tableName]['date_last_login'] = date('Y-m-d H:i:s');
                     $data[self::$_tableName]['date_last_connected'] = date('Y-m-d H:i:s');
                     $data[self::$_tableName][self::$_passwd] = $hash_password;
                     $data[self::$_tableName][self::$_login] = $ldap['samaccountname'][0];
                     $data[self::$_tableName]['email'] = $ldap['mail'][0];
                     $data[self::$_tableName]['name'] = strtoupper($ldap['sn'][0]);
                     $data[self::$_tableName]['firstname'] = $ldap['givenname'][0];
                     $data[self::$_tableName]['ip'] = $_SERVER["REMOTE_ADDR"];
                     $data[self::$_tableName]['date_created'] = substr($ldap['whencreated'][0], 0, 4) . "-" . substr($ldap['whencreated'][0], 4, 2) . "-" . substr($ldap['whencreated'][0], 6, 2) . " " . substr($ldap['whencreated'][0], 8, 2) . ":" . substr($ldap['whencreated'][0], 10, 2) . ":" . substr($ldap['whencreated'][0], 12, 2);
                     $data[self::$_tableName]['id_group'] = 2;
                     $data[self::$_tableName]['is_valid'] = 0;
                 } else {
                     throw new \Exception('GLI-999 : Whilte list failed');
                 }
                 if (!self::$_dbLink->sql_save($data)) {
                     debug($data);
                     debug(self::$_dbLink->sql_error());
                     die;
                 }
                 $sql = "select * from " . self::$_tableName . " where " . self::$_login . " = '" . self::$_dbLink->sql_real_escape_string($ldap['samaccountname'][0]) . "'";
                 $res = self::$_dbLink->sql_query($sql);
                 $ob = self::$_dbLink->sql_fetch_object($res);
                 $this->_user = $ob;
                 $this->id_user = $ob->id;
                 setcookie(self::$_name_cookie_login, $ob->{self::$_login}, time() + AUTH_SESSION_TIME, '/', $_SERVER['SERVER_NAME'], false, true);
                 setcookie(self::$_name_cookie_passwd, $hash_password, time() + AUTH_SESSION_TIME, '/', $_SERVER['SERVER_NAME'], false, true);
                 return true;
             }
             return false;
         } else {
             $sql = "select * from " . self::$_tableName . " where " . self::$_login . " = '" . $Identity . "'";
             $res = self::$_dbLink->sql_query($sql);
             if (self::$_dbLink->sql_num_rows($res) === 1) {
                 $ob = self::$_dbLink->sql_fetch_object($res);
                 $this->id_user = $ob->id;
                 if ($hash_password === $ob->{self::$_passwd}) {
                     $this->_user = $ob;
                     setcookie(self::$_name_cookie_login, $ob->{self::$_login}, time() + AUTH_SESSION_TIME, '/', $_SERVER['SERVER_NAME'], false, true);
                     setcookie(self::$_name_cookie_passwd, $hash_password, time() + AUTH_SESSION_TIME, '/', $_SERVER['SERVER_NAME'], false, true);
                     return true;
                 }
             }
         }
     }
     if (empty($_POST[self::$_tableName][self::$_login])) {
         if (!empty($_COOKIE[self::$_name_cookie_login]) && !empty($_COOKIE[self::$_name_cookie_passwd])) {
             $sql = "select * from " . self::$_tableName . " where " . self::$_login . " = '" . self::$_dbLink->sql_real_escape_string($_COOKIE[self::$_name_cookie_login]) . "'";
             $res = self::$_dbLink->sql_query($sql);
             if (self::$_dbLink->sql_num_rows($res) === 1) {
                 $ob = self::$_dbLink->sql_fetch_object($res);
                 if ($_COOKIE[self::$_name_cookie_passwd] === $ob->{self::$_passwd}) {
                     //if (password_verify($ob->{self::$_passwd}, $_COOKIE[self::$_name_cookie_passwd]) ) {
                     $this->_user = $ob;
                     if ($ob->is_valid == 0) {
                         if ($_SERVER['REQUEST_METHOD'] === "GET") {
                             $msg = I18n::getTranslation(__("Hello,") . "<br />" . __("Thank you for registering.") . "<br />" . __("To finalise your registration, an administrator have to give you a role."));
                             $title = I18n::getTranslation(__("Restricted access"));
                             set_flash("caution", $title, $msg);
                         }
                     }
                     return true;
                 }
             }
         }
     }
     return false;
 }
Exemple #7
0
 function index()
 {
     //remove view
     $this->view = false;
     //to make sexy install ?
     //header
     echo PHP_EOL . Glial::header() . PHP_EOL;
     //		ini_set('display_errors', '0');
     $drivers = $this->testDatabases();
     ini_set('display_errors', '1');
     $map_driver_with_ext = array("mysql" => "mysqli", "pgsql" => "pgsql", "sybase" => "sybase", "oracle" => "oci8");
     $ext = array();
     foreach ($drivers as $driver) {
         $ext[] = $map_driver_with_ext[$driver];
     }
     $this->testPhpComponent($ext);
     //making tree directory
     $fct = function ($msg) {
         $dirs = array("data", "data/img", "documentation", "tmp/crop", "tmp/documentation", "application/webroot/js", "application/webroot/css", "application/webroot/file", "application/webroot/video", "application/webroot/image");
         $error = array();
         foreach ($dirs as $dir) {
             $dir = $_SERVER['PWD'] . "/" . $dir;
             if (!file_exists($dir)) {
                 if (!mkdir($dir)) {
                     echo $this->out("Impossible to create this directory : " . $dir . " ", "KO");
                 }
             }
         }
         return array(true, $msg);
     };
     $this->anonymous($fct, "Making tree directory");
     // replace and install lastest jQuery
     $fct = function ($msg) {
         $name = "jquery-latest.min.js";
         $jQuery = $_SERVER['PWD'] . "/application/webroot/js/" . $name;
         $old_version = "";
         if (file_exists($jQuery)) {
             $data = file_get_contents($jQuery);
             preg_match("/v[\\d]+\\.[\\d]+\\.[\\d]+/", $data, $version);
             $old_version = $version[0] . " => ";
             $this->cmd("rm " . $jQuery, "Delete old jQuery");
         }
         $this->cmd("cd " . $_SERVER['PWD'] . "/application/webroot/js && wget -q http://code.jquery.com/" . $name, "Download lastest jQuery");
         if (file_exists($jQuery)) {
             $data = file_get_contents($jQuery);
             preg_match("/v[\\d]+\\.[\\d]+\\.[\\d]+/", $data, $version);
             $msg = sprintf($msg, $old_version . Color::getColoredString($version[0], "green"));
             return array(true, $msg);
         } else {
             $msg = sprintf($msg, "NOT INSTALLED");
             return array(false, $msg);
         }
     };
     $this->anonymous($fct, "jQuery installed (%s)");
     //$this->cmd("chown www-data:www-data -R *", "Setting right to www-data:www-data");
     $this->cmd("php glial administration admin_index_unique", "Generating DDL cash for index");
     $this->cmd("php glial administration admin_table", "Generating DDL cash for databases");
     $this->cmd("php glial administration generate_model", "Making model with reverse engineering of databases");
     $fct = function ($msg) {
         $file = $_SERVER['PWD'] . "/glial";
         $data = file_get_contents($file);
         $new_data = str_replace("php application", "php " . $_SERVER['PWD'] . "/application", $data);
         if (!file_put_contents($file, $new_data)) {
             return array(false, $msg);
         }
         return array(true, $msg);
     };
     $this->anonymous($fct, "Replace relative path by full path in Glial exec");
     $fct = function ($msg) {
         $file = $_SERVER['PWD'] . "/glial";
         $path_to_php = exec("which php", $res, $code);
         if ($code !== 0) {
             return array(false, $msg . " {$code}:{$path_to_php}: can't find php");
         }
         $data = file($file);
         $data[0] = "#!" . $path_to_php . PHP_EOL;
         file_put_contents($file, implode("", $data));
         return array(true, $msg);
     };
     $this->anonymous($fct, "get full path of php");
     $this->cmd("chmod +x glial", "Setting chmod +x to executable 'glial'");
     $this->cmd("cp -a glial /usr/local/bin/glial", "Copy glial to /usr/local/bin/");
     \Glial\I18n\I18n::install();
     // \Glial\I18n\I18n::unInstall();
     /*
               shell_exec("find " . $_SERVER['PWD'] . " -type f -exec chmod 740 {} \;;");
               echo $this->out("Setting chmod 440 to all files", "OK");
      shell_exec("find " . $_SERVER['PWD'] . " -type d -exec chmod 750 {} \;;");
               echo $this->out("Setting chmod 550 to all files", "OK");
     
      shell_exec("find " . $_SERVER['PWD'] . "/tmp -type f -exec chmod 770 {} \;;");
               echo $this->out("Setting chmod 660 to all files of /tmp", "OK");
      shell_exec("find " . $_SERVER['PWD'] . "/tmp -type d -exec chmod 770 {} \;;");
               echo $this->out("Setting chmod 660 to all directory of /tmp", "OK");
     */
     //echo $this->di['acl'];
     //echo $this->di['db'];
 }
 function index($params)
 {
     /*
      * SHOW TABLES
      * SHOW COLUMNS FROM table_name
      *
      */
     $this->layout_name = 'pmacontrol';
     $db = $this->di['db']->sql(DB_DEFAULT);
     $this->db_default = $db;
     $this->title = __("Compare");
     $this->ariane = "> " . '<a href="' . LINK . 'Plugins/index/">' . __('Plugins') . "</a> > " . $this->title;
     $redirect = false;
     if ($_SERVER['REQUEST_METHOD'] == "POST") {
         $id_server1 = empty($_POST['compare_main']['id_mysql_server__original']) ? "" : $_POST['compare_main']['id_mysql_server__original'];
         $id_server2 = empty($_POST['compare_main']['id_mysql_server__compare']) ? "" : $_POST['compare_main']['id_mysql_server__compare'];
         $db1 = empty($_POST['compare_main']['database__original']) ? "" : $_POST['compare_main']['database__original'];
         $db2 = empty($_POST['compare_main']['database__compare']) ? "" : $_POST['compare_main']['database__compare'];
         $out = $this->checkConfig($id_server1, $db1, $id_server2, $db2);
         if ($out !== true) {
             $extra = "";
             foreach ($out as $msg) {
                 $extra .= "<br />" . __($msg);
             }
             $msg = I18n::getTranslation(__("Please correct your paramaters !") . $extra);
             $title = I18n::getTranslation(__("Error"));
             set_flash("error", $title, $msg);
             $redirect = true;
         }
         header('location: ' . LINK . 'compare/index/compare_main:id_mysql_server__original:' . $id_server1 . '/compare_main:' . 'id_mysql_server__compare:' . $id_server2 . '/compare_main:' . 'database__original:' . $db1 . '/compare_main:' . 'database__compare:' . $db2);
     }
     $this->di['js']->addJavascript(array("jquery-latest.min.js", "jquery.browser.min.js", "jquery.autocomplete.min.js", "compare/index.js"));
     $sql = "SELECT * FROM mysql_server WHERE `error` = '' order by `name`";
     $servers = $db->sql_fetch_yield($sql);
     $data['server'] = [];
     foreach ($servers as $server) {
         $tmp = [];
         $tmp['id'] = $server['id'];
         $tmp['libelle'] = str_replace('_', '-', $server['name']) . " (" . $server['ip'] . ")";
         $data['server'][] = $tmp;
     }
     $data['listdb1'] = array();
     if (!empty($_GET['compare_main']['id_mysql_server__original'])) {
         $select1 = $this->getDatabaseByServer(array($_GET['compare_main']['id_mysql_server__original']));
         $data['listdb1'] = $select1['databases'];
     }
     $data['listdb2'] = array();
     if (!empty($_GET['compare_main']['id_mysql_server__compare'])) {
         $select1 = $this->getDatabaseByServer(array($_GET['compare_main']['id_mysql_server__compare']));
         $data['listdb2'] = $select1['databases'];
     }
     $data['display'] = false;
     if (count($data['listdb2']) != 0 && count($data['listdb1']) != 0) {
         if (!empty($_GET['compare_main']['database__original']) && !empty($_GET['compare_main']['database__compare'])) {
             $data['resultat'] = $this->analyse($_GET['compare_main']['id_mysql_server__original'], $_GET['compare_main']['database__original'], $_GET['compare_main']['id_mysql_server__compare'], $_GET['compare_main']['database__compare']);
             $data['display'] = true;
             //log
             $this->di['log']->warning('[Compare] ' . $_GET['compare_main']['id_mysql_server__original'] . ":" . $_GET['compare_main']['database__original'] . " vs " . $_GET['compare_main']['id_mysql_server__compare'] . ":" . $_GET['compare_main']['database__compare'] . "(" . $_SERVER["REMOTE_ADDR"] . ")");
         }
     }
     $this->set('data', $data);
 }
Exemple #9
0
        $_SYSTEM['param'] = !empty($_SERVER["argv"][3]) ? $_SERVER["argv"][3] : '';
        if ($_SERVER["argc"] > 3) {
            $params = array();
            for ($i = 3; $i < $_SERVER["argc"]; $i++) {
                $params[] = $_SERVER["argv"][$i];
            }
            $_SYSTEM['param'] = $params;
        }
        //cli_set_process_title("glial-" . $_SYSTEM['controller'] . "-" . $_SYSTEM['action']." (".$name.")");
    } else {
        throw new InvalidArgumentException('usage : gial <controlleur> <action> [params]');
    }
    define('LINK', WWW_ROOT . "en" . "/");
} else {
    //mode with apache
    define('LINK', WWW_ROOT . I18n::Get() . "/");
    if (AUTH_ACTIVE) {
        $auth = new Auth();
        $auth->setInstance($_DB->sql(DB_DEFAULT), "user_main", array("login", "password"));
        $auth->setFctToHashCookie(function ($password) {
            return password_hash($password . $_SERVER['HTTP_USER_AGENT'] . $_SERVER['REMOTE_ADDR'], PASSWORD_DEFAULT);
        });
        $auth->authenticate(false);
        FactoryController::addDi("auth", $auth);
    }
    ENVIRONEMENT ? $_DEBUG->save("User connexion") : "";
    $_SYSTEM['controller'] = \Glial\Utility\Inflector::camelize($url['controller']);
    $_SYSTEM['action'] = $url['action'];
    $_SYSTEM['param'] = $url['param'];
    $acl = new Acl(CONFIG . "acl.config.ini");
    FactoryController::addDi("acl", $acl);
Exemple #10
0
 final function setLayout()
 {
     Variable::$_open = false;
     if (!IS_CLI) {
         global $_SITE;
         $GLIALE_CONTENT = $this->html;
         $GLIALE_TITLE = $this->title;
         $GLIALE_ARIANE = $this->ariane;
         ob_implicit_flush(false);
         ob_start();
         Variable::$_open = true;
         include APP_DIR . DS . "layout" . DS . $this->layout_name . ".layout.php";
         if (!$this->ajax) {
             //echo $this->js;
             echo $this->di['js']->getJavascript();
             //echo $this->js;
         }
         echo "</html>\n";
         //TODO a mettre ailleurs
         Variable::$_html = ob_get_clean();
         Variable::$_html = I18n::getTranslation(Variable::$_html);
         echo Variable::$_html;
     }
 }
    public function add()
    {
        //df -Ph . | tail -1 | awk '{print $2}' => to know space
        $db = $this->di['db']->sql(DB_DEFAULT);
        if ($_SERVER['REQUEST_METHOD'] == "POST") {
            Crypt::$key = CRYPT_KEY;
            $storage_area['backup_storage_area'] = $_POST['backup_storage_area'];
            if (!Ssh::testAccount($storage_area['backup_storage_area']['ip'], $storage_area['backup_storage_area']['port'], $storage_area['backup_storage_area']['ssh_login'], $storage_area['backup_storage_area']['ssh_password'])) {
                foreach ($_POST['backup_storage_area'] as $var => $val) {
                    $ret[] = "backup_storage_area:" . $var . ":" . urlencode(html_entity_decode($val));
                }
                $param = implode("/", $ret);
                $title = I18n::getTranslation(__("Failed to connect on ssh/scp/sFtp"));
                $msg = I18n::getTranslation(__("Please check your hostname and you credentials !"));
                set_flash("error", $title, $msg);
                header("location: " . LINK . "backup/storageArea/add/" . $param);
                exit;
            }
            $storage_area['backup_storage_area']['ssh_login'] = Crypt::encrypt($storage_area['backup_storage_area']['ssh_login']);
            $storage_area['backup_storage_area']['ssh_password'] = Crypt::encrypt($storage_area['backup_storage_area']['ssh_password']);
            if (!($id_storage_area = $db->sql_save($storage_area))) {
                $error = $db->sql_error();
                $_SESSION['ERROR'] = $error;
                $title = I18n::getTranslation(__("Fail to add this storage area"));
                $msg = I18n::getTranslation(__("One or more problem came when you try to add this storage, please verify your informations"));
                set_flash("error", $title, $msg);
                foreach ($_POST['backup_storage_area'] as $var => $val) {
                    $ret[] = "backup_storage_area:" . $var . ":" . urlencode(html_entity_decode($val));
                }
                $param = implode("/", $ret);
                header("location: " . LINK . "backup/storageArea/add/" . $param);
                exit;
            } else {
                $this->getStorageSpace(array($id_storage_area));
                $title = I18n::getTranslation(__("Successfull"));
                $msg = I18n::getTranslation(__("You storage area has been successfull added !"));
                set_flash("success", $title, $msg);
            }
        }
        $this->di['js']->addJavascript(array("http://www.estrildidae.net/js/jquery.1.3.2.js", "jquery.autocomplete.min.js"));
        //$this->di['js']->addJavascript(array("jquery-latest.min.js", "jquery.autocomplete.min.js"));
        $this->di['js']->code_javascript('$("#backup_storage_area-id_geolocalisation_city-auto").autocomplete("' . LINK . 'user/city/ajax>yes", {
		extraParams: {
			country: function() {return $("#backup_storage_area-id_geolocalisation_country").val();}
		},
        mustMatch: true,
        autoFill: true,
        max: 100,
        scrollHeight: 302,
        delay:0
		});
		$("#backup_storage_area-id_geolocalisation_city-auto").result(function(event, data, formatted) {
			if (data)
				$("#backup_storage_area-id_geolocalisation_city").val(data[1]);
		});
		$("#backup_storage_area-id_geolocalisation_country").change( function() 
		{
			$("#backup_storage_area-id_geolocalisation_city-auto").val("");
			$("#backup_storage_area-id_geolocalisation_city").val("");
		} );

		');
        $sql = "SELECT id, libelle from geolocalisation_country where libelle != '' order by libelle asc";
        $res = $db->sql_query($sql);
        $this->data['geolocalisation_country'] = $db->sql_to_array($res);
        $this->set('data', $this->data);
    }