diff options
author | Tim Almdal <tnalmdal@shaw.ca> | 2008-11-10 20:17:09 +0000 |
---|---|---|
committer | Tim Almdal <tnalmdal@shaw.ca> | 2008-11-10 20:17:09 +0000 |
commit | 0a8d5edbdc8e3e251f29b7370fdc2e594b06446f (patch) | |
tree | c32a89c1c0b7f4458d0c6161be5d2a73f396f3ce /modules/user/libraries | |
parent | ddf0a519000f4c93df1f2ded18b631325256a905 (diff) |
Early look at the User/Auth module refactoring. It will look for a driver based on the contents of the user/config/user.php file. And load that driver based on the User_Driver interface. There is a default User_Gallery_Driver class that will provide the actual interface implementation. Replacing this driver will allow a completely different user and authentication implementation to be used... hopefully will reduce issues with embedding and other user management systems. Removed from unit tests so they will still run.
Diffstat (limited to 'modules/user/libraries')
-rw-r--r-- | modules/user/libraries/User.php | 196 | ||||
-rw-r--r-- | modules/user/libraries/drivers/User.php | 60 | ||||
-rw-r--r-- | modules/user/libraries/drivers/User/Gallery.php | 163 |
3 files changed, 419 insertions, 0 deletions
diff --git a/modules/user/libraries/User.php b/modules/user/libraries/User.php new file mode 100644 index 00000000..a32c5691 --- /dev/null +++ b/modules/user/libraries/User.php @@ -0,0 +1,196 @@ +<?php defined("SYSPATH") or die("No direct script access."); +/** + * Gallery - a web based photo album viewer and editor + * Copyright (C) 2000-2008 Bharat Mediratta + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or (at + * your option) any later version. + * + * This program is distributed in the hope that it will be useful, but + * WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA. + */ +/** + * This is the generalized wrapper to provide user management. The actual user management + * fucntionality is implemented by a driver module. This will insulate gallery3 user management + * from various CMS implementations. + * + */ +class User_Core implements User_Driver { + + // Session singleton + private static $instance; + + // Configuration and driver + protected $_config; + protected $_driver; + + /** + * Singleton instance of Session. + */ + public static function instance($config = array()) { + if (self::$instance == NULL) { + // Create a new instance + self::$instance = new User($config); + } + + return self::$instance; + } + + /** + * On first instance creation, sets up the driver. + */ + protected function __construct($config = array()) { + // Load config + $config += Kohana::config('user'); + + // Set the driver class name + $driver = "User_{$config['driver']}_Driver"; + if (!Kohana::auto_load($driver)) { + // @todo change to gallery specific exceptions + throw new Exception("@todo DRIVER_NOT_DEFINED {$config['driver']}"); + } + + // Load the driver + $driver = new $driver(); + + if (!($driver instanceof User_Driver)) { + // @todo change to gallery specific exceptions + throw new Exception( + "@todo User_Driver_INTERFACE_NOT_IMPLEMENTED: {$config['driver']}"); + } + + $this->_driver = $driver; + $this->_config = $config; + + Kohana::log('debug', 'Auth Library initialized'); + } + + /** + * @see User_Driver::install + */ + public function install() { + $this->_driver->install(); + + $user_module = ORM::factory("module")->where("name", "user")->find(); + $user_module->name = "user"; + $user_module->version = 1; + $user_module->save(); + + $user = $this->_driver->get_user_by_name("admin"); + if (!$user->loaded) { + $user = $this->_driver->create_user("admin", "admin", "admin"); + } + + foreach (array("administrator", "registered") as $group_name) { + $group = $user = $this->_driver->get_group_by_name($group_name); + if (!$group->loaded) { + $group = $this->_driver->create_group($group_name); + // Don't assume we can use ORM relationship to join groups and users. Use the interface. + $this->_driver->add_user_to_group($group->id, $user->id); + } + } + + $db = Database::instance(); + $db->query("UPDATE `items` SET `owner_id` = {$user->id} WHERE `owner_id` IS NULL"); + } + + /** + * @see User_Driver::uninstall + */ + public function uninstall() { + $this->_driver->uninstall(); + ORM::factory("module")->where("name", "user")->find()->delete(); + } + + /** + * @see User_Driver::install + */ + public function create_user($name, $display_name, $password, $email=null) { + $this->_driver->create_user($name, $display_name, $password, $email); + } + + /** + * @see User_Driver::update_user + */ + public function update_user($id, $name, $display_name, $password, $email=null) { + $this->_driver->update_user($id, $name, $display_name, $password, $email); + } + + /** + * @see User_Driver::get_user + */ + public function get_user($id) { + $this->_driver->get_user($id); + } + + /** + * @see User_Driver::get_user_by_name + */ + public function get_user_by_name($name) { + $this->_driver->get_user_by_name($name); + } + + /** + * @see User_Driver::delete_user + */ + public function delete_user($id) { + $this->_driver->delete_user($id); + } + + /** + * @see User_Driver::create_group + */ + public function create_group($group_name) { + $this->_driver->create_group($group_name); + } + + /** + * @see User_Driver::rename_group + */ + public function rename_group($id, $new_name) { + $this->_driver->rename_group($id, $new_name); + } + + /** + * @see User_Driver::get_group + */ + public function get_group($id) { + $this->_driver->get_group($id); + } + + /** + * @see User_Driver::get_group_by_name + */ + public function get_group_by_name($group_name) { + $this->_driver->get_group_by_name($group_name); + } + + /** + * @see User_Driver::delete_group + */ + public function delete_group($id) { + $this->_driver->delete_group($id); + } + + /** + * @see User_Driver::add_user_to_group + */ + public function add_user_to_group($group_id, $user_id) { + $this->_driver->add_user_to_group($group_id, $user_id); + } + + /** + * @see User_Driver::remove_user_from_group + */ + public function remove_user_from_group($group_id, $user_id) { + $this->_driver->remove_user_from_group($group_id, $user_id); + } +}
\ No newline at end of file diff --git a/modules/user/libraries/drivers/User.php b/modules/user/libraries/drivers/User.php new file mode 100644 index 00000000..1030f5e9 --- /dev/null +++ b/modules/user/libraries/drivers/User.php @@ -0,0 +1,60 @@ +<?php defined("SYSPATH") or die("No direct script access."); +/** + * Gallery - a web based photo album viewer and editor + * Copyright (C) 2000-2008 Bharat Mediratta + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or (at + * your option) any later version. + * + * This program is distributed in the hope that it will be useful, but + * WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA. + */ +/** + * This is the generalized wrapper to provide user management. The actual user management + * fucntionality is implemented by a driver module. This will insulate gallery3 user management + * from various CMS implementations. + * + */ +interface User_Driver { + /** + * Performs the installation steps that a specific driver requires + */ + public function install(); + + /** + * Performs the un install steps that a specific driver requires + */ + public function uninstall(); + + public function create_user($name, $display_name, $password, $email=null); + + public function update_user($id, $name, $display_name, $password, $email=null); + + public function get_user($id); + + public function get_user_by_name($name); + + public function delete_user($id); + + public function create_group($group_name); + + public function rename_group($id, $new_name); + + public function get_group($id); + + public function get_group_by_name($group_name); + + public function delete_group($id); + + public function add_user_to_group($group_id, $user_id); + + public function remove_user_from_group($group_id, $user_id); +}
\ No newline at end of file diff --git a/modules/user/libraries/drivers/User/Gallery.php b/modules/user/libraries/drivers/User/Gallery.php new file mode 100644 index 00000000..62c88ca6 --- /dev/null +++ b/modules/user/libraries/drivers/User/Gallery.php @@ -0,0 +1,163 @@ +<?php defined("SYSPATH") or die("No direct script access."); +/** + * Gallery - a web based photo album viewer and editor + * Copyright (C) 2000-2008 Bharat Mediratta + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or (at + * your option) any later version. + * + * This program is distributed in the hope that it will be useful, but + * WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA. + */ +class User_Gallery_Driver implements User_Driver { + /** + * @see User_Driver::install + */ + public function install() { + Kohana::log("debug", "user_gallery_driver::install"); + $db = Database::instance(); + try { + $base_version = ORM::factory("module")->where("name", "user")->find()->version; + } catch (Exception $e) { + if ($e->getCode() == E_DATABASE_ERROR) { + $base_version = 0; + } else { + Kohana::log("error", $e); + throw $e; + } + } + Kohana::log("debug", "base_version: $base_version"); + + if ($base_version == 0) { + $db->query("CREATE TABLE IF NOT EXISTS `users` ( + `id` int(9) NOT NULL auto_increment, + `name` varchar(255) NOT NULL, + `display_name` char(255) NOT NULL, + `password` varchar(128) NOT NULL, + `logins` int(10) unsigned NOT NULL default '0', + `last_login` int(10) unsigned NOT NULL default '0', + `email` int(9) default NULL, + PRIMARY KEY (`id`), + UNIQUE KEY(`display_name`)) + ENGINE=InnoDB DEFAULT CHARSET=utf8;"); + + $db->query("CREATE TABLE IF NOT EXISTS`groups` ( + `id` int(9) NOT NULL auto_increment, + `name` char(255) default NULL, + PRIMARY KEY (`id`), + UNIQUE KEY(`name`)) + ENGINE=InnoDB DEFAULT CHARSET=utf8;"); + + $db->query("CREATE TABLE IF NOT EXISTS `groups_users` ( + `group_id` int(9) NOT NULL, + `user_id` int(9) NOT NULL, + PRIMARY KEY (`group_id`, `user_id`), + UNIQUE KEY(`user_id`, `group_id`)) + ENGINE=InnoDB DEFAULT CHARSET=utf8;"); + + } + } + + /** + * @see User_Driver::install + * + */ + public function uninstall() { + $db = Database::instance(); + $db->query("DROP TABLE IF EXISTS `users`;"); + $db->query("DROP TABLE IF EXISTS `groups`;"); + $db->query("DROP TABLE IF EXISTS `groups_users`;"); + } + + /** + * @see User_Driver::create_user + */ + public function create_user($name, $display_name, $password, $email=null) { + throw new Exception("@todo NOT_IMPLMENTED: create_user"); + } + + /** + * @see User_Driver::update_user + */ + public function update_user($id, $name, $display_name, $password, $email=null) { + throw new Exception("@todo NOT_IMPLMENTED: update_user"); + } + + /** + * @see User_Driver::get_user + */ + public function get_user($id) { + throw new Exception("@todo NOT_IMPLMENTED: get_user"); + } + + /** + * @see User_Driver::get_user_by_name + */ + public function get_user_by_name($name) { + throw new Exception("@todo NOT_IMPLMENTED: get_user_by_name"); + } + + /** + * @see User_Driver::delete_user + */ + public function delete_user($id) { + throw new Exception("@todo NOT_IMPLMENTED: delete_user"); + } + + /** + * @see User_Driver::create_group + */ + public function create_group($group_name) { + throw new Exception("@todo NOT_IMPLMENTED: create_group"); + } + + /** + * @see User_Driver::rename_group + */ + public function rename_group($id, $new_name) { + throw new Exception("@todo NOT_IMPLMENTED: rename_group"); + } + + /** + * @see User_Driver::get_group + */ + public function get_group($id) { + throw new Exception("@todo NOT_IMPLMENTED: get_group"); + } + + /** + * @see User_Driver::get_group_by_name + */ + public function get_group_by_name($group_name) { + throw new Exception("@todo NOT_IMPLMENTED: get_group_by_name"); + } + + /** + * @see User_Driver::delete_group + */ + public function delete_group($id) { + throw new Exception("@todo NOT_IMPLMENTED: delete_group"); + } + + /** + * @see User_Driver::add_user_to_group + */ + public function add_user_to_group($group_id, $user_id) { + throw new Exception("@todo NOT_IMPLMENTED: add_user_to_group"); + } + + /** + * @see User_Driver::remove_user_from_group + */ + public function remove_user_from_group($group_id, $user_id) { + throw new Exception("@todo NOT_IMPLMENTED: remove_user_from_group"); + } +}
\ No newline at end of file |