summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAleksander Machniak <alec@alec.pl>2014-07-16 14:57:29 +0200
committerAleksander Machniak <alec@alec.pl>2014-07-16 14:57:29 +0200
commit97d853738a59c55a6a44aa4fca622f8af05f0de6 (patch)
tree5c5ea61263b2566b0a87784d1c14bc6e20e2fdb0
parent0a96bdf74d829cd230718243eeb733ad4e71bf5a (diff)
parent1599665651a3e6e259091e3f9576c47c06b20a30 (diff)
Merge pull request #203 from mdamt/gearman-password
New gearman driver for password plugin
-rw-r--r--plugins/password/config.inc.php.dist5
-rw-r--r--plugins/password/drivers/gearman.php50
2 files changed, 55 insertions, 0 deletions
diff --git a/plugins/password/config.inc.php.dist b/plugins/password/config.inc.php.dist
index 16b7f9317..d979a1901 100644
--- a/plugins/password/config.inc.php.dist
+++ b/plugins/password/config.inc.php.dist
@@ -367,3 +367,8 @@ $config['password_expect_params'] = '';
$config['password_smb_host'] = 'localhost';
// Location of smbpasswd binary
$config['password_smb_cmd'] = '/usr/bin/smbpasswd';
+
+// gearman driver options
+// ---------------------
+// Gearman host (default: localhost)
+$config['password_gearman_host'] = 'localhost';
diff --git a/plugins/password/drivers/gearman.php b/plugins/password/drivers/gearman.php
new file mode 100644
index 000000000..6c1ad3cf0
--- /dev/null
+++ b/plugins/password/drivers/gearman.php
@@ -0,0 +1,50 @@
+<?php
+/**
+ * Gearman Password Driver
+ *
+ * Payload is json string containing username, oldPassword and newPassword
+ * Return value is a json string saying result: true if success.
+ *
+ * @version 1.0
+ * @author Mohammad Anwari <mdamt@mdamt.net>
+ */
+
+class rcube_gearman_password
+{
+ function save($currpass, $newpass)
+ {
+ $user = $_SESSION['username'];
+ $rcmail = rcmail::get_instance();
+
+ if (extension_loaded('gearman')) {
+ $success = false;
+ $gmc= new GearmanClient();
+
+ $gmc->addServer($rcmail->config->get('password_gearman_host'));
+ $payload = array("username" => $user, "oldPassword" => $currpass, "newPassword" => $newpass);
+ $result = $gmc->doNormal("setPassword", json_encode($payload));
+ $success = json_decode($result);
+ if ($success->result == 1) {
+ return PASSWORD_SUCCESS;
+ } else {
+ rcube::raise_error(array(
+ 'code' => 600,
+ 'type' => 'php',
+ 'file' => __FILE__, 'line' => __LINE__,
+ 'message' => "Password plugin: Gearman authentication failed for user $user: $error"
+ ), true, false);
+ }
+ }
+ else {
+ rcube::raise_error(array(
+ 'code' => 600,
+ 'type' => 'php',
+ 'file' => __FILE__, 'line' => __LINE__,
+ 'message' => "Password plugin: PECL Gearman module not loaded"
+ ), true, false);
+ }
+
+ return PASSWORD_ERROR;
+ }
+}
+?>