";
        $ret = 0;
        if ($stdout) {
            passthru($exe, $ret);
        } else {
            exec($exe, $ret);
        }
        echo "";
        if ($ret != 0) {
            return false;
        } else {
            return true;
        }
    }
    /** 
     * Get the size of a database
     * @param $dbname name of the database
     * @return integer database size
     * @access private
     */
    function get_db_size($dbname) {
        $this->dbus->query("SHOW TABLE STATUS FROM $dbname;");
        $size = 0;
        while ($this->dbus->next_record()) {
            $size += $this->dbus->f('Data_length') + $this->dbus->f('Index_length');
            if ($this->dbus->f('Engine') != 'InnoDB') {
                $size += $this->dbus->f('Data_free');
            }
        }
        return $size;
    }
    /**
     * Returns the list of database users of an account
     */
    function get_userslist($all = null) {
        global $db, $msg, $cuid;
        $msg->debug("mysql", "get_userslist");
        $c = array();
        if (!$all) {
            $db->query("SELECT name FROM dbusers WHERE uid= ? and enable not in ('ADMIN','HIDDEN') ORDER BY name;", array($cuid));
        } else {
            $db->query("SELECT name FROM dbusers WHERE uid= ? ORDER BY name;", array($cuid));
        }
        while ($db->next_record()) {
            $pos = strpos($db->f("name"), "_");
            if ($pos === false) {
                $c[] = array("name" => ($db->f("name")));
            } else {
                $c[] = array("name" => ($db->f("name")));
                //$c[]=array("name"=>substr($db->f("name"),strpos($db->f("name"),"_")+1));
            }
        }
        return $c;
    }
    
    function get_defaultsparam($dbn) {
        global $db, $mem, $msg, $cuid;
        $msg->debug("mysql", "getdefaults");
        $login=$mem->user["login"];
        # The first condition allows us to access our "default" database, where the
        # name matches exactly our login name. The second condition allows us to
        # access the other databases suffixed with "_.*"
        # The condition is split into two here to avoid the following situation:
        #   * Given two accounts "example" and "exampleb", with defaults (un-suffixed)
        # databases, the user of account "example" could read the parameter information
        # for "exampleb".
        if (($dbn != $login) && !preg_match("#^$login\_#", $dbn)) {
                $msg->raise("ERROR", "mysql",_("Database not found")." (5)");
                return false;
        }
        $dbu = $dbn;
        $r = array();
        $dbn = str_replace('_', '\_', $dbn);
        $this->dbus->query("Select * from mysql.db where Db= ? and User!= ? ;", array($dbn, $cuid."_myadm"));
        if (!$this->dbus->num_rows()) {
            $msg->raise("ERROR", "mysql",_("Database not found"));
            return false;
        }
        $listRights = array('Select', 'Insert', 'Update', 'Delete', 'Create', 'Drop', 'References', 'Index', 'Alter', 'Create_tmp_table', 'Lock_tables', 'Create_view', 'Show_view', 'Create_routine', 'Alter_routine', 'Execute', 'Event', 'Trigger');
        while ($this->dbus->next_record()) {
            // rTmp is the array where we put the informations from each loop, added to array $r
            $rTmp = array();
            $variable = $this->dbus->Record;
            
            $dbu = $variable['User'];
            
            $rTmp['Host'] = $this->dbus->f('Host');
            $rTmp['Rights']='All';
            
            foreach ($listRights as $v) {
                $right = $v."_priv";
                if ($this->dbus->f($right) !== "Y") {
                    $rTmp['Rights'] = 'NotAll';
                    break;
                }
            }
            
            if (!$db->query("SELECT name,password from dbusers where name= ? and uid= ? ;", array($dbu, $cuid))) {
                $msg->raise("ERROR", "mysql",_("Database not found")." (3)");
                return false;
            }
            
            if (!$db->num_rows()) {
                $msg->raise("ERROR", "mysql",_("Database not found")." (4)");
                return false;
            }
            
            $db->next_record();
            $rTmp['user'] = $db->f('name');
            $rTmp['password'] = $db->f('password');
            
            $r[] = $rTmp;
            
        } // endwhile
        return $r;
    }
    
    /**
     * Create a new user in MySQL rights tables
     * @param $usern the username (we will add _[alternc-account] to it)
     * @param string $password The password for this username
     * @param string $passconf The password confirmation
     * @return boolean if the user has been created in MySQL or FALSE if an error occurred
     */
    function add_user($usern, $password, $passconf) {
        global $db, $msg, $mem, $cuid, $admin;
        $msg->log("mysql", "add_user", $usern);
        $usern = trim($usern);
        $login = $mem->user["login"];
        if ($login != $usern) {
            $user = $login . "_" . $usern;
        } else {
            $user = $usern;
        }
        if (!$usern) {
            $msg->raise("ALERT", "mysql", _("The username is mandatory"));
            return false;
        }
        if (!$password) {
            $msg->raise("ALERT", "mysql", _("The password is mandatory"));
            return false;
        }
        if (!preg_match("#^[0-9a-z]#", $usern)) {
            $msg->raise("ERROR", "mysql", _("The username can contain only letters and numbers"));
            return false;
        }
        // We check the length of the COMPLETE username, not only the part after _
        $len=variable_get("sql_max_username_length", 16);
        if (strlen($user) > $len) {
            $msg->raise("ERROR", "mysql", _("MySQL username cannot exceed %d characters"), $len);
            return false;
        }
        $db->query("SELECT * FROM dbusers WHERE name= ? ;", array($user));
        if ($db->num_rows()) {
            $msg->raise("ERROR", "mysql", _("The database user already exists"));
            return false;
        }
        if ($password != $passconf || !$password) {
            $msg->raise("ERROR", "mysql", _("The passwords do not match"));
            return false;
        }
        // Check this password against the password policy using common API : 
        if (is_callable(array($admin, "checkPolicy"))) {
            if (!$admin->checkPolicy("mysql", $user, $password)) {
                return false; // The error has been raised by checkPolicy()
            }
        }
        // We add him to the user table 
        $db->query("INSERT INTO dbusers (uid,name,password,enable) VALUES( ?, ?, ?, 'ACTIVATED');", array($cuid, $user, $password));
        $this->grant("*", $user, "USAGE", $password);
        return true;
    }
    /**
     * Change a user's MySQL password
     * @param $usern the username 
     * @param $password The password for this username
     * @param $passconf The password confirmation
     * @return boolean if the password has been changed in MySQL or FALSE if an error occurred
     */
    function change_user_password($usern, $password, $passconf) {
        global $db, $msg, $cuid, $admin;
        $msg->log("mysql", "change_user_pass", $usern);
        $usern = trim($usern);
        if ($password != $passconf || !$password) {
            $msg->raise("ERROR", "mysql", _("The passwords do not match"));
            return false;
        }
        // Check this password against the password policy using common API : 
        if (is_callable(array($admin, "checkPolicy"))) {
            if (!$admin->checkPolicy("mysql", $usern, $password)) {
                return false; // The error has been raised by checkPolicy()
            }
        }
        $this->dbus->query("SET PASSWORD FOR " . $db->quote($usern) . "@" . $db->quote($this->dbus->Client) . " = PASSWORD(?);", array($password));
        $db->query("UPDATE dbusers set password= ? where name= ? and uid= ? ;", array($password, $usern, $cuid));
        return true;
    }
    /**
     * Delete a user in MySQL rights tables
     * @param $user the username (we will add "[alternc-account]_" to it) to delete
     * @param integer $all
     * @return boolean if the user has been deleted in MySQL or FALSE if an error occurred
     */
    function del_user($user, $all = false, $caller_is_deldb = false) {
        global $db, $msg, $cuid;
        $msg->log("mysql", "del_user", $user);
        if (!preg_match("#^[0-9a-z]#", $user)) {
            $msg->raise("ERROR", "mysql", _("The username can contain only letters and numbers"));
            return false;
        }
        if (!$all) {
            $db->query("SELECT name FROM dbusers WHERE name= ? and enable not in ('ADMIN','HIDDEN');", array($user));
        } else {
            $db->query("SELECT name FROM dbusers WHERE uid= ? ;", array($cuid));
        }
        if (!$db->num_rows()) {
            if (! $caller_is_deldb )
                $msg->raise("ERROR", "mysql", _("The username was not found"));
            return false;
        }
        $db->next_record();
        $login = $db->f("name");
        // Ok, database exists and dbname is compliant. Let's proceed
        $this->dbus->query("REVOKE ALL PRIVILEGES ON *.* FROM " . $db->quote($user) . "@" . $db->quote($this->dbus->Client) . ";");
        $this->dbus->query("DELETE FROM mysql.db WHERE User= ? AND Host= ? ;", array($user, $this->dbus->Client));
        $this->dbus->query("DELETE FROM mysql.user WHERE User= ? AND Host= ? ;", array($user, $this->dbus->Client));
        $this->dbus->query("FLUSH PRIVILEGES");
        $db->query("DELETE FROM dbusers WHERE uid= ? AND name= ? ;", array($cuid, $user));
        if ( $caller_is_deldb )
            $msg->raise("INFO", "mysql", _("The user '%s' has been successfully deleted"), $user);
        
        return true;
    }
    /**
     * Return the list of the database rights of user $user
     * @param $user the username 
     * @return array An array of database name and rights
     */
    function get_user_dblist($user) {
        global $db, $msg;
        $this->dbus->query("SELECT * FROM mysql.user WHERE User= ? AND Host= ? ;", array($user, $this->dbus->Client));
        if (!$this->dbus->next_record()) {
            $msg->raise("ERROR", 'mysql', _("This user does not exist in the MySQL/User database"));
            return false;
        }
        $r = array();
        $db->free();
        $dblist = $this->get_dblist();
        foreach ($dblist as $tab) {
            $dbname = str_replace('_', '\_', $tab["db"]);
            $this->dbus->query("SELECT * FROM mysql.db WHERE User= ? AND Host= ? AND Db= ? ;", array($user, $this->dbus->Client, $dbname));
            if ($this->dbus->next_record()) {
                $r[] = array("db" => $tab["db"], "select" => $this->dbus->f("Select_priv"), "insert" => $this->dbus->f("Insert_priv"), "update" => $this->dbus->f("Update_priv"), "delete" => $this->dbus->f("Delete_priv"), "create" => $this->dbus->f("Create_priv"), "drop" => $this->dbus->f("Drop_priv"), "references" => $this->dbus->f("References_priv"), "index" => $this->dbus->f("Index_priv"), "alter" => $this->dbus->f("Alter_priv"), "create_tmp" => $this->dbus->f("Create_tmp_table_priv"), "lock" => $this->dbus->f("Lock_tables_priv"),
                "create_view" => $this->dbus->f("Create_view_priv"),
                "show_view" => $this->dbus->f("Show_view_priv"),
                "create_routine" => $this->dbus->f("Create_routine_priv"),
                "alter_routine" => $this->dbus->f("Alter_routine_priv"),
                "execute" => $this->dbus->f("Execute_priv"),
                "event" => $this->dbus->f("Event_priv"),
                "trigger" => $this->dbus->f("Trigger_priv")
                );
            } else {
                $r[] = array("db" => $tab['db'], "select" => "N", "insert" => "N", "update" => "N", "delete" => "N", "create" => "N", "drop" => "N", "references" => "N", "index" => "N", "alter" => "N", "create_tmp" => "N", "lock" => "N", "create_view" => "N", "show_view" => "N", "create_routine" => "N", "alter_routine" => "N", "execute" => "N", "event" => "N", "trigger" => "N");
            }
        }
        return $r;
    }
    /**
     * Set the access rights of user $user to database $dbn to be rights $rights
     * @param $user the username to give rights to
     * @param $dbn The database to give rights to
     * @param $rights The rights as an array of MySQL keywords (insert, select ...)
     * @return boolean TRUE if the rights has been applied or FALSE if an error occurred
     */
    function set_user_rights($user, $dbn, $rights) {
        global $msg;
        $msg->log("mysql", "set_user_rights");
        // We generate the rights array depending on the rights list:
        $strrights = "";
        for ($i = 0; $i < count($rights); $i++) {
            switch ($rights[$i]) {
            case "select":
                $strrights.="SELECT,";
                break;
            case "insert":
                $strrights.="INSERT,";
                break;
            case "update":
                $strrights.="UPDATE,";
                break;
            case "delete":
                $strrights.="DELETE,";
                break;
            case "create":
                $strrights.="CREATE,";
                break;
            case "drop":
                $strrights.="DROP,";
                break;
            case "references":
                $strrights.="REFERENCES,";
                break;
            case "index":
                $strrights.="INDEX,";
                break;
            case "alter":
                $strrights.="ALTER,";
                break;
            case "create_tmp":
                $strrights.="CREATE TEMPORARY TABLES,";
                break;
            case "lock":
                $strrights.="LOCK TABLES,";
                break;
            case "create_view":
                $strrights.="CREATE VIEW,";
                break;
            case "show_view":
                $strrights.="SHOW VIEW,";
                break;
            case "create_routine":
                $strrights.="CREATE ROUTINE,";
                break;
            case "alter_routine":
                $strrights.="ALTER ROUTINE,";
                break;
            case "execute":
                $strrights.="EXECUTE,";
                break;
            case "event":
                $strrights.="EVENT,";
                break;
            case "trigger":
                $strrights.="TRIGGER,";
                break;
            }
        }
        // We reset all user rights on this DB : 
        $dbname = str_replace('_', '\_', $dbn);
        $this->dbus->query("SELECT * FROM mysql.db WHERE User = ? AND Db = ?;", array($user, $dbname));
        if ($this->dbus->num_rows()) {
            $this->dbus->query("REVOKE ALL PRIVILEGES ON `".$dbname."`.* FROM ".$this->dbus->quote($user)."@" . $this->dbus->quote($this->dbus->Client) . ";");
        }
        if ($strrights) {
            $strrights = substr($strrights, 0, strlen($strrights) - 1);
            $this->grant($dbname, $user, $strrights);
        }
        $this->dbus->query("FLUSH PRIVILEGES");
        return TRUE;
    }
    /** 
     * list of all possible SQL rights
     */
    function available_sql_rights() {
        return Array('select', 'insert', 'update', 'delete', 'create', 'drop', 'references', 'index', 'alter', 'create_tmp', 'lock', 'create_view', 'show_view', 'create_routine', 'alter_routine', 'execute', 'event', 'trigger');
    }
    /** 
     * Hook function called by the lxc class to set mysql_host and port 
     * parameters 
     * @access private
     */
    function hook_lxc_params($params) {
        global $msg;
        $msg->log("mysql", "alternc_get_quota");
        $p = array();
        if (isset($this->dbus["Host"]) && $this->dbus["Host"] != "") {
            $p["mysql_host"] = $this->dbus["Host"];
            $p["mysql_port"] = 3306;
        }
        return $p;
    }
    /** 
     * Hook function called by the quota class to compute user used quota
     * Returns the used quota for the $name service for the current user.
     * @param $name string name of the quota
     * @return integer the number of service used or false if an error occured
     * @access private
     */
    function hook_quota_get() {
        global $msg, $mem, $quota;
        $msg->debug("mysql", "alternc_get_quota");
        $q = Array("name" => "mysql", "description" => _("MySQL Databases"), "used" => 0);
        $c = $this->get_dblist();
        if (is_array($c)) {
            $q['used'] = count($c);
            $q['sizeondisk'] = $quota->get_size_db_sum_user($mem->user["login"])/1024;
        }
        return $q;
    }
    /** 
     * Hook function called when a user is created.
     * AlternC's standard function that create a member
     * @access private
     */
    function alternc_add_member() {
        global $db, $msg, $cuid, $mem;
        $msg->log("mysql", "alternc_add_member");
        // checking for the phpmyadmin user
        $db->query("SELECT name,password FROM dbusers WHERE uid= ? AND enable='ADMIN';", array($cuid));
        if ($db->num_rows()) {
            $myadm = $db->f("name");
            $password = $db->f("password");
        } else {
            $myadm = $cuid . "_myadm";
            $password = create_pass();
        }
        $db->query("INSERT INTO dbusers (uid,name,password,enable) VALUES (?, ?, ?, 'ADMIN');", array($cuid, $myadm, $password));
        return true;
    }
    /** 
     * Hook function called when a user is deleted.
     * AlternC's standard function that delete a member
     * @access private
     */
    function alternc_del_member() {
        global $msg;
        $msg->log("mysql", "alternc_del_member");
        $c = $this->get_dblist();
        if (is_array($c)) {
            for ($i = 0; $i < count($c); $i++) {
                $this->del_db($c[$i]["name"]);
            }
        }
        $d = $this->get_userslist(1);
        if (!empty($d)) {
            for ($i = 0; $i < count($d); $i++) {
                $this->del_user($d[$i]["name"], 1,true);
            }
        }
        return true;
    }
    /** 
     * Hook function called when a user is logged out.
     * We just remove the cookie created in admin/sql_admin.php
     * a @access private
    */
    function alternc_del_session() {
        $_SESSION['PMA_single_signon_user'] = '';
        $_SESSION['PMA_single_signon_password'] = '';
        $_SESSION['PMA_single_signon_host'] = '';
    }
    /**
     * Exports all the mysql information of an account
     * @access private
     * EXPERIMENTAL 'sid' function ;) 
     */
    function alternc_export_conf() {
        // TODO don't work with separated sql server for dbusers
        global $db, $msg, $cuid;
        $msg->log("mysql", "export");
        $db->query("SELECT login, pass, db, bck_mode, bck_dir, bck_history, bck_gzip FROM db WHERE uid= ? ;", array($cuid));
        $str = "";
        if ($db->next_record()) {
            $str.="