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


PHP unix::file_size方法代碼示例

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


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

示例1: inject_extracted_attach

function inject_extracted_attach($filepath)
{
    if ($GLOBALS["VERBOSE"]) {
        echo "Injecting {$filepath}\n";
    }
    $unix = new unix();
    $MYSQL_DATA_DIR = $unix->MYSQL_DATA_DIR();
    if (!is_dir($MYSQL_DATA_DIR)) {
        @mkdir($MYSQL_DATA_DIR, 0755, true);
        @chown($MYSQL_DATA_DIR, "mysql");
        @chgrp($MYSQL_DATA_DIR, "mysql");
    }
    $basename = basename($filepath);
    $tempfile = "{$MYSQL_DATA_DIR}/{$basename}";
    $last_modified = filemtime($filepath);
    $filetime = date("Y-m-d H:i:s", $last_modified);
    $filesize = $unix->file_size($filepath);
    @copy($filepath, $tempfile);
    @chmod($tempfile, 0777);
    $q = new mysql_mimedefang_builder();
    $sql = "SELECT `filename` FROM `storage` WHERE `filename`='{$basename}'";
    $ligne = mysql_fetch_array($q->QUERY_SQL($sql));
    if (strlen(trim($ligne["filename"])) > 0) {
        if ($GLOBALS["VERBOSE"]) {
            echo "Skipped {$basename}, already exists in database\n";
        }
        @unlink($filepath);
        return;
    }
    $sql = "INSERT INTO `storage` (`filename`,`filetime`,`filesize`,`filedata`) VALUES ('{$basename}','{$filetime}','{$filesize}',LOAD_FILE('{$filepath}'))";
    $q->QUERY_SQL($sql);
    if (!$q->ok) {
        system_admin_events("Fatal: {$q->mysql_error}.", __FUNCTION__, __FILE__, __LINE__, "postfix");
        $returned = false;
    } else {
        $returned = true;
        @unlink($filepath);
    }
    @unlink($tempfile);
    return $returned;
}
開發者ID:BillTheBest,項目名稱:1.6.x,代碼行數:41,代碼來源:exec.mimedefang.mysql.php

示例2: streamget

function streamget()
{
    $sock = new sockets();
    $unix = new unix();
    $SquidGuardStorageDir = $sock->GET_INFO("SquidGuardStorageDir");
    $EnableRemoteStatisticsAppliance = $sock->GET_INFO("EnableRemoteStatisticsAppliance");
    if (!is_numeric($EnableRemoteStatisticsAppliance)) {
        $EnableRemoteStatisticsAppliance = 0;
    }
    $hostname = $unix->FULL_HOSTNAME();
    $PREFIX = "INSERT IGNORE INTO `youtubecache`(`filename`,`filesize`,`urlsrc`,`zDate`,`zMD5`,`proxyname`) VALUES ";
    $q = new mysql_squid_builder();
    if (!($handle = opendir($SquidGuardStorageDir))) {
        events_tail("streamget:: -> glob failed {$SquidGuardStorageDir} in Line: " . __LINE__);
        return;
    }
    while (false !== ($filename = readdir($handle))) {
        if ($filename == ".") {
            continue;
        }
        if ($filename == "..") {
            continue;
        }
        $fullFileName = "{$SquidGuardStorageDir}/{$filename}";
        $time = null;
        if (strpos($filename, ".url") > 0) {
            continue;
        }
        if (strpos($filename, ".log") > 0) {
            continue;
        }
        $filesize = $unix->file_size($fullFileName);
        $time = filemtime($fullFileName);
        $zdate = date("Y-m-d H:i:s", $time);
        $url = null;
        if (is_file($fullFileName . ".url")) {
            $url = @file_get_contents($fullFileName . ".url");
        }
        if ($GLOBALS["VERBOSE"]) {
            echo "\n\nFile:{$fullFileName}\nSize:{$filesize}\ndate:{$zdate}\nurl:{$url}\n";
        }
        $md5 = md5($filename . $hostname);
        $f[] = "('{$fullFileName}','{$filesize}','{$url}','{$zdate}','{$md5}','{$hostname}')";
    }
    if (count($f) > 0) {
        $sql = $PREFIX . " " . @implode(",", $f);
        if ($EnableRemoteStatisticsAppliance == 0) {
            $q->QUERY_SQL($sql);
            if (!$q->ok) {
                events_tail("streamget:: Fatal {$q->mysql_error}");
            }
        } else {
            if ($GLOBALS["VERBOSE"]) {
                echo "streamget_send_remote() with hostname {$hostname}\n";
            }
            streamget_send_remote($sql, $hostname);
        }
    }
}
開發者ID:BillTheBest,項目名稱:1.6.x,代碼行數:59,代碼來源:exec.dansguardian.injector.php

示例3: ScanUpdateUtilityLogs

