當前位置: 首頁>>代碼示例>>PHP>>正文


PHP DbManager::getManager方法代碼示例

本文整理匯總了PHP中DbManager::getManager方法的典型用法代碼示例。如果您正苦於以下問題:PHP DbManager::getManager方法的具體用法?PHP DbManager::getManager怎麽用?PHP DbManager::getManager使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在DbManager的用法示例。


在下文中一共展示了DbManager::getManager方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: correctMysqlUsers

/**
 * loop over all mysql databases and create/delete users according to $access_hosts.
 *
 * This function is called when system.mysql_access_hosts or system.ipaddress is changed
 *
 * @param array $access_hosts list of hosts from which mysql access should be allowed
 */
function correctMysqlUsers($access_hosts)
{
    global $log;
    Database::needRoot(false);
    $databases_stmt = Database::query("SELECT * FROM `" . TABLE_PANEL_DATABASES . "` ORDER BY `dbserver`");
    $current_server = -1;
    $flush_privileges = false;
    $dbm = null;
    while ($dbdata = $databases_stmt->fetch(PDO::FETCH_ASSOC)) {
        // next server?
        if ($current_server != $dbdata['dbserver']) {
            // flush privileges if necessary
            if ($flush_privileges) {
                $dbm->getManager()->flushPrivileges();
            }
            // connect to the server which hosts this database
            Database::needRoot(true, $dbdata['dbserver'], true);
            $dbm = new DbManager($log);
        }
        // get the list of users belonging to this database
        $users = $dbm->getManager()->getAllSqlUsers(false, $dbdata['databasename']);
        // compare required access hosts with actual data
        foreach ($users as $username => $data) {
            $hosts_to_create = $access_hosts;
            foreach ($data['hosts'] as $host) {
                if (($key = array_search($host, $hosts_to_create)) !== false) {
                    // host is already in access_hosts, no need to create
                    unset($hosts_to_create[$key]);
                } else {
                    // host not in access_hosts, remove it
                    $dbm->getManager()->deleteUser($username, $host);
                    $flush_privileges = true;
                }
            }
            // create missing host permissions
            foreach ($hosts_to_create as $host) {
                $dbm->getManager()->grantPrivilegesTo($username, $data['password'], $host, true);
            }
        }
    }
    if ($flush_privileges) {
        $dbm->getManager()->flushPrivileges();
    }
    Database::needRoot(false);
}
開發者ID:greybyte,項目名稱:froxlor-mn,代碼行數:52,代碼來源:function.correctMysqlUsers.php

示例2: correctMysqlUsers

/**
 * This file is part of the Froxlor project.
 * Copyright (c) 2003-2009 the SysCP Team (see authors).
 * Copyright (c) 2010 the Froxlor Team (see authors).
 *
 * For the full copyright and license information, please view the COPYING
 * file that was distributed with this source code. You can also view the
 * COPYING file online at http://files.froxlor.org/misc/COPYING.txt
 *
 * @copyright  (c) the authors
 * @author     Florian Lippert <flo@syscp.org> (2003-2009)
 * @author     Froxlor team <team@froxlor.org> (2010-)
 * @license    GPLv2 http://files.froxlor.org/misc/COPYING.txt
 * @package    Functions
 *
 */
function correctMysqlUsers($mysql_access_host_array)
{
    global $log;
    // get sql-root access data
    Database::needRoot(true);
    Database::needSqlData();
    $sql_root = Database::getSqlData();
    Database::needRoot(false);
    $dbservers_stmt = Database::query("SELECT DISTINCT `dbserver` FROM `" . TABLE_PANEL_DATABASES . "`");
    $mysql_servers = '';
    while ($dbserver = $dbservers_stmt->fetch(PDO::FETCH_ASSOC)) {
        Database::needRoot(true, $dbserver['dbserver']);
        Database::needSqlData();
        $sql_root = Database::getSqlData();
        $dbm = new DbManager($log);
        $users = $dbm->getManager()->getAllSqlUsers(false);
        $databases = array($sql_root['db']);
        $databases_result_stmt = Database::prepare("\n\t\t\tSELECT * FROM `" . TABLE_PANEL_DATABASES . "`\n\t\t\tWHERE `dbserver` = :mysqlserver\n\t\t");
        Database::pexecute($databases_result_stmt, array('mysqlserver' => $dbserver['dbserver']));
        while ($databases_row = $databases_result_stmt->fetch(PDO::FETCH_ASSOC)) {
            $databases[] = $databases_row['databasename'];
        }
        foreach ($databases as $username) {
            if (isset($users[$username]) && is_array($users[$username]) && isset($users[$username]['hosts']) && is_array($users[$username]['hosts'])) {
                $password = $users[$username]['password'];
                foreach ($mysql_access_host_array as $mysql_access_host) {
                    $mysql_access_host = trim($mysql_access_host);
                    if (!in_array($mysql_access_host, $users[$username]['hosts'])) {
                        $dbm->getManager()->grantPrivilegesTo($username, $password, $mysql_access_host, true);
                    }
                }
                foreach ($users[$username]['hosts'] as $mysql_access_host) {
                    if (!in_array($mysql_access_host, $mysql_access_host_array)) {
                        $dbm->getManager()->deleteUser($username, $mysql_access_host);
                    }
                }
            }
        }
        $dbm->getManager()->flushPrivileges();
        Database::needRoot(false);
    }
}
開發者ID:cobrafast,項目名稱:Froxlor,代碼行數:58,代碼來源:function.correctMysqlUsers.php

