summaryrefslogtreecommitdiffstats
path: root/controllers/AdminController.php
blob: 3e4dfab879b5ce2409501eaa5327cae2f1bc22f7 (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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
<?php
namespace app\controllers;

use app\models\User;
use lithium\security\Auth;
use lithium\util\String;
use li3_access\security\Access;
use li3_flash_message\extensions\storage\FlashMessage;
use lithium\action\Dispatcher;

class AdminController extends \lithium\action\Controller {
	public function index()
	{
		$limit = 5;
		$page = $this->request->page ?: 1;
		//$order = array('created' => 'DESC');
		$total = User::count();
		$users = User::all(compact('limit','page'));
		$this->render(array('layout' => 'admin', 'data' =>  compact('users', 'total', 'page', 'limit')));	
	}

	public function users()
	{
		$users = User::all();
		$this->render(array('layout' => 'admin', 'data' => compact('users')));
		//Should have paginate for when there is more users.
	}

	
	//This is basically admins version of signup
	public function addUser()
	{
		$sucsess = false;

		//If the request isn't empty
		if($this->request->data) {
			//Does admins data need to be validated?
			$user = User::Create($this->request->data);
			$sucsess = $user->save();
		}
		if ($sucsess) {
			return $this->redirect('Users');
		}
	
		FlashMessage::set($user->name . "was added sucessfully.");
	}

	public function editUser($username = NULL)
	{
		if ($username != NULL)
		{
			$user = User::find('first', array('conditions' => compact('username')));
		
			if($this->request->data)
			{
				$user->set($this->request->data);
				if ($user->save(null, array('validate' => false)))
				{
					FlashMessage::set('User updated sucsessfully');
					$this->redirect('Admin::index');
				}
				else
				{
					FlashMessage::set('There was an error');
					$this->redirect('Admin::index');

				}
			}
			else
			{
				//unset($user->password);
				return compact('user');
			}
		}
	}

	public function removeUser($username)
	{
		/*
		//Form data needs to have $username and $confirm = true to do the delete.
		if($this->request->data)
		{
			//If the user has confirmed the deletion of the user.
			if($this->request->data->confirm)
			{ */
				$user = User::find('first', array('conditions' => compact('username')));
				$user->delete();
				FlashMessage::set("User was deleted sucsessfully.");
				$this->redirect('Admin');	
			//}
		}
		/*else
		{
			//Render the form
			$this->render(array('layout' => 'form', 'data' => compact('users')));

		}*/
	//}
}
?>