/** * Authenticate a Google user * * @access public * @param string $google_id Google unique id * @return boolean */ public function authenticate($google_id) { $userModel = new User($this->db, $this->event); $user = $userModel->getByGoogleId($google_id); if ($user) { // Create the user session $userModel->updateSession($user); // Update login history $lastLogin = new LastLogin($this->db, $this->event); $lastLogin->create(LastLogin::AUTH_GOOGLE, $user['id'], $userModel->getIpAddress(), $userModel->getUserAgent()); return true; } return false; }
public function testPrepareCreation() { $tc = new TaskCreation($this->container); $tf = new TaskFinder($this->container); $tp = new TaskPermission($this->container); $p = new Project($this->container); $u = new User($this->container); $this->assertNotFalse($u->create(array('username' => 'toto', 'password' => '123456'))); $this->assertNotFalse($u->create(array('username' => 'toto2', 'password' => '123456'))); $this->assertEquals(1, $p->create(array('name' => 'Project #1'))); $this->assertEquals(1, $tc->create(array('title' => 'Task #1', 'project_id' => 1, 'creator_id' => 1))); $this->assertEquals(2, $tc->create(array('title' => 'Task #2', 'project_id' => 1, 'creator_id' => 2))); $this->assertEquals(3, $tc->create(array('title' => 'Task #3', 'project_id' => 1, 'creator_id' => 3))); $this->assertEquals(4, $tc->create(array('title' => 'Task #4', 'project_id' => 1))); // User #1 can remove everything $user = $u->getbyId(1); $this->assertNotEmpty($user); $u->updateSession($user); $task = $tf->getbyId(1); $this->assertNotEmpty($task); $this->assertTrue($tp->canRemoveTask($task)); // User #2 can't remove the task #1 $user = $u->getbyId(2); $this->assertNotEmpty($user); $u->updateSession($user); $task = $tf->getbyId(1); $this->assertNotEmpty($task); $this->assertFalse($tp->canRemoveTask($task)); // User #1 can remove everything $user = $u->getbyId(1); $this->assertNotEmpty($user); $u->updateSession($user); $task = $tf->getbyId(2); $this->assertNotEmpty($task); $this->assertTrue($tp->canRemoveTask($task)); // User #2 can remove his own task $user = $u->getbyId(2); $this->assertNotEmpty($user); $u->updateSession($user); $task = $tf->getbyId(2); $this->assertNotEmpty($task); $this->assertTrue($tp->canRemoveTask($task)); // User #1 can remove everything $user = $u->getbyId(1); $this->assertNotEmpty($user); $u->updateSession($user); $task = $tf->getbyId(3); $this->assertNotEmpty($task); $this->assertTrue($tp->canRemoveTask($task)); // User #2 can't remove the task #3 $user = $u->getbyId(2); $this->assertNotEmpty($user); $u->updateSession($user); $task = $tf->getbyId(3); $this->assertNotEmpty($task); $this->assertFalse($tp->canRemoveTask($task)); // User #1 can remove everything $user = $u->getbyId(1); $this->assertNotEmpty($user); $u->updateSession($user); $task = $tf->getbyId(4); $this->assertNotEmpty($task); $this->assertTrue($tp->canRemoveTask($task)); // User #2 can't remove the task #4 $user = $u->getbyId(2); $this->assertNotEmpty($user); $u->updateSession($user); $task = $tf->getbyId(4); $this->assertNotEmpty($task); $this->assertFalse($tp->canRemoveTask($task)); }