From 7207dccc7cebd641913796ff0270ff451818cfa5 Mon Sep 17 00:00:00 2001 From: mark_story Date: Sun, 2 Jan 2011 14:24:25 -0500 Subject: [PATCH] Adding ActionsAuthorize. It implements using Acl as the authorization object. --- .../components/auth/actions_authorize.php | 39 ++++++ .../auth/actions_authorize.test.php | 130 ++++++++++++++++++ 2 files changed, 169 insertions(+) create mode 100644 cake/libs/controller/components/auth/actions_authorize.php create mode 100644 cake/tests/cases/libs/controller/components/auth/actions_authorize.test.php diff --git a/cake/libs/controller/components/auth/actions_authorize.php b/cake/libs/controller/components/auth/actions_authorize.php new file mode 100644 index 000000000..7f4f722d7 --- /dev/null +++ b/cake/libs/controller/components/auth/actions_authorize.php @@ -0,0 +1,39 @@ +_controller->Components->load('Acl'); + return $Acl->check($user, $this->action($request)); + } +} \ No newline at end of file diff --git a/cake/tests/cases/libs/controller/components/auth/actions_authorize.test.php b/cake/tests/cases/libs/controller/components/auth/actions_authorize.test.php new file mode 100644 index 000000000..5aedbda04 --- /dev/null +++ b/cake/tests/cases/libs/controller/components/auth/actions_authorize.test.php @@ -0,0 +1,130 @@ +controller = $this->getMock('Controller', array(), array(), '', false); + $this->Acl = $this->getMock('AclComponent', array(), array(), '', false); + $this->controller->Components = $this->getMock('ComponentCollection'); + + $this->auth = new ActionsAuthorize($this->controller); + $this->auth->actionPath = '/controllers'; + } + +/** + * setup the mock acl. + * + * @return void + */ + protected function _mockAcl() { + $this->controller->Components->expects($this->any()) + ->method('load') + ->with('Acl') + ->will($this->returnValue($this->Acl)); + } + +/** + * test failure + * + * @return void + */ + function testAuthorizeFailure() { + $user = array( + 'User' => array( + 'id' => 1, + 'user' => 'mariano' + ) + ); + $request = new CakeRequest('/posts/index', false); + $request->addParams(array( + 'plugin' => null, + 'controller' => 'posts', + 'action' => 'index' + )); + + $this->_mockAcl(); + + $this->Acl->expects($this->once()) + ->method('check') + ->with($user, '/controllers/Posts/index') + ->will($this->returnValue(false)); + + $this->assertFalse($this->auth->authorize($user, $request)); + } + +/** + * test isAuthorized working. + * + * @return void + */ + function testAuthorizeSuccess() { + $user = array( + 'User' => array( + 'id' => 1, + 'user' => 'mariano' + ) + ); + $request = new CakeRequest('/posts/index', false); + $request->addParams(array( + 'plugin' => null, + 'controller' => 'posts', + 'action' => 'index' + )); + + $this->_mockAcl(); + + $this->Acl->expects($this->once()) + ->method('check') + ->with($user, '/controllers/Posts/index') + ->will($this->returnValue(true)); + + $this->assertTrue($this->auth->authorize($user, $request)); + } + +/** + * test action() + * + * @return void + */ + function testActionMethod() { + $request = new CakeRequest('/posts/index', false); + $request->addParams(array( + 'plugin' => null, + 'controller' => 'posts', + 'action' => 'index' + )); + + $result = $this->auth->action($request); + + $this->assertEquals('/controllers/Posts/index', $result); + } + +/** + * test action() and plugins + * + * @return void + */ + function testActionWithPlugin() { + $request = new CakeRequest('/debug_kit/posts/index', false); + $request->addParams(array( + 'plugin' => 'debug_kit', + 'controller' => 'posts', + 'action' => 'index' + )); + + $result = $this->auth->action($request); + $this->assertEquals('/controllers/DebugKit/Posts/index', $result); + } +}