diff options
author | Hugues Hiegel <root@paranoid> | 2015-04-21 12:45:58 +0200 |
---|---|---|
committer | Hugues Hiegel <root@paranoid> | 2015-04-21 12:45:58 +0200 |
commit | ef2e7b3f9d264ec146d4dae257b1e295ab3b462a (patch) | |
tree | 76b4a98d7b3b38f691c4fbee1612197ab6615c2b /plugins/virtuser_query | |
parent | d09b64c6270c638059b003922db508f95d32d555 (diff) |
updates - plugins as a separate git folder
Diffstat (limited to 'plugins/virtuser_query')
-rw-r--r-- | plugins/virtuser_query/composer.json | 24 | ||||
-rw-r--r-- | plugins/virtuser_query/tests/VirtuserQuery.php | 23 | ||||
-rw-r--r-- | plugins/virtuser_query/virtuser_query.php | 165 |
3 files changed, 0 insertions, 212 deletions
diff --git a/plugins/virtuser_query/composer.json b/plugins/virtuser_query/composer.json deleted file mode 100644 index 7459ca9bd..000000000 --- a/plugins/virtuser_query/composer.json +++ /dev/null @@ -1,24 +0,0 @@ -{ - "name": "roundcube/virtuser_query", - "type": "roundcube-plugin", - "description": "Plugin adds possibility to resolve user email/login according to lookup tables in SQL database.", - "license": "GPLv3+", - "version": "2.0", - "authors": [ - { - "name": "Aleksander Machniak", - "email": "alec@alec.pl", - "role": "Lead" - } - ], - "repositories": [ - { - "type": "composer", - "url": "http://plugins.roundcube.net" - } - ], - "require": { - "php": ">=5.3.0", - "roundcube/plugin-installer": ">=0.1.3" - } -} diff --git a/plugins/virtuser_query/tests/VirtuserQuery.php b/plugins/virtuser_query/tests/VirtuserQuery.php deleted file mode 100644 index 6c68f4c64..000000000 --- a/plugins/virtuser_query/tests/VirtuserQuery.php +++ /dev/null @@ -1,23 +0,0 @@ -<?php - -class VirtuserQuery_Plugin extends PHPUnit_Framework_TestCase -{ - - function setUp() - { - include_once __DIR__ . '/../virtuser_query.php'; - } - - /** - * Plugin object construction test - */ - function test_constructor() - { - $rcube = rcube::get_instance(); - $plugin = new virtuser_query($rcube->api); - - $this->assertInstanceOf('virtuser_query', $plugin); - $this->assertInstanceOf('rcube_plugin', $plugin); - } -} - diff --git a/plugins/virtuser_query/virtuser_query.php b/plugins/virtuser_query/virtuser_query.php deleted file mode 100644 index c08d6bd38..000000000 --- a/plugins/virtuser_query/virtuser_query.php +++ /dev/null @@ -1,165 +0,0 @@ -<?php - -/** - * DB based User-to-Email and Email-to-User lookup - * - * Add it to the plugins list in config.inc.php and set - * SQL queries to resolve usernames, e-mail addresses and hostnames from the database - * %u will be replaced with the current username for login. - * %m will be replaced with the current e-mail address for login. - * - * Queries should select the user's e-mail address, username or the imap hostname as first column - * The email query could optionally select identity data columns in specified order: - * name, organization, reply-to, bcc, signature, html_signature - * - * $config['virtuser_query'] = array('email' => '', 'user' => '', 'host' => '', 'alias' => ''); - * - * The email query can return more than one record to create more identities. - * This requires identities_level option to be set to value less than 2. - * - * By default Roundcube database is used. To use different database (or host) - * you can specify DSN string in $config['virtuser_query_dsn'] option. - * - * @version @package_version@ - * @author Aleksander Machniak <alec@alec.pl> - * @author Steffen Vogel - * @author Tim Gerundt - * @license GNU GPLv3+ - */ -class virtuser_query extends rcube_plugin -{ - private $config; - private $app; - private $db; - - function init() - { - $this->app = rcmail::get_instance(); - $this->config = $this->app->config->get('virtuser_query'); - - if (!empty($this->config)) { - if (is_string($this->config)) { - $this->config = array('email' => $this->config); - } - - if ($this->config['email']) { - $this->add_hook('user2email', array($this, 'user2email')); - } - if ($this->config['user']) { - $this->add_hook('email2user', array($this, 'email2user')); - } - if ($this->config['host']) { - $this->add_hook('authenticate', array($this, 'user2host')); - } - if ($this->config['alias']) { - $this->add_hook('authenticate', array($this, 'alias2user')); - } - } - } - - /** - * User > Email - */ - function user2email($p) - { - $dbh = $this->get_dbh(); - - $sql_result = $dbh->query(preg_replace('/%u/', $dbh->escape($p['user']), $this->config['email'])); - - while ($sql_arr = $dbh->fetch_array($sql_result)) { - if (strpos($sql_arr[0], '@')) { - if ($p['extended'] && count($sql_arr) > 1) { - $result[] = array( - 'email' => rcube_utils::idn_to_ascii($sql_arr[0]), - 'name' => (string) $sql_arr[1], - 'organization' => (string) $sql_arr[2], - 'reply-to' => (string) rcube_utils::idn_to_ascii($sql_arr[3]), - 'bcc' => (string) rcube_utils::idn_to_ascii($sql_arr[4]), - 'signature' => (string) $sql_arr[5], - 'html_signature' => (int) $sql_arr[6], - ); - } - else { - $result[] = $sql_arr[0]; - } - - if ($p['first']) { - break; - } - } - } - - $p['email'] = $result; - - return $p; - } - - /** - * EMail > User - */ - function email2user($p) - { - $dbh = $this->get_dbh(); - - $sql_result = $dbh->query(preg_replace('/%m/', $dbh->escape($p['email']), $this->config['user'])); - - if ($sql_arr = $dbh->fetch_array($sql_result)) { - $p['user'] = $sql_arr[0]; - } - - return $p; - } - - /** - * User > Host - */ - function user2host($p) - { - $dbh = $this->get_dbh(); - - $sql_result = $dbh->query(preg_replace('/%u/', $dbh->escape($p['user']), $this->config['host'])); - - if ($sql_arr = $dbh->fetch_array($sql_result)) { - $p['host'] = $sql_arr[0]; - } - - return $p; - } - - /** - * Alias > User - */ - function alias2user($p) - { - $dbh = $this->get_dbh(); - - $sql_result = $dbh->query(preg_replace('/%u/', $dbh->escape($p['user']), $this->config['alias'])); - - if ($sql_arr = $dbh->fetch_array($sql_result)) { - $p['user'] = $sql_arr[0]; - } - - return $p; - } - - /** - * Initialize database handler - */ - function get_dbh() - { - if (!$this->db) { - if ($dsn = $this->app->config->get('virtuser_query_dsn')) { - // connect to the virtuser database - $this->db = rcube_db::factory($dsn); - $this->db->set_debug((bool)$this->app->config->get('sql_debug')); - $this->db->db_connect('r'); // connect in read mode - } - else { - $this->db = $this->app->get_dbh(); - } - } - - return $this->db; - } - -} |