summaryrefslogtreecommitdiff
path: root/demos/blog/protected/Pages/Users/EditUser.php
blob: f48a2606942ec32ace0573ca60db857752c4c8d9 (plain)
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
<?php
/**
 * EditUser class file
 *
 * @author Qiang Xue <qiang.xue@gmail.com>
 * @link https://github.com/pradosoft/prado
 * @copyright Copyright &copy; 2006-2015 The PRADO Group
 * @license https://github.com/pradosoft/prado/blob/master/COPYRIGHT
 */

/**
 * EditUser class
 *
 * @author Qiang Xue <qiang.xue@gmail.com>
 * @link https://github.com/pradosoft/prado
 * @copyright Copyright &copy; 2006-2015 The PRADO Group
 * @license https://github.com/pradosoft/prado/blob/master/COPYRIGHT
 */
class EditUser extends BlogPage
{
	private $_userRecord=null;

	public function onInit($param)
	{
		parent::onInit($param);
		if(($id=$this->Request['id'])!==null)
		{
			$id=TPropertyValue::ensureInteger($id);
			if(!$this->User->IsAdmin && $this->User->ID!==$id)
				throw new BlogException(500,'profile_edit_disallowed',$id);
		}
		else
			$id=$this->User->ID;
		if(($this->_userRecord=$this->DataAccess->queryUserByID($id))===null)
			throw new BlogException(500,'profile_id_invalid',$id);
	}

	public function onLoad($param)
	{
		parent::onLoad($param);
		if(!$this->IsPostBack)
		{
			$userRecord=$this->_userRecord;
			$this->Username->Text=$userRecord->Name;
			$this->FullName->Text=$userRecord->FullName;
			$this->Email->Text=$userRecord->Email;
			$this->Website->Text=$userRecord->Website;
		}
	}

	public function saveButtonClicked($sender,$param)
	{
		if($this->IsValid)
		{
			$userRecord=$this->_userRecord;
			if($this->Password->Text!=='')
				$userRecord->Password=md5($this->Password->Text);
			$userRecord->FullName=$this->FullName->Text;
			$userRecord->Email=$this->Email->Text;
			$userRecord->Website=$this->Website->Text;
			$this->DataAccess->updateUser($userRecord);
			$authManager=$this->Application->getModule('auth');
			$this->gotoPage('Users.ViewUser',array('id'=>$userRecord->ID));
		}
	}
}