mirror of
https://github.com/alchemy-fr/Phraseanet.git
synced 2025-10-24 18:33:13 +00:00
597 lines
20 KiB
PHP
597 lines
20 KiB
PHP
<?php
|
|
|
|
namespace Alchemy\Tests\Phrasea\Controller\Root;
|
|
|
|
use Alchemy\Phrasea\Application;
|
|
use Alchemy\Phrasea\Model\Entities\Registration;
|
|
use Alchemy\Phrasea\Model\Entities\User;
|
|
use RandomLib\Factory;
|
|
|
|
/**
|
|
* @group functional
|
|
* @group legacy
|
|
* @group authenticated
|
|
* @group web
|
|
*/
|
|
class AccountTest extends \PhraseanetAuthenticatedWebTestCase
|
|
{
|
|
/**
|
|
* @covers \Alchemy\Phrasea\Controller\Root\Account::displayAccount
|
|
* @covers \Alchemy\Phrasea\Controller\Root\Account::call
|
|
*/
|
|
public function testGetAccount()
|
|
{
|
|
$client = $this->getClient();
|
|
$crawler = $client->request('GET', '/account/');
|
|
|
|
$response = $client->getResponse();
|
|
|
|
$this->assertTrue($response->isOk());
|
|
|
|
$actionForm = $crawler->filter('form[name=account]')->attr('action');
|
|
$methodForm = $crawler->filter('form[name=account]')->attr('method');
|
|
|
|
$this->assertEquals('/account/', $actionForm);
|
|
$this->assertEquals('post', $methodForm);
|
|
}
|
|
|
|
/**
|
|
* @dataProvider provideFlashMessages
|
|
*/
|
|
public function testGetAccountNotice($type, $message)
|
|
{
|
|
$app = $this->getApplication();
|
|
$client = $this->getClient();
|
|
$app->addFlash($type, $message);
|
|
$crawler = $client->request('GET', '/account/');
|
|
|
|
$response = $client->getResponse();
|
|
|
|
$this->assertTrue($response->isOk());
|
|
|
|
$this->assertFlashMessage($crawler, $type, 1, $message);
|
|
}
|
|
|
|
/**
|
|
* @covers \Alchemy\Phrasea\Controller\Root\Account::accountAccess
|
|
*/
|
|
public function testGetAccountAccess()
|
|
{
|
|
$data = [
|
|
[
|
|
'registrations' => [
|
|
'by-type' => [
|
|
'inactive' => [[
|
|
'base-id' => '1',
|
|
'db-name' => 'db_test',
|
|
'active' => false,
|
|
'time-limited' => false,
|
|
'in-time' => false,
|
|
'registration' => null,
|
|
'coll-name' => 'BIBOO_INACTIVE',
|
|
'type' => 'inactive',
|
|
]],
|
|
'accepted' => [[
|
|
'base-id' => '2',
|
|
'db-name' => 'db_test',
|
|
'active' => true,
|
|
'time-limited' => false,
|
|
'in-time' => false,
|
|
'registration' => null,
|
|
'coll-name' => 'BIBOO_ACCEPTED',
|
|
'type' => 'accepted',
|
|
]],
|
|
'in-time' => [[
|
|
'base-id' => '3',
|
|
'db-name' => 'db_test',
|
|
'active' => true,
|
|
'time-limited' => false,
|
|
'in-time' => false,
|
|
'registration' => null,
|
|
'coll-name' => 'BIBOO_INTIME',
|
|
'type' => 'in-time',
|
|
]],
|
|
'out-dated' => [[
|
|
'base-id' => '4',
|
|
'db-name' => 'db_test',
|
|
'active' => true,
|
|
'time-limited' => false,
|
|
'in-time' => false,
|
|
'registration' => null,
|
|
'coll-name' => 'BIBOO_OUTDATED',
|
|
'type' => 'out-dated',
|
|
]],
|
|
'pending' => [[
|
|
'base-id' => '5',
|
|
'db-name' => 'db_test',
|
|
'active' => true,
|
|
'time-limited' => false,
|
|
'in-time' => false,
|
|
'registration' => null,
|
|
'coll-name' => 'BIBOO_PENDING',
|
|
'type' => 'pending',
|
|
]],
|
|
'rejected' => [[
|
|
'base-id' => '6',
|
|
'db-name' => 'db_test',
|
|
'active' => true,
|
|
'time-limited' => false,
|
|
'in-time' => false,
|
|
'registration' => null,
|
|
'coll-name' => 'BIBOO_REJECTED',
|
|
'type' => 'rejected',
|
|
]],
|
|
],
|
|
'by-collection' => []
|
|
],
|
|
'config' => [
|
|
'db-name' => 'a_db_name',
|
|
'cgu' => null,
|
|
'cgu-release' => null,
|
|
'can-register' => false,
|
|
'collections' => [
|
|
[
|
|
'coll-name' => 'a_coll_name',
|
|
'can-register' => false,
|
|
'cgu' => 'Some terms of use.',
|
|
'registration' => null
|
|
],
|
|
[
|
|
'coll-name' => 'an_other_coll_name',
|
|
'can-register' => false,
|
|
'cgu' => null,
|
|
'registration' => null
|
|
]
|
|
],
|
|
]
|
|
]
|
|
];
|
|
|
|
$app = $this->getApplication();
|
|
$client = $this->getClient();
|
|
$service = $this->getMockBuilder('Alchemy\Phrasea\Core\Configuration\RegistrationManager')
|
|
->setConstructorArgs([$app['phraseanet.appbox'], $app['repo.registrations'], $app['locale']])
|
|
->setMethods(['getRegistrationSummary'])
|
|
->getMock();
|
|
|
|
$service->expects($this->once())->method('getRegistrationSummary')->will($this->returnValue($data));
|
|
|
|
$app['registration.manager'] = $service;
|
|
$client->request('GET', '/account/access/');
|
|
|
|
$response = $client->getResponse();
|
|
$this->assertTrue($response->isOk());
|
|
}
|
|
|
|
/**
|
|
* @covers \Alchemy\Phrasea\Controller\Root\Account::resetEmail
|
|
*/
|
|
public function testGetResetMailWithToken()
|
|
{
|
|
$app = $this->getApplication();
|
|
$client = $this->getClient();
|
|
$tokenValue = $app['manipulator.token']->createResetEmailToken(self::$DI['user'], 'new_email@email.com')->getValue();
|
|
$client->request('GET', '/account/reset-email/', ['token' => $tokenValue]);
|
|
$response = $client->getResponse();
|
|
$this->assertTrue($response->isRedirect());
|
|
$this->assertEquals('/account/', $response->headers->get('location'));
|
|
|
|
$this->assertEquals('new_email@email.com', self::$DI['user']->getEmail());
|
|
self::$DI['user']->setEmail('noone@example.com');
|
|
if (null !== $app['repo.tokens']->find($tokenValue)) {
|
|
$this->fail('Token has not been removed');
|
|
}
|
|
|
|
$this->assertFlashMessagePopulated($app, 'success', 1);
|
|
}
|
|
|
|
/**
|
|
* @covers \Alchemy\Phrasea\Controller\Root\Account::resetEmail
|
|
*/
|
|
public function testGetResetMailWithBadToken()
|
|
{
|
|
$app = $this->getApplication();
|
|
$client = $this->getClient();
|
|
$client->request('GET', '/account/reset-email/', ['token' => '134dT0k3n']);
|
|
$response = $client->getResponse();
|
|
$this->assertTrue($response->isRedirect());
|
|
$this->assertEquals('/account/', $response->headers->get('location'));
|
|
|
|
$this->assertFlashMessagePopulated($app, 'error', 1);
|
|
}
|
|
|
|
/**
|
|
* @covers \Alchemy\Phrasea\Controller\Root\Account::resetEmail
|
|
*/
|
|
public function testPostResetMailBadRequest()
|
|
{
|
|
$client = $this->getClient();
|
|
$client->request('POST', '/account/reset-email/');
|
|
|
|
$this->assertBadResponse($client->getResponse());
|
|
}
|
|
|
|
/**
|
|
* @covers \Alchemy\Phrasea\Controller\Root\Account::resetEmail
|
|
*/
|
|
public function testPostResetMailBadPassword()
|
|
{
|
|
$app = $this->getApplication();
|
|
$client = $this->getClient();
|
|
$client->request('POST', '/account/reset-email/', [
|
|
'form_password' => 'changeme',
|
|
'form_email' => 'new@email.com',
|
|
'form_email_confirm' => 'new@email.com',
|
|
]);
|
|
|
|
$response = $client->getResponse();
|
|
$this->assertTrue($response->isRedirect());
|
|
$this->assertEquals('/account/reset-email/', $response->headers->get('location'));
|
|
|
|
$this->assertFlashMessagePopulated($app, 'error', 1);
|
|
}
|
|
|
|
/**
|
|
* @covers \Alchemy\Phrasea\Controller\Root\Account::resetEmail
|
|
*/
|
|
public function testPostResetMailBadEmail()
|
|
{
|
|
$app = $this->getApplication();
|
|
$client = $this->getClient();
|
|
$password = $app['random.low']->generateString(8);
|
|
$app['manipulator.user']->setPassword($app->getAuthenticatedUser(), $password);
|
|
$client->request('POST', '/account/reset-email/', [
|
|
'form_password' => $password,
|
|
'form_email' => "invalid#!&&@@email.x",
|
|
'form_email_confirm' => 'invalid#!&&@@email.x',
|
|
]);
|
|
|
|
$response = $client->getResponse();
|
|
$this->assertTrue($response->isRedirect());
|
|
$this->assertEquals('/account/reset-email/', $response->headers->get('location'));
|
|
|
|
$this->assertFlashMessagePopulated($app, 'error', 1);
|
|
}
|
|
|
|
/**
|
|
* @covers \Alchemy\Phrasea\Controller\Root\Account::resetEmail
|
|
*/
|
|
public function testPostResetMailEmailNotIdentical()
|
|
{
|
|
$app = $this->getApplication();
|
|
$client = $this->getClient();
|
|
$password = $app['random.low']->generateString(8);
|
|
$app['manipulator.user']->setPassword($app->getAuthenticatedUser(), $password);
|
|
$client->request('POST', '/account/reset-email/', [
|
|
'form_password' => $password,
|
|
'form_email' => 'email1@email.com',
|
|
'form_email_confirm' => 'email2@email.com',
|
|
]);
|
|
|
|
$response = $client->getResponse();
|
|
$this->assertTrue($response->isRedirect());
|
|
$this->assertEquals('/account/reset-email/', $response->headers->get('location'));
|
|
|
|
$this->assertFlashMessagePopulated($app, 'error', 1);
|
|
}
|
|
|
|
/**
|
|
* @covers \Alchemy\Phrasea\Controller\Root\Account::resetEmail
|
|
*/
|
|
public function testPostResetMailEmail()
|
|
{
|
|
$this->mockNotificationDeliverer('Alchemy\Phrasea\Notification\Mail\MailRequestEmailUpdate');
|
|
|
|
$app = $this->getApplication();
|
|
$client = $this->getClient();
|
|
$password = $app['random.low']->generateString(8);
|
|
$app['manipulator.user']->setPassword(
|
|
$app->getAuthenticatedUser(),
|
|
$password
|
|
);
|
|
$client->request('POST', '/account/reset-email/', [
|
|
'form_password' => $password,
|
|
'form_email' => 'email1@email.com',
|
|
'form_email_confirm' => 'email1@email.com',
|
|
]);
|
|
|
|
$client->followRedirects();
|
|
$response = $client->getResponse();
|
|
$this->assertTrue($response->isRedirect());
|
|
$this->assertEquals('/account/', $response->headers->get('location'));
|
|
|
|
$this->assertFlashMessagePopulated($app, 'info', 1);
|
|
}
|
|
|
|
/**
|
|
* @dataProvider provideFlashMessages
|
|
*/
|
|
public function testGetResetMailNotice($type, $message)
|
|
{
|
|
$app = $this->getApplication();
|
|
$client = $this->getClient();
|
|
$app->addFlash($type, $message);
|
|
|
|
$crawler = $client->request('GET', '/account/reset-email/');
|
|
|
|
$this->assertTrue($client->getResponse()->isOk());
|
|
|
|
$this->assertFlashMessage($crawler, $type, 1, $message);
|
|
}
|
|
|
|
/**
|
|
* @covers \Alchemy\Phrasea\Controller\Root\Account::accountSessionsAccess
|
|
*/
|
|
public function testGetAccountSecuritySessions()
|
|
{
|
|
$client = $this->getClient();
|
|
$client->request('GET', '/account/security/sessions/');
|
|
|
|
$response = $client->getResponse();
|
|
|
|
$this->assertTrue($response->isOk());
|
|
}
|
|
|
|
/**
|
|
* @covers \Alchemy\Phrasea\Controller\Root\Account::accountAuthorizedApps
|
|
*/
|
|
public function testGetAccountSecurityApplications()
|
|
{
|
|
$client = $this->getClient();
|
|
$client->request('GET', '/account/security/applications/');
|
|
|
|
$response = $client->getResponse();
|
|
|
|
$this->assertTrue($response->isOk());
|
|
}
|
|
|
|
/**
|
|
* @covers \Alchemy\Phrasea\Controller\Root\Account::resetPassword
|
|
*/
|
|
public function testGetResetPassword()
|
|
{
|
|
$client = $this->getClient();
|
|
$client->request('GET', '/account/reset-password/');
|
|
|
|
$response = $client->getResponse();
|
|
|
|
$this->assertTrue($response->isOk());
|
|
}
|
|
|
|
/**
|
|
* @dataProvider provideFlashMessages
|
|
*/
|
|
public function testGetResetPasswordPassError($type, $message)
|
|
{
|
|
$app = $this->getApplication();
|
|
$client = $this->getClient();
|
|
$app->addFlash($type, $message);
|
|
|
|
$crawler = $client->request('GET', '/account/reset-password/');
|
|
|
|
$response = $client->getResponse();
|
|
|
|
$this->assertTrue($response->isOk());
|
|
|
|
$this->assertFlashMessage($crawler, $type, 1, $message);
|
|
}
|
|
|
|
/**
|
|
* @covers \Alchemy\Phrasea\Controller\Root\Account::updateAccount
|
|
*/
|
|
public function testUpdateAccount()
|
|
{
|
|
$app = $this->getApplication();
|
|
$client = $this->getClient();
|
|
$bases = $notifs = [];
|
|
|
|
foreach ($app->getDataboxes() as $databox) {
|
|
foreach ($databox->get_collections() as $collection) {
|
|
$bases[] = $collection->get_base_id();
|
|
}
|
|
}
|
|
|
|
if (0 === count($bases)) {
|
|
$this->markTestSkipped('No collections');
|
|
}
|
|
|
|
foreach ($app['events-manager']->list_notifications_available($app->getAuthenticatedUser()) as $notifications) {
|
|
foreach ($notifications as $notification) {
|
|
$notifs[] = $notification['id'];
|
|
}
|
|
}
|
|
|
|
array_shift($notifs);
|
|
|
|
$client->request('POST', '/account/', [
|
|
'registrations' => $bases,
|
|
'form_gender' => User::GENDER_MR,
|
|
'form_firstname' => 'gros',
|
|
'form_lastname' => 'minet',
|
|
'form_address' => 'rue du lac',
|
|
'form_zip' => '75005',
|
|
'form_phone' => '+33645787878',
|
|
'form_fax' => '+33145787845',
|
|
'form_function' => 'astronaute',
|
|
'form_company' => 'NASA',
|
|
'form_activity' => 'Space',
|
|
'form_geonameid' => '1839',
|
|
'form_addressFTP' => '',
|
|
'form_loginFTP' => '',
|
|
'form_pwdFTP' => '',
|
|
'form_destFTP' => '',
|
|
'form_prefixFTPfolder' => '',
|
|
'form_retryFTP' => '',
|
|
'notifications' => $notifs,
|
|
'form_defaultdataFTP' => ['document', 'preview', 'caption'],
|
|
'mail_notifications' => '1'
|
|
]);
|
|
|
|
$response = $client->getResponse();
|
|
|
|
$this->assertTrue($response->isRedirect());
|
|
$this->assertEquals('minet', $app->getAuthenticatedUser()->getLastName());
|
|
|
|
$rs = $app['orm.em']->getRepository('Phraseanet:Registration')->findBy([
|
|
'user' => $app->getAuthenticatedUser()->getId(),
|
|
'pending' => true
|
|
]);
|
|
|
|
$this->assertCount(count($bases), $rs);
|
|
}
|
|
|
|
public function testAUthorizedAppGrantAccessBadRequest()
|
|
{
|
|
$client = $this->getClient();
|
|
$client->request('GET', '/account/security/application/3/grant/');
|
|
$this->assertBadResponse($client->getResponse());
|
|
}
|
|
|
|
public function testAUthorizedAppGrantAccessNotSuccessfull()
|
|
{
|
|
$client = $this->getClient();
|
|
$client->request('GET', '/account/security/application/0/grant/', [], [], ['HTTP_ACCEPT' => 'application/json', 'HTTP_X-Requested-With' => 'XMLHttpRequest']);
|
|
$response = $client->getResponse();
|
|
|
|
$this->assertTrue($response->isOk());
|
|
$json = json_decode($response->getContent());
|
|
$this->assertInstanceOf('StdClass', $json);
|
|
$this->assertObjectHasAttribute('success', $json);
|
|
$this->assertFalse($json->success);
|
|
}
|
|
|
|
/**
|
|
* @dataProvider revokeProvider
|
|
*/
|
|
public function testAUthorizedAppGrantAccessSuccessfull($revoke, $expected)
|
|
{
|
|
$app = $this->getApplication();
|
|
$client = $this->getClient();
|
|
$client->request('GET', '/account/security/application/' . self::$DI['oauth2-app-user']->getId() . '/grant/', [
|
|
'revoke' => $revoke
|
|
], [], [
|
|
'HTTP_ACCEPT' => 'application/json',
|
|
'HTTP_X-Requested-With' => 'XMLHttpRequest'
|
|
]);
|
|
|
|
$response = $client->getResponse();
|
|
$this->assertTrue($response->isOk());
|
|
$json = json_decode($response->getContent());
|
|
$this->assertInstanceOf('StdClass', $json);
|
|
$this->assertObjectHasAttribute('success', $json);
|
|
$this->assertTrue($json->success);
|
|
|
|
$account = $app['repo.api-accounts']->findByUserAndApplication(self::$DI['user'], self::$DI['oauth2-app-user']);
|
|
|
|
$this->assertEquals($expected, $account->isRevoked());
|
|
}
|
|
|
|
public function revokeProvider()
|
|
{
|
|
return [
|
|
['1', true],
|
|
['0', false],
|
|
[null, false],
|
|
['titi', true],
|
|
];
|
|
}
|
|
|
|
/**
|
|
* @dataProvider passwordProvider
|
|
*/
|
|
public function testPostRenewPasswordBadArguments($oldPassword, $password, $passwordConfirm)
|
|
{
|
|
$app = $this->getApplication();
|
|
$client = $this->getClient();
|
|
$app['manipulator.user']->setPassword($app->getAuthenticatedUser(), $oldPassword);
|
|
|
|
$crawler = $client->request('POST', '/account/reset-password/', [
|
|
'password' => [
|
|
'password' => $password,
|
|
'confirm' => $passwordConfirm
|
|
],
|
|
'oldPassword' => $oldPassword,
|
|
'_token' => 'token',
|
|
]);
|
|
|
|
$response = $client->getResponse();
|
|
|
|
$this->assertFalse($response->isRedirect());
|
|
$this->assertFormOrFlashError($crawler, 1);
|
|
}
|
|
|
|
public function testPostRenewPasswordBadOldPassword()
|
|
{
|
|
$client = $this->getClient();
|
|
$crawler = $client->request('POST', '/account/reset-password/', [
|
|
'password' => [
|
|
'password' => 'password',
|
|
'confirm' => 'password'
|
|
],
|
|
'oldPassword' => 'oulala',
|
|
'_token' => 'token',
|
|
]);
|
|
|
|
$response = $client->getResponse();
|
|
$this->assertFalse($response->isRedirect());
|
|
$this->assertFlashMessage($crawler, 'error', 1);
|
|
}
|
|
|
|
public function testPostRenewPasswordNoToken()
|
|
{
|
|
$app = $this->getApplication();
|
|
$client = $this->getClient();
|
|
$password = $app['random.low']->generateString(8);
|
|
|
|
$app['manipulator.user']->setPassword($app->getAuthenticatedUser(), $password);
|
|
|
|
$crawler = $client->request('POST', '/account/reset-password/', [
|
|
'password' => [
|
|
'password' => 'password',
|
|
'confirm' => 'password'
|
|
],
|
|
'oldPassword' => $password,
|
|
]);
|
|
|
|
$response = $client->getResponse();
|
|
|
|
$this->assertFalse($response->isRedirect());
|
|
$this->assertFormError($crawler, 1);
|
|
}
|
|
|
|
public function testPostRenewPassword()
|
|
{
|
|
$app = $this->getApplication();
|
|
$client = $this->getClient();
|
|
$password = $app['random.low']->generateString(8);
|
|
|
|
$app['manipulator.user']->setPassword($app->getAuthenticatedUser(), $password);
|
|
|
|
$client->request('POST', '/account/reset-password/', [
|
|
'password' => [
|
|
'password' => 'password',
|
|
'confirm' => 'password'
|
|
],
|
|
'oldPassword' => $password,
|
|
'_token' => 'token',
|
|
]);
|
|
|
|
$response = $client->getResponse();
|
|
|
|
$this->assertTrue($response->isRedirect());
|
|
$this->assertEquals('/account/', $response->headers->get('location'));
|
|
|
|
$this->assertFlashMessagePopulated($app, 'success', 1);
|
|
}
|
|
|
|
public function passwordProvider()
|
|
{
|
|
$factory = new Factory();
|
|
$generator = $factory->getLowStrengthGenerator();
|
|
|
|
return [
|
|
[$generator->generateString(8), 'password', 'not_identical_password'],
|
|
];
|
|
}
|
|
}
|