From 3c65b68e1c958190ea6c4ca995019109a6a55865 Mon Sep 17 00:00:00 2001 From: Tim Almdal Date: Wed, 5 Nov 2008 05:32:47 +0000 Subject: The start of the user module. At this point, it shows up on the scaffolding screen and you can install and uninstall it. Which creates the tables, defines 2 groups (adminstrator, registered) and one user (admin). --- modules/user/helpers/user_installer.php | 86 +++++++++++++++++++++++++++++++++ 1 file changed, 86 insertions(+) create mode 100644 modules/user/helpers/user_installer.php (limited to 'modules/user/helpers/user_installer.php') diff --git a/modules/user/helpers/user_installer.php b/modules/user/helpers/user_installer.php new file mode 100644 index 00000000..d37904ea --- /dev/null +++ b/modules/user/helpers/user_installer.php @@ -0,0 +1,86 @@ +where("name", "user")->find()->version; + } catch (Exception $e) { + if ($e->getMessage() == "Table modules does not exist in your database.") { + $base_version = 0; + } else { + throw $e; + } + } + + if ($base_version == 0) { + $db->query("CREATE TABLE IF NOT EXISTS `users` ( + `id` int(9) NOT NULL auto_increment, + `logon_name` varchar(255) NOT NULL, + `name` char(255) NOT NULL, + `email` int(9) default NULL, + `external_id` varchar(255) default null, + PRIMARY KEY (`id`), + UNIQUE KEY(`logon_name`), + UNIQUE KEY(`external_id`)) + 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("logon_name", "admin")->find(); + $user->logon_name = "admin"; + $user->name = "Gallery Administrator"; + $user->save(); + + foreach (array('administrator', 'registered') as $group_name) { + $group = ORM::factory("group")->where("name", $group_name)->find(); + $group->name = $group_name; + $group->add($user); + $group->save(); + } + } + } + + public static function uninstall() { + $db = Database::instance(); + $db->query("DROP TABLE IF EXISTS `user`;"); + $db->query("DROP TABLE IF EXISTS `group`;"); + $db->query("DROP TABLE IF EXISTS `groups_users`;"); + $user_module = ORM::factory("module")->where("name", "user")->find(); + $user_module->delete(); + } +} \ No newline at end of file -- cgit v1.2.3