示例3: array

 $upd_stmt = Database::prepare("\n\t\t\t\t\t\t\tUPDATE `" . TABLE_MAIL_USERS . "` SET `postfix`= :yesno, `pop3` = :pop3, `imap` = :imap WHERE `customerid` = :customerid");
 Database::pexecute($upd_stmt, array('yesno' => $yesno, 'pop3' => $pop3, 'imap' => $imap, 'customerid' => $id));
 $upd_stmt = Database::prepare("\n\t\t\t\t\t\t\tUPDATE `" . TABLE_FTP_USERS . "` SET `login_enabled` = :yesno WHERE `customerid` = :customerid");
 Database::pexecute($upd_stmt, array('yesno' => $yesno, 'customerid' => $id));
 $upd_stmt = Database::prepare("\n\t\t\t\t\t\t\tUPDATE `" . TABLE_PANEL_DOMAINS . "` SET `deactivated`= :deactivated WHERE `customerid` = :customerid");
 Database::pexecute($upd_stmt, array('deactivated' => $deactivated, 'customerid' => $id));
 // Retrieve customer's databases
 $databases_stmt = Database::prepare("SELECT * FROM " . TABLE_PANEL_DATABASES . " WHERE customerid = :customerid ORDER BY `dbserver`");
 Database::pexecute($databases_stmt, array('customerid' => $id));
 Database::needRoot(true);
 $last_dbserver = 0;
 $dbm = new DbManager($log);
 // For each of them
 while ($row_database = $databases_stmt->fetch(PDO::FETCH_ASSOC)) {
     if ($last_dbserver != $row_database['dbserver']) {
         $dbm->getManager()->flushPrivileges();
         Database::needRoot(true, $row_database['dbserver']);
         $last_dbserver = $row_database['dbserver'];
     }
     foreach (array_unique(explode(',', Settings::Get('system.mysql_access_host'))) as $mysql_access_host) {
         $mysql_access_host = trim($mysql_access_host);
         // Prevent access, if deactivated
         if ($deactivated) {
             // failsafe if user has been deleted manually (requires MySQL 4.1.2+)
             $dbm->getManager()->disableUser($row_database['databasename'], $mysql_access_host);
         } else {
             // Otherwise grant access
             $dbm->getManager()->enableUser($row_database['databasename'], $mysql_access_host);
         }
     }
 }
開發者ID:mowamed,項目名稱:Froxlor,代碼行數:31,代碼來源:admin_customers.php

示例4: array

			AND `id`="' . (int) $id . '"');
        Database::pexecute($result_stmt, array("customerid" => $userinfo['customerid']));
        $result = $result_stmt->fetch(PDO::FETCH_ASSOC);
        if (isset($result['databasename']) && $result['databasename'] != '') {
            Database::needRoot(true, $result['dbserver']);
            Database::needSqlData();
            $sql_root = Database::getSqlData();
            Database::needRoot(false);
            if (!isset($sql_root[$result['dbserver']]) || !is_array($sql_root[$result['dbserver']])) {
                $result['dbserver'] = 0;
            }
            if (isset($_POST['send']) && $_POST['send'] == 'send') {
                // Begin root-session
                Database::needRoot(true, $result['dbserver']);
                $dbm = new DbManager($log);
                $dbm->getManager()->deleteDatabase($result['databasename']);
                $log->logAction(USR_ACTION, LOG_INFO, "deleted database '" . $result['databasename'] . "'");
                Database::needRoot(false);
                // End root-session
                $stmt = Database::prepare("DELETE FROM `" . TABLE_PANEL_DATABASES . "`\n\t\t\t\t\tWHERE `customerid` = :customerid\n\t\t\t\t\tAND `id` = :id");
                Database::pexecute($stmt, array("customerid" => $userinfo['customerid'], "id" => $id));
                $resetaccnumber = $userinfo['mysqls_used'] == '1' ? " , `mysql_lastaccountnumber` = '0' " : '';
                $stmt = Database::prepare("UPDATE `" . TABLE_PANEL_CUSTOMERS . "`\n\t\t\t\t\tSET `mysqls_used` = `mysqls_used` - 1 " . $resetaccnumber . "\n\t\t\t\t\tWHERE `customerid` = :customerid");
                Database::pexecute($stmt, array("customerid" => $userinfo['customerid']));
                redirectTo($filename, array('page' => $page, 's' => $s));
            } else {
                $dbnamedesc = $result['databasename'];
                if (isset($result['description']) && $result['description'] != '') {
                    $dbnamedesc .= ' (' . $result['description'] . ')';
                }
                ask_yesno('mysql_reallydelete', $filename, array('id' => $id, 'page' => $page, 'action' => $action), $dbnamedesc);
開發者ID:Git-Host,項目名稱:Froxlor,代碼行數:31,代碼來源:customer_mysql.php


注:本文中的DbManager::getManager方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。