73 lines
2.0 KiB
PHP
73 lines
2.0 KiB
PHP
<?php defined('SYSPATH') or die('No direct access allowed.');
|
|
|
|
/**
|
|
* This class provides User Account Update functions
|
|
*
|
|
* @package lnApp
|
|
* @category Controllers/User
|
|
* @author Deon George
|
|
* @copyright (c) 2009-2013 Deon George
|
|
* @license http://dev.leenooks.net/license.html
|
|
*/
|
|
abstract class lnApp_Controller_User_Account extends Controller_Account {
|
|
protected $secure_actions = array(
|
|
'edit'=>TRUE,
|
|
'resetpassword'=>TRUE,
|
|
);
|
|
|
|
/**
|
|
* Enable User to Edit their Account Details
|
|
*/
|
|
public function action_edit() {
|
|
if ($_POST AND $this->ao->values($_POST)->changed() AND (! $this->save($this->ao)))
|
|
$this->ao->reload();
|
|
|
|
Block::factory()
|
|
->title(sprintf('Account: %s',$this->ao->accnum()))
|
|
->title_icon('fa-wrench')
|
|
->type('form-horizontal')
|
|
->body(View::factory('account/user/edit')->set('o',$this->ao));
|
|
}
|
|
|
|
public function action_resetpassword() {
|
|
if ($this->request->post()) {
|
|
$validation = Validation::factory($this->request->post())
|
|
->rule('password','not_empty')
|
|
->rule('password','min_length',array(':value',6))
|
|
->rule('password_confirm','matches',array(':validation',':field','password'));
|
|
|
|
// Store our new values
|
|
$this->ao->values($this->request->post());
|
|
|
|
if (! $validation->check())
|
|
SystemMessage::factory()
|
|
->title(_('Record NOT updated'))
|
|
->type('error')
|
|
->body(_('Your password didnt pass validation.'));
|
|
|
|
// Run validation and save
|
|
elseif ($this->ao->changed())
|
|
if ($this->ao->save()) {
|
|
SystemMessage::factory()
|
|
->title('Record updated')
|
|
->type('success')
|
|
->body(_('Your account record has been updated.'));
|
|
|
|
// Log the password reset
|
|
$this->ao->log('Password reset');
|
|
|
|
}
|
|
|
|
HTTP::redirect('login');
|
|
}
|
|
|
|
Block::factory()
|
|
->title(sprintf('Password Reset: %s',$this->ao->accnum()))
|
|
->title_icon('fa-cog')
|
|
->id('reset')
|
|
->type('form-horizontal')
|
|
->body(View::factory('account/user/resetpassword')->set('o',$this->ao));
|
|
}
|
|
}
|
|
?>
|