mirror of
https://github.com/Pathduck/gallery3.git
synced 2026-05-20 03:19:13 -04:00
* Remove user registration link and popup from the theme; this shouldn't be done in a popup. Use ajaxform to simplify the way that we load the login popup. * Create form.html.php, this is a template for Forge based forms. * Move user validation rules into User_Model and let forms populate the rules into their forms as useful. * Undo r18688's changes regarding the REST code. We should never accept a null resource, this breaks the REST abstraction. * Change login and user controllers to use Forge which lets us delete login.html.php and user.html.php since those now are generated by the theme-owned form template
108 lines
3.3 KiB
PHP
108 lines
3.3 KiB
PHP
<?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_Controller extends REST_Controller {
|
|
protected $resource_type = "user";
|
|
|
|
/**
|
|
* Return the form for creating / modifying users.
|
|
*/
|
|
private function _get_form($user) {
|
|
$form = new Forge("user/{$user->id}", "", "post", array("id" => "gUser"));
|
|
$group = $form->group(_("User Info"));
|
|
$group->input("name")
|
|
->label(_("Name"))
|
|
->id("gName")
|
|
->class(null)
|
|
->value($user->name);
|
|
$group->input("display_name")
|
|
->label(_("Display Name"))
|
|
->id("gDisplayName")
|
|
->class(null)
|
|
->value($user->display_name);
|
|
$group->password("password")
|
|
->label(_("Password"))
|
|
->id("gPassword")
|
|
->class(null);
|
|
$group->input("email")
|
|
->label(_("Email"))
|
|
->id("gEmail")
|
|
->class(null)
|
|
->value($user->email);
|
|
$group->submit(_("Modify"));
|
|
$form->hidden("continue")->value($this->input->get("continue"));
|
|
|
|
$this->_add_validation_rules(ORM::factory("user")->validation_rules, $form);
|
|
|
|
return $form;
|
|
}
|
|
|
|
/**
|
|
* @todo Refactor this into a more generic location
|
|
*/
|
|
private function _add_validation_rules($rules, $form) {
|
|
foreach ($form->inputs as $name => $input) {
|
|
if (isset($input->inputs)) {
|
|
$this->_add_validation_rules($rules, $input);
|
|
}
|
|
if (isset($rules[$name])) {
|
|
$input->rules($rules[$name]);
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @see Rest_Controller::_get($resource)
|
|
*/
|
|
public function _get($user) {
|
|
$form = $this->_get_form($user);
|
|
print $form->render("form.html", false);
|
|
}
|
|
|
|
/**
|
|
* @see Rest_Controller::_put($resource)
|
|
*/
|
|
public function _put($resource) {
|
|
throw new Exception("@todo User_Controller::_put NOT IMPLEMENTED");
|
|
}
|
|
|
|
/**
|
|
* @see Rest_Controller::_post($resource)
|
|
*/
|
|
public function _post($user) {
|
|
$form = $this->_get_form($user);
|
|
if ($form->validate()) {
|
|
// @todo if we use the Validation class here, the ORM can just read the inputs directly. We
|
|
// need to investigate that.
|
|
//
|
|
// @todo
|
|
// Verify the user input, store it in the object.
|
|
// Show errors on validation failure.
|
|
// On success, redirect if there's a form->continue, else show an empty page.
|
|
}
|
|
throw new Exception("@todo User_Controller::_post NOT IMPLEMENTED");
|
|
}
|
|
|
|
/**
|
|
* @see Rest_Controller::_delete($resource)
|
|
*/
|
|
public function _delete($resource) {
|
|
throw new Exception("@todo User_Controller::_delete NOT IMPLEMENTED");
|
|
}
|
|
} |