diff options
Diffstat (limited to 'modules/user')
| -rw-r--r-- | modules/user/config/user.php | 25 | ||||
| -rw-r--r-- | modules/user/helpers/user_installer.php | 68 | ||||
| -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 | 
5 files changed, 449 insertions, 63 deletions
| diff --git a/modules/user/config/user.php b/modules/user/config/user.php new file mode 100644 index 00000000..9a82c5fd --- /dev/null +++ b/modules/user/config/user.php @@ -0,0 +1,25 @@ +<?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. + */ + +/** + * Name of the driver to be used for handling user authentication and password management + */ +$config['driver'] = 'Gallery'; + diff --git a/modules/user/helpers/user_installer.php b/modules/user/helpers/user_installer.php index 97206752..31865ad1 100644 --- a/modules/user/helpers/user_installer.php +++ b/modules/user/helpers/user_installer.php @@ -22,71 +22,13 @@ class user_installer {    public static function install() {      Kohana::log("debug", "user_installer::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, -          `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;"); - -      $user_module = ORM::factory("module")->where("name", "user")->find(); -      $user_module->name = "user"; -      $user_module->version = 1; -      $user_module->save(); - -      $user = ORM::factory("user")->where("display_name", "admin")->find(); -      $user->name = "admin"; -      $user->display_name = "Gallery Administrator"; -      $user->save(); -      $id = $user->id; -      $db->query("UPDATE `items` SET `owner_id` = $id WHERE `owner_id` IS NULL"); - -      foreach (array("administrator", "registered") as $group_name) { -        $group = ORM::factory("group")->where("name", $group_name)->find(); -        $group->name = $group_name; -        $group->save(); -        if (!$group->add($user)) { -          throw new Exception("@todo {$user->name} WAS_NOT_ADDED_TO {$group_name}"); -        } -      } -    } +    $user = User::instance(); +    $user->install();    }    public static 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`;"); -    ORM::factory("module")->where("name", "user")->find()->delete(); +    Kohana::log("debug", "user_installer::install"); +    $user = User::instance(); +    $user->uninstall();    }  }
\ No newline at end of file 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 | 
