]> git.datanom.net - qtadmin.git/commitdiff
Handle multi action button
authorMichael Rasmussen <mir@datanom.net>
Tue, 2 Jun 2015 23:05:07 +0000 (01:05 +0200)
committerMichael Rasmussen <mir@datanom.net>
Tue, 2 Jun 2015 23:05:07 +0000 (01:05 +0200)
js/checkbox.js
quarantine.php

index d0088038f6bc377bbef6ae8da9130feb5ae1bc1c..fab9f77b6ae46d49367984134f18c37988009ed5 100644 (file)
@@ -4,7 +4,7 @@ function checkAction() {
     var ids = '';
     var c = document.getElementsByName('action');
     for (var i = 0; i < c.length; i++) {
-        if (c[i].type == 'checkbox' and c[i].checked == true) {
+        if (c[i].type == 'checkbox' && c[i].checked == true) {
             if (ids == '') {
                 ids = c[i].value;
             } else {
index 9155602572f191444ffa255d6af3942217724f9d..25529956e07b1f27dfc677e1975feab895408206 100644 (file)
         echo $util->getFooter();
     }
 
+    function handleRequest($request, $ids) {
+        $query = array();
+        foreach ($ids as $id) {
+            $mail_id = urldecode($id);
+            $mail = unserialize($_SESSION['mailInfo']["$mail_id"]);
+            $secret_id = $mail->secret_id;
+            $recipient = $mail->recipient;
+            echo "$mail_id $secret_id $recipient";
+/*
+            if ($request == 'release') {
+                $amavisserver = $CFG->amavisd_db_host;
+                $policy_port = $CFG->amavis_policy_port;
+
+                $fp = fsockopen($amavisserver, $policy_port, $errno, $errstr, 30);
+                if (!$fp) {
+                    error("$errstr ($errno)");
+                    exit;
+                }
+                $out = "request=" . $request . "\r\n";
+                $out .= "mail_id=" . $mail_id . "\r\n";
+                $out .= "recipient=" . $recipient . "\r\n";
+                $out .= "secret_id=" . $secret_id . "\r\n\r\n";
+                fwrite($fp, $out);
+                $response = fread($fp, 8192);
+                fclose($fp);
+                $response = urldecode($response);
+                if (! preg_match("/^setreply=250\s+([\d\.]+)\s+(.*)/", $response, $matches)) {
+                    error("Request to release failed [$out][$response]");
+                    exit;
+                }
+                if ($matches[1] != '2.0.0') {
+                    error($matches[2]);
+                    exit;
+                }
+
+                $query[] = "UPDATE msgrcpt SET rs = 'R' WHERE mail_id = '$mail_id'";
+            } else if ($request == 'delete') {
+                $query[] = "UPDATE msgrcpt SET rs = 'D' WHERE mail_id = '$mail_id'";
+            } else {
+                error("Unknown operation [$request]");
+                exit;
+            }
+*/
+        }
+    }
+
     $util = Utils::getInstance();
     $loggedIn = $util->isLoggedIn();
     $request = isset($_GET['op']) ? $_GET['op'] : '';
     if ($loggedIn && isset($_GET['id'])) {
-        $mail_id = urldecode($_GET['id']);
+        $ids = explode(',', $_GET['id']);
+        $query = handleRequest($request, $ids);
+        exit;
+/*        $mail_id = urldecode($_GET['id']);
         $mail = unserialize($_SESSION['mailInfo']["$mail_id"]);
         $secret_id = $mail->secret_id;
         $recipient = $mail->recipient;
         } else {
             error("Unknown operation [$request]");
             exit;
-        }
+        }*/
         $success = $DB->update($query);
         if (! $success) {
             error("Message not released, contact administrator [$query]");
This page took 0.034279 seconds and 5 git commands to generate.