1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 | <?php // // Open Web Analytics - An Open Source Web Analytics Framework // // Copyright 2006 Peter Adams. All rights reserved. // // Licensed under GPL v2.0 http://www.gnu.org/copyleft/gpl.html // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. // // $Id$ // require_once(OWA_BASE_DIR.'/owa_adminController.php'); /** * Edit User Controller * * @author Peter Adams <peter@openwebanalytics.com> * @copyright Copyright © 2006 Peter Adams <peter@openwebanalytics.com> * @license http://www.gnu.org/copyleft/gpl.html GPL v2.0 * @category owa * @package owa * @version $Revision$ * @since owa 1.0.0 */ class owa_usersEditController extends owa_adminController { function __construct($params) { parent::__construct($params); $this->setRequiredCapability('edit_users'); $this->setNonceRequired(); // check that user_id is present $v1 = owa_coreAPI::validationFactory('required'); $v1->setValues($this->getParam('user_id')); $this->setValidation('user_id', $v1); // Check user name exists $v2 = owa_coreAPI::validationFactory('entityExists'); $v2->setConfig('entity', 'base.user'); $v2->setConfig('column', 'user_id'); $v2->setValues($this->getParam('user_id')); $v2->setErrorMessage($this->getMsg(3001)); $this->setValidation('user_id', $v2); } function action() { // This needs form validation in a bad way. $u = owa_coreAPI::entityFactory('base.user'); $u->getByColumn('user_id', $this->getParam('user_id')); $u->set('email_address', $this->getParam('email_address')); $u->set('real_name', $this->getParam('real_name')); // never change the role of the admin user if ($u->get('user_id') != 'admin') { $u->set('role', $this->getParam('role')); } $u->update(); $this->set('status_code', 3003); $this->setRedirectAction('base.users'); } function errorAction() { $this->setView('base.options'); $this->setSubview('base.usersProfile'); $this->set('error_code', 3311); $this->set('user', $this->params); } } ?> |