From a3b85d7b8560cdc1057fcaffa3acbd247b4b5b7a Mon Sep 17 00:00:00 2001
From: Thomas B. <thomas@roundcube.net>
Date: Mon, 07 Oct 2013 13:19:03 -0400
Subject: [PATCH] Merge pull request #133 from cwickert/release-0.9-canned-responses

---
 plugins/password/drivers/vpopmaild.php |   66 +++++++++++++++++----------------
 1 files changed, 34 insertions(+), 32 deletions(-)

diff --git a/plugins/password/drivers/vpopmaild.php b/plugins/password/drivers/vpopmaild.php
index b6fb393..6c1a9ee 100644
--- a/plugins/password/drivers/vpopmaild.php
+++ b/plugins/password/drivers/vpopmaild.php
@@ -5,47 +5,49 @@
  *
  * Driver to change passwords via vpopmaild
  *
- * @version 1.1
+ * @version 2.0
  * @author Johannes Hessellund
  *
  */
 
-function password_save($curpass, $passwd)
+class rcube_vpopmaild_password
 {
-    $rcmail = rcmail::get_instance();
-//    include('Net/Socket.php');
-    $vpopmaild = new Net_Socket();
+    function save($curpass, $passwd)
+    {
+        $rcmail = rcmail::get_instance();
+    //    include('Net/Socket.php');
+        $vpopmaild = new Net_Socket();
 
-    if (PEAR::isError($vpopmaild->connect($rcmail->config->get('password_vpopmaild_host'),
-	    $rcmail->config->get('password_vpopmaild_port'), null))) {
-        return PASSWORD_CONNECT_ERROR;
-    }
+        if (PEAR::isError($vpopmaild->connect($rcmail->config->get('password_vpopmaild_host'),
+            $rcmail->config->get('password_vpopmaild_port'), null))) {
+            return PASSWORD_CONNECT_ERROR;
+        }
 
-    $result = $vpopmaild->readLine();
-    if(!preg_match('/^\+OK/', $result)) {
-        $vpopmaild->disconnect();
-        return PASSWORD_CONNECT_ERROR;
-    }
+        $result = $vpopmaild->readLine();
+        if(!preg_match('/^\+OK/', $result)) {
+            $vpopmaild->disconnect();
+            return PASSWORD_CONNECT_ERROR;
+        }
 
-    $vpopmaild->writeLine("slogin ". $_SESSION['username'] . " " . $curpass);
-    $result = $vpopmaild->readLine();
-    if(!preg_match('/^\+OK/', $result) ) {
+        $vpopmaild->writeLine("slogin ". $_SESSION['username'] . " " . $curpass);
+        $result = $vpopmaild->readLine();
+
+        if(!preg_match('/^\+OK/', $result) ) {
+            $vpopmaild->writeLine("quit");
+            $vpopmaild->disconnect();
+            return PASSWORD_ERROR;
+        }
+
+        $vpopmaild->writeLine("mod_user ". $_SESSION['username']);
+        $vpopmaild->writeLine("clear_text_password ". $passwd);
+        $vpopmaild->writeLine(".");
+        $result = $vpopmaild->readLine();
         $vpopmaild->writeLine("quit");
         $vpopmaild->disconnect();
-        return PASSWORD_ERROR;
+
+        if (!preg_match('/^\+OK/', $result))
+            return PASSWORD_ERROR;
+
+        return PASSWORD_SUCCESS;
     }
-
-    $vpopmaild->writeLine("mod_user ". $_SESSION['username']);
-    $vpopmaild->writeLine("clear_text_password ". $passwd);
-    $vpopmaild->writeLine(".");
-    $result = $vpopmaild->readLine();
-    $vpopmaild->writeLine("quit");
-    $vpopmaild->disconnect();
-
-    if (!preg_match('/^\+OK/', $result))
-        return PASSWORD_ERROR;
-
-    return PASSWORD_SUCCESS;
 }
-
-?>

--
Gitblit v1.9.1