function ScanUpdateUtilityLogs($force = false)
{
    $unix = new unix();
    $sock = new sockets();
    $unix = new unix();
    $timefile = "/etc/artica-postfix/pids/ScanUpdateUtilityLogs.time";
    $pidfile = "/etc/artica-postfix/pids/ScanUpdateUtilityLogs.pid";
    if (!$force) {
        $pid = $unix->get_pid_from_file($pidfile);
        if ($unix->process_exists($pid, basename(__FILE__))) {
            $time = $unix->PROCCESS_TIME_MIN($pid);
            if ($GLOBALS["VERBOSE"]) {
                echo "Already process exists {$pid}\n";
            }
            return;
        }
        @file_put_contents($pidfile, getmypid());
        $time = $unix->file_time_min($timefile);
        if ($timefile < 10) {
            if ($GLOBALS["VERBOSE"]) {
                echo "Only each 10mn\n";
            }
            return;
        }
    }
    @unlink($timefile);
    @file_put_contents($timefile, time());
    $UpdateUtilityStorePath = $sock->GET_INFO("UpdateUtilityStorePath");
    if ($UpdateUtilityStorePath == null) {
        $UpdateUtilityStorePath = "/home/kaspersky/UpdateUtility";
    }
    $UpdateUtilityUseLoop = $sock->GET_INFO("UpdateUtilityUseLoop");
    if (!is_numeric($UpdateUtilityUseLoop)) {
        $UpdateUtilityUseLoop = 0;
    }
    if ($UpdateUtilityUseLoop == 1) {
        $UpdateUtilityStorePath = "/automounts/UpdateUtility";
    }
    if ($GLOBALS["VERBOSE"]) {
        echo "Scanning /var/log/artica-postfix/UpdateUtility-*.log...\n";
    }
    foreach (glob("/var/log/artica-postfix/UpdateUtility-*.log") as $filename) {
        $timefile = $unix->file_time_min($filename);
        $time = filemtime($filename);
        $details = @file_get_contents($filename);
        $f = explode("\n", $details);
        $isSuccess = 1;
        $files = 0;
        $size = 0;
        $rp_finish = false;
        if ($timefile > 720) {
            $rp_finish = true;
        }
        while (list($key, $line) = each($f)) {
            if (preg_match("#New file installed '(.*?)'#", $line, $re)) {
                $nextFile = "{$UpdateUtilityStorePath}/databases/Updates/{$re[1]}";
                if (!is_file($nextFile)) {
                    if ($GLOBALS["VERBOSE"]) {
                        echo "{$nextFile}, no such file\n";
                    }
                    $nextFile = "{$UpdateUtilityStorePath}/TempFolder/temporaryFolder/{$re[1]}";
                }
                if (!is_file($nextFile)) {
                    if ($GLOBALS["VERBOSE"]) {
                        echo "{$nextFile}, no such file\n";
                    }
                    continue;
                }
                $files++;
                $size = $size + $unix->file_size($nextFile);
                continue;
            }
            if (preg_match("#Segmentation fault#", $line)) {
                $isSuccess = 0;
                continue;
                $rp_finish = true;
            }
            if (preg_match("#Bus error#", $line)) {
                $isSuccess = 0;
                continue;
                $rp_finish = true;
            }
            if (preg_match("#Report finished at#", $line, $re)) {
                $rp_finish = true;
                continue;
            }
            if (preg_match("#Insufficient disk space#i", $line, $re)) {
                $isSuccess = 0;
                continue;
                $rp_finish = true;
            }
            if (preg_match("#Failed to#i", $line, $re)) {
                $isSuccess = 0;
                continue;
            }
            if (preg_match("#not retranslated#i", $line, $re)) {
                $isSuccess = 0;
                continue;
                $rp_finish = true;
            }
//.........這裏部分代碼省略.........
開發者ID:brucewu16899,項目名稱:1.6.x,代碼行數:101,代碼來源:exec.keepup2date.php

示例4: replic_host

function replic_host($servername)
{
    $t = time();
    $unix = new unix();
    $free = new freeweb($servername);
    $instanceid = $free->mysql_instance_id;
    $localdatabase = $free->mysql_database;
    if (!isset($free->Params["ROUNDCUBE"]["ENABLE_REPLIC"])) {
        if ($GLOBALS["VERBOSE"]) {
            echo "{$servername}: ROUNDCUBE/ENABLE_REPLIC no set\n";
        }
        return null;
    }
    if ($free->Params["ROUNDCUBE"]["ENABLE_REPLIC"] == 0) {
        if ($GLOBALS["VERBOSE"]) {
            echo "{$servername}: ROUNDCUBE/ENABLE_REPLIC set to disabled\n";
        }
        return null;
    }
    $ARTICA_PORT = $free->Params["ROUNDCUBE"]["ARTICA_PORT"];
    $ARTICA_ADMIN = $free->Params["ROUNDCUBE"]["ARTICA_ADMIN"];
    $ARTICA_PASSWORD = $free->Params["ROUNDCUBE"]["ARTICA_PASSWORD"];
    $ARTICA_HOST = $free->Params["ROUNDCUBE"]["ARTICA_HOST"];
    $ARTICA_RMWEB = $free->Params["ROUNDCUBE"]["ARTICA_RMWEB"];
    if ($GLOBALS["VERBOSE"]) {
        echo "Send order to get database dump {$ARTICA_HOST}:{$ARTICA_PORT}\n";
    }
    $auth = array("username" => $ARTICA_ADMIN, "password" => md5($ARTICA_PASSWORD));
    $auth = base64_encode(serialize($auth));
    $curl = new ccurl("https://{$ARTICA_HOST}:{$ARTICA_PORT}/exec.gluster.php");
    $curl->noproxyload = true;
    $curl->parms["AUTH"] = $auth;
    $curl->parms["RDCUBE-REPLIC"] = $ARTICA_RMWEB;
    if (!$curl->get()) {
        if ($GLOBALS["VERBOSE"]) {
            echo "Error replicate roundcube to {$ARTICA_HOST}:{$ARTICA_PORT} with error {$curl->error}\n";
        }
        system_admin_events("Error replicate roundcube to {$ARTICA_HOST}:{$ARTICA_PORT} with error {$curl->error}", __FUNCTION__, __FILE__, __LINE__, "roundcube");
        return;
    }
    preg_match("#<INFOS>(.*?)</INFOS>#is", $curl->data, $re);
    if ($GLOBALS["VERBOSE"]) {
        echo "{$curl->data}\n";
    }
    if (!preg_match("#<FILENAME>(.*?)</FILENAME>#is", $curl->data, $re)) {
        preg_match("#<ERROR>(.*?)</ERROR>#is", $curl->data, $re);
        if ($GLOBALS["VERBOSE"]) {
            echo "Error replicate roundcube to {$ARTICA_HOST}:{$ARTICA_PORT} with error {$re[1]}\n";
        }
        system_admin_events("Error replicate roundcube to {$ARTICA_HOST}:{$ARTICA_PORT} with error {$re[1]}", __FUNCTION__, __FILE__, __LINE__, "roundcube");
        return;
    }
    $filepath = $re[1];
    $filename = basename($filepath);
    $curl = new ccurl("https://{$ARTICA_HOST}:{$ARTICA_PORT}/{$filepath}");
    if (!$curl->GetFile("/tmp/{$filename}")) {
        if ($GLOBALS["VERBOSE"]) {
            echo "Error get  roundcube database from {$filepath} with error {$curl->error}\n";
        }
        system_admin_events("Error get  roundcube database from {$filepath} with error {$curl->error}", __FUNCTION__, __FILE__, __LINE__, "roundcube");
        return;
    }
    $filesize = $unix->file_size("/tmp/{$filename}");
    if ($GLOBALS["VERBOSE"]) {
        echo "Downloading {$filename} done with {$filesize} bytes\n";
    }
    if (!$unix->uncompress("/tmp/{$filename}", "/tmp/{$filename}.sql")) {
        @unlink("/tmp/{$filename}");
        if ($GLOBALS["VERBOSE"]) {
            echo "Error uncompress {$filepath}\n";
        }
        system_admin_events("Error uncompress {$filepath}", __FUNCTION__, __FILE__, __LINE__, "roundcube");
        return;
    }
    @unlink("/tmp/{$filename}");
    $mysqlbin = $unix->find_program("mysql");
    if ($instanceid > 0) {
        $q = new mysql_multi($instance_id);
        if ($q->mysql_password != null) {
            $password = " --password={$q->mysql_password} ";
        }
        $cmdline = "{$mysqlbin} --batch --force --user={$q->mysql_admin}{$password} --socket={$q->SocketPath} --database={$localdatabase} </tmp/{$filename}.sql 2>&1";
    } else {
        $q = new mysql();
        if ($q->mysql_server == "127.0.0.1") {
            $servcmd = " --socket=/var/run/mysqld/mysqld.sock ";
        } else {
            $servcmd = " --host={$q->mysql_server} --port={$q->mysql_port} ";
        }
        if ($q->mysql_password != null) {
            $password = " --password={$q->mysql_password} ";
        }
        $cmdline = "{$mysqlbin} --batch --force --user={$q->mysql_admin}{$password} {$servcmd} --database={$localdatabase} </tmp/{$filename}.sql 2>&1";
    }
    if ($GLOBALS["VERBOSE"]) {
        echo $cmdline . "\n";
    }
    shell_exec($cmdline);
    $took = $unix->distanceOfTimeInWords($t, time(), true);
    system_admin_events("Success import from {$filename} to {$localdatabase} took {$took}", __FUNCTION__, __FILE__, __LINE__, "roundcube");
//.........這裏部分代碼省略.........
開發者ID:BillTheBest,項目名稱:1.6.x,代碼行數:101,代碼來源:exec.freeweb.rdcube-replic.php

示例5: Dumpimport

function Dumpimport($innodb_file_pertable = 0)
{
    system_admin_events("Create pointer to block Artica ", __FUNCTION__, __FILE__, __LINE__, "mysql");
    @mkdir("/home/mysqldump", 0755, true);
    $tmpfile = "/home/mysqldump/all-database.sql";
    $tmpError = "/home/mysqldump/all-database.errors";
    $t1 = time();
    $sock = new sockets();
    $sock->SET_INFO("DisableMySqlTemp", 0);
    $unix = new unix();
    $q = new mysql();
    $mysql_admin = $q->mysql_admin;
    $MYSQL_DATA_DIR = $unix->MYSQL_DATA_DIR();
    if (trim($mysql_admin) == null) {
        system_admin_events("Error, unable to get mysql_admin credentials", __FUNCTION__, __FILE__, __LINE__, "mysql");
        die;
    }
    if (!is_file($tmpfile)) {
        system_admin_events("Error, {$tmpfile} no such file", __FUNCTION__, __FILE__, __LINE__, "mysql");
        die;
    }
    $password = $q->mysql_password;
    if ($password != null) {
        $passwordcmdline = " --password={$password}";
    }
    $mysqlbin = $unix->find_program("mysql");
    if (!is_file($mysqlbin)) {
        system_admin_events("Error, mysqldump no such binary, aborting", __FUNCTION__, __FILE__, __LINE__, "mysql");
        die;
    }
    $BaseDir = $MYSQL_DATA_DIR;
    $files = $unix->DirFiles($BaseDir);
    system_admin_events("Info, stopping mysql", __FUNCTION__, __FILE__, __LINE__, "mysql");
    @file_put_contents("/etc/artica-postfix/mysql.stop", time());
    shell_exec("/etc/init.d/artica-postfix stop mysql");
    while (list($index, $line) = each($files)) {
        $fsize = FormatBytes($unix->file_size("{$BaseDir}/{$line}"));
        if (preg_match("#ib_logfile#", $line)) {
            system_admin_events("Info, removing {$BaseDir}/{$line}", __FUNCTION__, __FILE__, __LINE__, "mysql");
            @unlink("/{$BaseDir}/{$line}");
            $deleted[] = $line . ": {$fsize}";
            continue;
        }
        if (preg_match("#ibdata#", $line)) {
            system_admin_events("Info, removing {$BaseDir}/{$line}", __FUNCTION__, __FILE__, __LINE__, "mysql");
            @unlink("/{$BaseDir}/{$line}");
            $deleted[] = $line . ": {$fsize}";
            continue;
        }
        $skipped[] = $line . ": {$fsize}";
    }
    if ($innodb_file_pertable == 1) {
        system_admin_events("Info, innodb_file_per_table is enabled", __FUNCTION__, __FILE__, __LINE__, "mysql");
        $sock->SET_INFO("InnodbFilePerTable", 1);
        $php5 = $unix->LOCATE_PHP5_BIN();
        shell_exec("{$php5} " . dirname(__FILE__) . "/exec.mysql.build.php");
        system_admin_events("Deleting, ibdata1,ib_logfile0,ib_logfile1 is enabled", __FUNCTION__, __FILE__, __LINE__, "mysql");
        @unlink("{$MYSQL_DATA_DIR}/ibdata1");
        @unlink("{$MYSQL_DATA_DIR}/ib_logfile0");
        @unlink("{$MYSQL_DATA_DIR}/ib_logfile1");
    }
    @unlink("/etc/artica-postfix/mysql.stop");
    system_admin_events("Info, Cleaning Mysql directory: delete files\n" . @implode($deleted, "\n") . "Skipped files:\n" . @implode($skipped, "\n"), __FUNCTION__, __FILE__, __LINE__, "mysql");
    system_admin_events("Info, starting mysql", __FUNCTION__, __FILE__, __LINE__, "mysql");
    exec("/etc/init.d/artica-postfix start mysql 2>&1", $results);
    system_admin_events("Info, starting mysql done\n" . @implode("\n", $results), __FUNCTION__, __FILE__, __LINE__, "mysql");
    unset($results);
    system_admin_events("Stamp artica to not trying to inject to mysql", __FUNCTION__, __FILE__, __LINE__, "mysql");
    sleep(2);
    for ($i = 0; $i < 50; $i++) {
        $q = new mysql();
        $sleep = true;
        if (!$q->DATABASE_EXISTS("artica_backup")) {
            $sleep = true;
        }
        $pid = @file_get_contents("/var/run/mysqld/mysqld.pid");
        if ($unix->process_exists($pid)) {
            echo "MySQL server running PID {$pid}\n";
            $sleep = false;
        } else {
            $sleep = true;
        }
        if ($sleep) {
            echo "Sleeping 1s pid:{$pid} not running, artica_backup not available...\n";
            continue;
        }
        break;
    }
    if (!$unix->process_exists($pid)) {
        $pid = @file_get_contents("/var/run/mysqld/mysqld.pid");
        echo "MySQL server not running...\n";
        system_admin_events("Task aborted, MySQL did not running...", __FUNCTION__, __FILE__, __LINE__, "mysql");
        return;
    }
    $t = time();
    @unlink($tmpError);
    $cmd = "{$mysqlbin} --batch --force --user={$mysql_admin}{$passwordcmdline} < {$tmpfile} >{$tmpError} 2>&1";
    if ($GLOBALS["VERBOSE"]) {
        echo "{$cmd}\n";
    }
//.........這裏部分代碼省略.........
開發者ID:BillTheBest,項目名稱:1.6.x,代碼行數:101,代碼來源:mysqldefrag.php

示例6: UFDBGUARD_STATUS

function UFDBGUARD_STATUS()
{
    $Narray = array();
    $unix = new unix();
    $array = explode("\n", @file_get_contents("/etc/ufdbguard/ufdbGuard.conf"));
    while (list($index, $line) = each($array)) {
        if (preg_match("#domainlist.+?(.+)\\/domains#", $line, $re)) {
            $datas_path = "/var/lib/squidguard/{$re[1]}/domains";
            $path = "/var/lib/squidguard/{$re[1]}/domains.ufdb";
            $size = $unix->file_size($path);
            $Narray[$path] = $size;
        }
    }
    @file_put_contents("/usr/share/artica-postfix/ressources/logs/ufdbguard.db.size.txt", serialize($Narray));
    chmod("/usr/share/artica-postfix/ressources/logs/ufdbguard.db.size.txt", 777);
    return $Narray;
}
開發者ID:brucewu16899,項目名稱:1.6.x,代碼行數:17,代碼來源:exec.squidguard.old.php

示例7: UFDBGUARD_STATUS

function UFDBGUARD_STATUS()
{
    $sock = new sockets();
    $EnableRemoteStatisticsAppliance = $sock->GET_INFO("EnableRemoteStatisticsAppliance");
    if (!is_numeric($EnableRemoteStatisticsAppliance)) {
        $EnableRemoteStatisticsAppliance = 0;
    }
    if ($EnableRemoteStatisticsAppliance == 1) {
        return;
    }
    $Narray = array();
    $unix = new unix();
    $array = explode("\n", @file_get_contents("/etc/ufdbguard/ufdbGuard.conf"));
    while (list($index, $line) = each($array)) {
        if (preg_match("#domainlist.+?(.+)\\/domains#", $line, $re)) {
            $datas_path = "/var/lib/squidguard/{$re[1]}/domains";
            $path = "/var/lib/squidguard/{$re[1]}/domains.ufdb";
            $size = $unix->file_size($path);
            $Narray[$path] = $size;
        }
    }
    @file_put_contents("/usr/share/artica-postfix/ressources/logs/ufdbguard.db.size.txt", serialize($Narray));
    chmod("/usr/share/artica-postfix/ressources/logs/ufdbguard.db.size.txt", 777);
    return $Narray;
}
開發者ID:BillTheBest,項目名稱:1.6.x,代碼行數:25,代碼來源:exec.squidguard.php

示例8: SafeBoxIncreaseSize

function SafeBoxIncreaseSize($uid)
{
    $unix = new unix();
    $safe = new safebox($uid);
    $mapper = "/dev/mapper/{$uid}";
    $SafeBox = $safe->crypted_filepath;
    $file_size = $unix->file_size($SafeBox) / 1024;
    $file_size = $file_size / 1000;
    $file_size = $file_size / 1000;
    $file_size = round($file_size);
    $increase = $safe->CryptedHomeSize - $file_size;
    writelogs("{$SafeBox} ({$uid}) {$file_size}Go increase it to {$increase}Go", __FUNCTION__, __FILE__, __LINE__);
    if ($increase < 0) {
        writelogs("Failed negative size", __FUNCTION__, __FILE__, __LINE__);
        return;
    }
    $cmd = $unix->find_program("dd") . " conv=notrunc oflag=append if=/dev/zero bs=1G count={$increase} of={$SafeBox}";
    exec($cmd, $results);
    logsArray($results, __FUNCTION__, __LINE__);
    if (!mountLoop($SafeBox)) {
        writelogs("Failed to mount loop", __FUNCTION__, __FILE__, __LINE__);
        return false;
    }
    if (!_CryptOpen($SafeBox, $GLOBALS["CRYPT_PASSWORD"])) {
        writelogs("Failed to open {$SafeBox}", __FUNCTION__, __FILE__, __LINE__);
    }
    $cmd = $unix->find_program("cryptsetup") . " resize {$uid}";
    writelogs("{$cmd}", __FUNCTION__, __FILE__, __LINE__);
    exec($cmd, $results);
    logsArray($results, __FUNCTION__, __LINE__);
    $cmd = $unix->find_program("e2fsck") . " -f /dev/mapper/{$uid}";
    writelogs("{$cmd}", __FUNCTION__, __FILE__, __LINE__);
    exec($cmd, $results);
    logsArray($results, __FUNCTION__, __LINE__);
    $cmd = $unix->find_program("resize2fs") . " -p /dev/mapper/{$uid}";
    writelogs("{$cmd}", __FUNCTION__, __FILE__, __LINE__);
    exec($cmd, $results);
    logsArray($results, __FUNCTION__, __LINE__);
    return true;
}
開發者ID:BillTheBest,項目名稱:1.6.x,代碼行數:40,代碼來源:exec.safebox.php

示例9: check_all_squid

function check_all_squid()
{
    $sock = new sockets();
    $unix = new unix();
    $syslog = new mysql_storelogs();
    $php5 = $unix->LOCATE_PHP5_BIN();
    $pidfile = "/etc/artica-postfix/pids/" . basename(__FILE__) . "." . __FUNCTION__ . ".pid";
    $timefile = "/etc/artica-postfix/pids/" . basename(__FILE__) . "." . __FUNCTION__ . ".time";
    $pid = file_get_contents("{$pidfile}");
    if (system_is_overloaded(basename(__FILE__))) {
        die;
    }
    if ($unix->process_exists($pid, basename(__FILE__))) {
        $timeMin = $unix->PROCCESS_TIME_MIN($pid);
        if ($timeMin > 240) {
            system_admin_events("Too many TTL, {$pid} will be killed", __FUNCTION__, __FILE__, __LINE__, "logrotate");
            $kill = $unix->find_program("kill");
            unix_system_kill_force($pid);
        } else {
            die;
        }
    }
    $time = $unix->file_time_min($timefile);
    if ($time < 300) {
        return;
    }
    @file_put_contents($pidfile, getmypid());
    @file_put_contents($timefile, time());
    $php = $unix->LOCATE_PHP5_BIN();
    $bzip2 = $unix->find_program("bzip2");
    $ALREADYCOMP["gz"] = true;
    $ALREADYCOMP["bz2"] = true;
    $LogRotateCompress = 1;
    $LogRotatePath = $sock->GET_INFO("LogRotatePath");
    $ApacheLogRotate = $sock->GET_INFO("ApacheLogRotate");
    if (!is_numeric($ApacheLogRotate)) {
        $ApacheLogRotate = 1;
    }
    if ($LogRotatePath == null) {
        $LogRotatePath = "/home/logrotate";
    }
    $LogsRotateDefaultSizeRotation = $sock->GET_INFO("LogsRotateDefaultSizeRotation");
    if (!is_numeric($LogsRotateDefaultSizeRotation)) {
        $LogsRotateDefaultSizeRotation = 100;
    }
    foreach (glob("/var/log/squid/*") as $filename) {
        if (is_dir($filename)) {
            continue;
        }
        $size = $unix->file_size($filename);
        $time = $unix->file_time_min($filename);
        $size = round($size / 1024 / 1000, 2);
        if ($size > $LogsRotateDefaultSizeRotation) {
            if ($filename == "/var/log/squid/access.log") {
                events("{$filename} -> is a production log for Squid, launch the rotation procedure.");
                squid_admin_mysql(1, "{$filename} {$size}M exceed {$LogsRotateDefaultSizeRotation}M, launch rotation", null, __FILE__, __LINE__);
                shell_exec("{$php} /usr/share/artica-postfix/exec.squid.php --rotate");
                continue;
            }
            $TOROT[$filename] = true;
            events("{$filename} -> Add to queue {$size}M exceed {$LogsRotateDefaultSizeRotation}M");
            continue;
        }
        if ($time > 1440) {
            if ($filename == "/var/log/squid/access.log") {
                events("{$filename} -> is a production log for Squid, launch the rotation procedure.");
                squid_admin_mysql(1, "{$filename} {$size}M exceed {$LogsRotateDefaultSizeRotation}M, launch rotation", null, __FILE__, __LINE__);
                shell_exec("{$php} /usr/share/artica-postfix/exec.squid.php --rotate");
                continue;
            }
            events("{$filename} -> Add to queue {$time}mn exceed 1440mn");
            $TOROT[$filename] = true;
            continue;
        }
    }
    if (count($TOROT) == 0) {
        return;
    }
    while (list($filename, $none) = each($TOROT)) {
        $extension = pathinfo($filename, PATHINFO_EXTENSION);
        $filedate = date('Y-m-d H:i:s', filemtime($filename));
        $basename = basename($filename);
        if (preg_match("#sarg\\.#", $filename)) {
            shell_exec("{$php5} " . dirname(__FILE__) . "/exec.sarg.php --rotate {$basename} >/dev/null 2>&1 &");
            continue;
        }
        if (preg_match("#access\\.log\\.[0-9]+\$#", $filename)) {
            continue;
        }
        if ($extension != "gz") {
            if (!$unix->compress($filename, "{$filename}.gz")) {
                continue;
            }
            $filename = $filename . ".gz";
            $extension = "gz";
        }
        echo "[{$filedate}]: {$filename} ({$extension})\n";
        if ($syslog->ROTATE_TOMYSQL($filename, $filedate)) {
            @unlink($filename);
        }
//.........這裏部分代碼省略.........
開發者ID:brucewu16899,項目名稱:1.6.x,代碼行數:101,代碼來源:exec.logrotate.php

示例10: backup_md5

function backup_md5($md5)
{
    $sock = new sockets();
    $unix = new unix();
    $q = new mysql();
    $backend_root = "/root/.offlineimap";
    $pidfile = "/var/run/offlineimap-{$md5}.pid";
    $pid = @file_get_contents($pidfile);
    if ($unix->process_exists($pid)) {
        $timemin = $unix->PROCCESS_TIME_MIN($pid);
        $timefile = buildlogs("PID {$pid} running since {$timemin}mn , aborting", __FUNCTION__, __LINE__);
        LogsToMysqlMD5($md5);
        return;
    }
    $mypid = getmypid();
    @file_put_contents($pidfile, $mypid);
    if ($GLOBALS["VERBOSE"]) {
        echo "{$pidfile} -> {$mypid}\n";
    }
    $OfflineImapBackupTool = $sock->GET_INFO("OfflineImapBackupTool");
    if (!is_numeric($OfflineImapBackupTool)) {
        $OfflineImapBackupTool = 0;
    }
    $sql = "SELECT * FROM mbxs_backup WHERE zmd5='{$md5}'";
    $ligne = @mysql_fetch_array($q->QUERY_SQL($sql, 'artica_backup'));
    if (!$q->ok) {
        buildlogs("{$q->mysql_error}", __FUNCTION__, __LINE__);
        LogsToMysqlMD5($md5);
        return;
    }
    $uid = $ligne["uid"];
    $account = $ligne["account"];
    $imapserv = $ligne["imapserv"];
    $MySqlQuery = $ligne;
    $OfflineImapWKDir = $sock->GET_INFO("OfflineImapWKDir");
    $OfflineImapBackupDir = $sock->GET_INFO("OfflineImapBackupDir");
    if ($OfflineImapBackupDir == null) {
        $OfflineImapBackupDir = "%HOME%/mailbackups";
    }
    if ($OfflineImapWKDir == null) {
        $OfflineImapWKDir = "/home/artica/mailbackups";
    }
    if ($OfflineImapBackupTool == 0) {
        buildlogs("This feature is disabled, aborting", __FUNCTION__, __LINE__);
        LogsToMysqlMD5($md5);
        return;
    }
    $fileZ = build_remote_backup_settings($MySqlQuery);
    $fileConf = $fileZ[0];
    $TargetDir = $fileZ[1];
    $logfile = "/var/log/" . basename($unix->FILE_TEMP());
    if (!is_file($fileConf)) {
        LogsToMysqlMD5($md5);
        return;
    }
    if (!is_dir($TargetDir)) {
        buildlogs("{$TargetDir} no such directory", __FUNCTION__, __LINE__);
        LogsToMysqlMD5($md5);
        return;
    }
    $offlineimap = $unix->find_program("offlineimap");
    $tar = $unix->find_program("tar");
    $rm = $unix->find_program("rm");
    $NICE = EXEC_NICE();
    $t = time();
    $CacheLocal = "{$backend_root}/Account-{$ligne["uid"]}";
    $CacheRemote = "{$backend_root}/Account-{$ligne["account"]}";
    if (is_dir($CacheLocal)) {
        shell_exec("{$rm} -rf {$CacheLocal}");
    }
    if (is_dir($CacheRemote)) {
        shell_exec("{$rm} -rf {$CacheRemote}");
    }
    $cmd = "{$NICE}{$offlineimap} -u basic -c {$fileConf} -l {$logfile} 2>&1";
    exec($cmd, $results);
    if (count($results) > 0) {
        while (list($num, $ligne) = each($results)) {
            buildlogs($ligne, __FUNCTION__, __LINE__);
        }
    }
    $results = explode("\n", @file_get_contents($logfile));
    if (count($results) > 0) {
        while (list($num, $ligne) = each($results)) {
            buildlogs($ligne, __FUNCTION__, __LINE__);
        }
    }
    @unlink($logfile);
    $offlimap = new offlineimap();
    $FinalDir = $offlimap->maildir_parse($OfflineImapBackupDir, $uid);
    @mkdir($FinalDir, 0755, true);
    $FinalFile = "{$FinalDir}/" . date("YmdH") . "-{$account}@{$imapserv}.tar.bz2";
    chdir($TargetDir);
    $cmd = "{$tar} -cjf {$FinalFile} *";
    shell_exec($cmd);
    chdir("/root");
    $cmd = "{$rm} -rf {$TargetDir}/";
    shell_exec($cmd);
    $FinalFileSize = $unix->file_size_human($FinalFile);
    buildlogs("{$FinalFile}: {$FinalFileSize}", __FUNCTION__, __LINE__);
    buildlogs("Execution done took:" . $unix->distanceOfTimeInWords($t, time()), __FUNCTION__, __LINE__);
//.........這裏部分代碼省略.........
開發者ID:BillTheBest,項目名稱:1.6.x,代碼行數:101,代碼來源:exec.offlineimap.php

示例11: scan

function scan($aspid = false)
{
    $unix = new unix();
    $sock = new sockets();
    $q = new mysql_squid_builder();
    if (!$aspid) {
        $pidfile = "/etc/artica-postfix/pids/" . basename(__FILE__) . "." . __FUNCTION__ . ".pid";
        $pid = @file_get_contents($pidfile);
        if ($pid < 100) {
            $pid = null;
        }
        if ($unix->process_exists($pid, basename(__FILE__))) {
            $timepid = $unix->PROCCESS_TIME_MIN($pid);
            events("Already executed pid {$pid} since {$timepid}Mn");
            return;
        }
        @file_put_contents($pidfile, time());
    }
    if (!tests_nas()) {
        return;
    }
    $SquidOldLogsNAS = unserialize(base64_decode($sock->GET_INFO("SquidOldLogsNAS")));
    $mountPoint = "/mnt/SquidImportLogs";
    $NasFolder = $SquidOldLogsNAS["folder"];
    $NasFolder = str_replace('\\', '/', $NasFolder);
    $NasFolder = str_replace('//', '/', $NasFolder);
    if (strpos($NasFolder, "/") > 0) {
        $f = explode("/", $NasFolder);
        unset($f[0]);
        $NasFolder = @implode("/", $f);
    }
    $WORKDIR = "{$mountPoint}/{$NasFolder}";
    $WORKDIR = str_replace("//", "/", $WORKDIR);
    if (!is_dir($WORKDIR)) {
        events("!!! Fatal {$WORKDIR}, nu such directory...");
        return;
    }
    if (!($handle = opendir($WORKDIR))) {
        return;
    }
    $countDeFiles = 0;
    $array = array();
    if (!$q->FIELD_EXISTS("accesslogs_import", "lnumbers")) {
        $q->QUERY_SQL("ALTER IGNORE TABLE `accesslogs_import` ADD `lnumbers` BIGINT UNSIGNED ,ADD INDEX( `lnumbers` )");
    }
    while (false !== ($filename = readdir($handle))) {
        if ($filename == ".") {
            continue;
        }
        if ($filename == "..") {
            continue;
        }
        $targetFile = "{$WORKDIR}/{$filename}";
        $countDeFiles++;
        $md5 = md5_file($targetFile);
        events("{$targetFile} MD5:{$md5}");
        $ligne = mysql_fetch_array($q->QUERY_SQL("SELECT filename FROM accesslogs_import WHERE zmd5='{$md5}'"));
        if (!$q->ok) {
            echo $q->mysql_error;
            killNas();
            return;
        }
        if ($GLOBALS["VERBOSE"]) {
            echo "{$md5} = {$ligne["filename"]}\n";
        }
        $ext = $unix->file_ext($targetFile);
        if ($ext == "gz") {
            @mkdir("/home/squid/wkdir", 0755, true);
            if ($GLOBALS["VERBOSE"]) {
                echo "Uncompress {$targetFile}\n";
            }
            $unix->uncompress($targetFile, "/home/squid/wkdir/{$filename}");
            $date = GetDateOfFile("/home/squid/wkdir/{$filename}");
            $lnumbers = $unix->COUNT_LINES_OF_FILE("/home/squid/wkdir/{$filename}");
            @unlink("/home/squid/wkdir/{$filename}");
        } else {
            $date = GetDateOfFile($targetFile);
            $lnumbers = $unix->COUNT_LINES_OF_FILE($targetFile);
        }
        if ($date == null) {
            events("{$targetFile} = No date");
            continue;
        }
        if ($lnumbers == 0) {
            events("{$targetFile} = No Lines");
            continue;
        }
        if (trim($ligne["filename"]) != null) {
            $q->QUERY_SQL("UPDATE accesslogs_import SET zDate='{$date}', lnumbers='{$lnumbers}' WHERE zmd5='{$md5}'");
            if (!$q->ok) {
                events("{$q->mysql_error}");
                killNas();
                return;
            }
            continue;
        }
        $size = $unix->file_size($targetFile);
        events("Found new file to analyze {$targetFile} - {$md5} ({$date}) " . round($size / 1024 / 1024) . "MB");
        $q->QUERY_SQL("INSERT INTO accesslogs_import (zmd5,filename,zDate,size,status,percent,lnumbers) VALUES ('{$md5}','{$filename}','{$date}','{$size}',0,0,{$lnumbers})");
        if (!$q->ok) {
//.........這裏部分代碼省略.........
開發者ID:brucewu16899,項目名稱:1.6.x,代碼行數:101,代碼來源:exec.squid.logs.import.php

示例12: ScanDirs

function ScanDirs()
{
    $sock = new sockets();
    $ZarafaBackupParams = unserialize(base64_decode($sock->GET_INFO("ZarafaBackupParams")));
    if ($ZarafaBackupParams["DEST"] == null) {
        $ZarafaBackupParams["DEST"] = "/home/zarafa-backup";
    }
    if (!is_numeric($ZarafaBackupParams["DELETE_OLD_BACKUPS"])) {
        $ZarafaBackupParams["DELETE_OLD_BACKUPS"] = 1;
    }
    if (!is_numeric($ZarafaBackupParams["DELETE_BACKUPS_OLDER_THAN_DAYS"])) {
        $ZarafaBackupParams["DELETE_BACKUPS_OLDER_THAN_DAYS"] = 10;
    }
    $unix = new unix();
    $directories = $unix->dirdir($ZarafaBackupParams["DEST"]);
    while (list($directory, $ext) = each($directories)) {
        if (is_file("{$directory}/zarafa.gz")) {
            $Gooddirs[$directory] = true;
        }
    }
    $q = new mysql();
    $q->QUERY_SQL("TRUNCATE TABLE zarafa_backup", "artica_backup");
    $prefix = "INSERT INTO zarafa_backup (`filepath`,`filesize`,`ztime`,`zDate`) VALUES ";
    while (list($directory, $ext) = each($Gooddirs)) {
        $date = null;
        $stamp = "{$directory}/took.txt";
        $datestamp = "{$directory}/time.txt";
        $size = $unix->file_size("{$directory}/zarafa.gz");
        if (is_file($datestamp)) {
            $date = @file_get_contents($datestamp);
        }
        if ($date == null) {
            $date = date("Y-m-d H:i:s", filemtime("{$directory}/zarafa.gz"));
        }
        if (is_file($stamp)) {
            $took = @file_get_contents($stamp);
        }
        if ($GLOBALS["VERBOSE"]) {
            $sizeDBG = round($size / 1024 / 1000, 2);
            echo "Found: Container saved on: {$date} took:{$took} {$directory}/zarafa.gz Size:{$sizeDBG} MB\n";
        }
        $directory = mysql_escape_string2($directory);
        $f[] = "('{$directory}','{$size}','{$took}','{$date}')";
    }
    if (count($f) > 0) {
        $sql = "{$prefix}" . @implode(",", $f);
        $q->QUERY_SQL($sql, "artica_backup");
        if (!$q->ok) {
            system_admin_events("Fatal {$q->mysql_error}", __FUNCTION__, __FILE__, __LINE__, "backup");
        }
    }
    echo count($f) . " container(s) found...\n";
}
開發者ID:BillTheBest,項目名稱:1.6.x,代碼行數:53,代碼來源:exec.zarafa-backup.php

示例13: moveolds2

function moveolds2()
{
    $sock = new sockets();
    $LogsDirectoryStorage = $sock->GET_INFO("LogsDirectoryStorage");
    if (trim($LogsDirectoryStorage) == null) {
        $LogsDirectoryStorage = "/home/logs-backup";
    }
    $unix = new unix();
    $mv = $unix->find_program("mv");
    $php5 = $unix->LOCATE_PHP5_BIN();
    $nohup = $unix->find_program("nohup");
    if ($GLOBALS["VERBOSE"]) {
        echo "Scanning /var/log....\n";
    }
    $d = $unix->DirFiles("/var/log", "(.+)-[0-9]+");
    @mkdir("{$LogsDirectoryStorage}/olds", 0755, true);
    $delete = 0;
    $size = 0;
    $CountDeFiles = count($d);
    while (list($num, $path) = each($d)) {
        $time = $unix->file_time_min("/var/log/{$path}");
        if ($time > 7200) {
            $delete++;
            $size = $size + $unix->file_size("/var/log/{$path}");
            $targetFile = "{$LogsDirectoryStorage}/olds/{$path}";
            if (is_file("{$targetFile}")) {
                $targetFile = $targetFile . "." . time();
            }
            shell_exec("{$mv} /var/log/{$path} {$targetFile}");
        }
    }
    if ($delete > 0) {
        $size = FormatBytes($size / 1024);
        system_admin_events("Moving {$delete}/{$CountDeFiles} old log file to {$LogsDirectoryStorage}/olds ({$size})", __FUNCTION__, __FILE__, __LINE__, "logrotate");
    }
    $delete = 0;
    $size = 0;
    if ($GLOBALS["VERBOSE"]) {
        echo "Scanning /var/log/artica-postfix/loadavg....\n";
    }
    $d = $unix->DirFiles("/var/log/artica-postfix/loadavg");
    $CountDeFiles = count($d);
    while (list($num, $path) = each($d)) {
        usleep(700);
        $time = $unix->file_time_min("/var/log/artica-postfix/loadavg/{$path}");
        if ($time > 7200) {
            $size = $size + $unix->file_size("/var/log/artica-postfix/loadavg/{$path}");
            @unlink("/var/log/artica-postfix/loadavg/{$path}");
            $delete++;
        }
    }
    if ($delete > 0) {
        $size = FormatBytes($size / 1024);
        system_admin_events("{$delete}/{$CountDeFiles} deleted old files in /var/log/artica-postfix/loadavg ({$size} free)", __FUNCTION__, __FILE__, __LINE__, "logrotate");
    }
    // Page Peeker
    if ($GLOBALS["VERBOSE"]) {
        echo "Scanning /var/log/artica-postfix/pagepeeker....\n";
    }
    $delete = 0;
    $size = 0;
    $d = $unix->DirFiles("/var/log/artica-postfix/pagepeeker");
    $CountDeFiles = count($d);
    if ($GLOBALS["VERBOSE"]) {
        echo "Scanning /var/log/artica-postfix/pagepeeker -> {$CountDeFiles} files....\n";
    }
    while (list($num, $path) = each($d)) {
        usleep(700);
        $time = $unix->file_time_min("/var/log/artica-postfix/pagepeeker/{$path}");
        if ($time > 7200) {
            $size = $size + $unix->file_size("/var/log/artica-postfix/pagepeeker/{$path}");
            @unlink("/var/log/artica-postfix/pagepeeker/{$path}");
            $delete++;
        }
    }
    if ($delete > 0) {
        $size = FormatBytes($size / 1024);
        system_admin_events("{$CountDeFiles}/{$delete} deleted old files in /var/log/artica-postfix/pagepeeker ({$size} free)", __FUNCTION__, __FILE__, __LINE__, "logrotate");
    }
}
開發者ID:BillTheBest,項目名稱:1.6.x,代碼行數:80,代碼來源:exec.logrotate.php

示例14: update_remote_file

function update_remote_file($BASE_URI, $filename, $md5, $prc)
{
    if (!isset($GLOBALS["UFDB_SIZE"])) {
        $GLOBALS["UFDB_SIZE"] = 0;
    }
    WriteMyLogs("update_remote_file({$BASE_URI},{$filename},{$md5})", __FUNCTION__, __FILE__, __LINE__);
    $STATUS = unserialize(@file_get_contents("/etc/artica-postfix/TLSE_LAST_DOWNLOAD"));
    $indexuri = "{$BASE_URI}/{$filename}";
    $unix = new unix();
    $q = new mysql_squid_builder();
    $tar = $unix->find_program("tar");
    $rm = $unix->find_program("rm");
    $ln = $unix->find_program("ln");
    $ufdbGenTable = $unix->find_program("ufdbGenTable");
    $Conversion = $q->TLSE_CONVERTION();
    $ufdb = new compile_ufdbguard();
    $curl = new ccurl($indexuri);
    $curl->Timeout = 360;
    echo "Downloading {$indexuri}\n";
    $cache_temp = "/tmp/{$filename}";
    if (!$curl->GetFile($cache_temp)) {
        build_progress("Fatal error downloading {$indexuri} {$curl->error}", $prc);
        echo "Fatal error downloading {$indexuri} {$curl->error}\n";
        $errorDetails = @implode("\n", $GLOBALS["CURLDEBUG"]);
        artica_update_event(0, "Web filtering databases, unable to download {$indexuri}", "Fatal error downloading {$indexuri} {$curl->error}\n{$errorDetails}", __FILE__, __LINE__);
        return;
    }
    $filesize = $unix->file_size($cache_temp);
    $GLOBALS["UFDB_SIZE"] = $GLOBALS["UFDB_SIZE"] + $filesize;
    @mkdir("/var/lib/ftpunivtlse1fr", 755, true);
    $categoryname = str_replace(".tar.gz", "", $filename);
    $categoryDISK = $categoryname;
    if (isset($Conversion[$categoryname])) {
        $categoryDISK = $Conversion[$categoryname];
    }
    $STATUS["LAST_DOWNLOAD"]["TIME"] = time();
    $STATUS["LAST_DOWNLOAD"]["CATEGORY"] = $categoryname;
    $STATUS["LAST_DOWNLOAD"]["SIZE"] = $GLOBALS["CURL_LAST_SIZE_DOWNLOAD"] / 1024;
    @file_put_contents("/etc/artica-postfix/TLSE_LAST_DOWNLOAD", serialize($STATUS));
    $categoryDISK = str_replace("/", "_", $categoryDISK);
    if (is_link("/var/lib/ftpunivtlse1fr/{$categoryname}")) {
        if ($GLOBALS["VERBOSE"]) {
            echo "/var/lib/ftpunivtlse1fr/{$categoryname} is a link of " . @readlink("/var/lib/ftpunivtlse1fr/{$categoryname}") . "\n";
        }
        if ($GLOBALS["VERBOSE"]) {
            echo "Removing  /var/lib/ftpunivtlse1fr/{$categoryname}/\n";
        }
        shell_exec("{$rm} -rf /var/lib/ftpunivtlse1fr/{$categoryname}");
    }
    if (is_dir("/var/lib/ftpunivtlse1fr/{$categoryname}")) {
        if ($GLOBALS["VERBOSE"]) {
            echo "Removing  /var/lib/ftpunivtlse1fr/{$categoryname}/\n";
        }
        shell_exec("{$rm} -rf /var/lib/ftpunivtlse1fr/{$categoryname}");
    }
    if ($GLOBALS["VERBOSE"]) {
        echo "Creating  /var/lib/ftpunivtlse1fr/{$categoryname}/\n";
    }
    @mkdir("/var/lib/ftpunivtlse1fr/{$categoryname}", 0755, true);
    if ($GLOBALS["VERBOSE"]) {
        echo "Extracting {$cache_temp} to  /var/lib/ftpunivtlse1fr/\n";
    }
    shell_exec("{$tar} -xf {$cache_temp} -C /var/lib/ftpunivtlse1fr/");
    if (!is_file("/var/lib/ftpunivtlse1fr/{$categoryname}/domains")) {
        build_progress("Fatal!!: {$categoryname}/domains no such file", $prc);
        ufdbevents("Fatal!!: /var/lib/ftpunivtlse1fr/{$categoryname}/domains no such file", __FUNCTION__, __FILE__, __LINE__);
        return;
    }
    $CountDeSitesFile = CountDeSitesFile("/var/lib/ftpunivtlse1fr/{$categoryname}/domains");
    if ($GLOBALS["VERBOSE"]) {
        echo "/var/lib/ftpunivtlse1fr/{$categoryname}/domains -> {$CountDeSitesFile} websites\n";
    }
    if ($CountDeSitesFile == 0) {
        build_progress("Fatal!!: {$categoryname}/domains corrupted, no website", $prc);
        ufdbevents("Fatal!!: /var/lib/ftpunivtlse1fr/{$categoryname}/domains corrupted, no website", __FUNCTION__, __FILE__, __LINE__, "Toulouse DB");
        shell_exec("{$rm} -rf /var/lib/ftpunivtlse1fr/{$categoryname}");
        return;
    }
    if (trim(strtolower($categoryDISK)) != trim(strtolower($categoryname))) {
        if (is_dir("/var/lib/ftpunivtlse1fr/{$categoryDISK}")) {
            shell_exec("{$rm} -rf /var/lib/ftpunivtlse1fr/{$categoryDISK}");
        }
        shell_exec("ln -sf /var/lib/ftpunivtlse1fr/{$categoryDISK} /var/lib/ftpunivtlse1fr/{$categoryname}");
    }
    $q->QUERY_SQL("DELETE FROM ftpunivtlse1fr WHERE filename='{$filename}'");
    if (!$q->ok) {
        ufdbevents("Fatal!!: {$q->mysql_error}", __FUNCTION__, __FILE__, __LINE__, "Toulouse DB");
        return;
    }
    $q->QUERY_SQL("INSERT INTO ftpunivtlse1fr (`filename`,`zmd5`,`websitesnum`) VALUES ('{$filename}','{$md5}','{$CountDeSitesFile}')");
    if (!$q->ok) {
        ufdbevents("Fatal!!: {$q->mysql_error}", __FUNCTION__, __FILE__, __LINE__, "Toulouse DB");
        return;
    }
    $GLOBALS["UFDB_COUNT_OF_DOWNLOADED"] = $GLOBALS["UFDB_COUNT_OF_DOWNLOADED"] + 1;
    build_progress("{$categoryname} {$CountDeSitesFile} websites", $prc);
    $GLOBALS["squid_admin_mysql"][] = "Success updating category `{$categoryname}` with {$CountDeSitesFile} websites";
    if ($GLOBALS["VERBOSE"]) {
        echo "ufdbGenTable={$ufdbGenTable}\n";
    }
//.........這裏部分代碼省略.........
開發者ID:brucewu16899,項目名稱:1.6.x,代碼行數:101,代碼來源:exec.update.squid.tlse.php

示例15: scan_artica_databases

function scan_artica_databases()
{
    $unix = new unix();
    $URIBASE = $unix->MAIN_URI();
    $tmpdir = $unix->TEMP_DIR();
    $curl = new ccurl("{$URIBASE}/catz/index.txt");
    if (!$curl->GetFile("{$tmpdir}/index.txt")) {
        squid_admin_mysql(0, "BLACKLISTS: Failed to retreive {$URIBASE}/catz/index.txt ", $curl->error, __FUNCTION__, __LINE__);
        artica_update_event(0, "BLACKLISTS: Failed to retreive {$URIBASE}/catz/index.txt ", $curl->error, __FUNCTION__, __LINE__);
        echo "BLACKLISTS: Failed to retreive {$URIBASE}/catz/index.txt ({$curl->error})\n";
        return;
    }
    $fIndex = unserialize(base64_decode(@file_get_contents("{$tmpdir}/index.txt")));
    //print_r($fIndex);
    $time = $fIndex["TIME"];
    $q = new mysql_squid_builder();
    //webfilters_databases_disk
    $prefix = "INSERT IGNORE INTO webfilters_databases_disk (`filename`,`size`,`category`,`filtime`) VALUES ";
    $unix = new unix();
    $dirs = $unix->dirdir($GLOBALS["WORKDIR_LOCAL"]);
    if ($GLOBALS["VERBOSE"]) {
        echo "Scanning " . count($dirs) . " files last pattern was " . date("Y-m-d H:i:s", $time) . "\n";
    }
    $sizz = 0;
    while (list($path, $path2) = each($dirs)) {
        $size = $unix->file_size("{$path2}/domains.ufdb");
        $category = basename($path);
        $sizz = $sizz + $size;
        if ($GLOBALS["VERBOSE"]) {
            echo "{$category} `{$path2}/domains.ufdb` = " . $size / 1024 . " Kb\n";
        }
        $category = $q->filaname_tocat("{$path2}/domains.ufdb");
        $filtime = filemtime("{$path2}/domains.ufdb");
        $f[] = "('{$path2}/domains.ufdb','{$size}','{$category}','{$filtime}')";
    }
    if ($GLOBALS["VERBOSE"]) {
        echo "scanned " . count($f) . " files\n";
    }
    if (count($f) > 0) {
        $sql = $prefix . @implode(",", $f);
        if (!$q->TABLE_EXISTS("webfilters_databases_disk")) {
            $q->CheckTables();
        }
        $q->QUERY_SQL("TRUNCATE TABLE webfilters_databases_disk");
        $q->CheckTables();
        $q->QUERY_SQL($sql);
        if (!$q->ok) {
            squid_admin_mysql(0, "{$q->mysql_error}", null, __FUNCTION__, __LINE__);
            artica_update_event(0, "{$q->mysql_error}", null, __FUNCTION__, __LINE__);
        }
    }
}
開發者ID:brucewu16899,項目名稱:1.6.x,代碼行數:52,代碼來源:exec.squid.blacklists.php


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