2015-10-14 17:10:12 +02:00
|
|
|
<?php
|
|
|
|
|
2016-06-01 21:27:35 +02:00
|
|
|
namespace Tests\Wallabag\CoreBundle\Controller;
|
2015-10-14 17:10:12 +02:00
|
|
|
|
2016-06-01 21:27:35 +02:00
|
|
|
use Tests\Wallabag\CoreBundle\WallabagCoreTestCase;
|
2015-10-14 17:10:12 +02:00
|
|
|
|
|
|
|
class SecurityControllerTest extends WallabagCoreTestCase
|
|
|
|
{
|
|
|
|
public function testLoginWithout2Factor()
|
|
|
|
{
|
|
|
|
$this->logInAs('admin');
|
|
|
|
$client = $this->getClient();
|
|
|
|
$client->followRedirects();
|
|
|
|
|
2016-03-09 08:59:08 +01:00
|
|
|
$crawler = $client->request('GET', '/config');
|
2016-04-12 11:36:01 +02:00
|
|
|
$this->assertContains('config.form_rss.description', $crawler->filter('body')->extract(['_text'])[0]);
|
2015-10-14 17:10:12 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testLoginWith2Factor()
|
|
|
|
{
|
|
|
|
$client = $this->getClient();
|
|
|
|
|
2016-03-09 08:59:08 +01:00
|
|
|
if (!$client->getContainer()->getParameter('twofactor_auth')) {
|
|
|
|
$this->markTestSkipped('twofactor_auth is not enabled.');
|
2016-03-11 14:55:02 +01:00
|
|
|
|
2016-03-09 08:59:08 +01:00
|
|
|
return;
|
|
|
|
}
|
2015-10-14 17:10:12 +02:00
|
|
|
|
2016-03-09 08:59:08 +01:00
|
|
|
$client->followRedirects();
|
2015-10-15 13:17:21 +02:00
|
|
|
|
2016-03-09 08:59:08 +01:00
|
|
|
$em = $client->getContainer()->get('doctrine.orm.entity_manager');
|
|
|
|
$user = $em
|
|
|
|
->getRepository('WallabagUserBundle:User')
|
|
|
|
->findOneByUsername('admin');
|
|
|
|
$user->setTwoFactorAuthentication(true);
|
|
|
|
$em->persist($user);
|
|
|
|
$em->flush();
|
2015-10-15 13:17:21 +02:00
|
|
|
|
2016-06-24 11:55:45 +02:00
|
|
|
$this->logInAsUsingHttp('admin');
|
2016-03-09 08:59:08 +01:00
|
|
|
$crawler = $client->request('GET', '/config');
|
2016-04-12 11:36:01 +02:00
|
|
|
$this->assertContains('scheb_two_factor.trusted', $crawler->filter('body')->extract(['_text'])[0]);
|
2016-03-09 08:59:08 +01:00
|
|
|
|
|
|
|
// restore user
|
|
|
|
$user = $em
|
|
|
|
->getRepository('WallabagUserBundle:User')
|
|
|
|
->findOneByUsername('admin');
|
|
|
|
$user->setTwoFactorAuthentication(false);
|
|
|
|
$em->persist($user);
|
|
|
|
$em->flush();
|
2015-10-14 17:10:12 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testTrustedComputer()
|
|
|
|
{
|
|
|
|
$client = $this->getClient();
|
2015-10-15 13:17:21 +02:00
|
|
|
|
2016-03-09 08:59:08 +01:00
|
|
|
if (!$client->getContainer()->getParameter('twofactor_auth')) {
|
|
|
|
$this->markTestSkipped('twofactor_auth is not enabled.');
|
2016-03-11 14:55:02 +01:00
|
|
|
|
2016-03-09 08:59:08 +01:00
|
|
|
return;
|
2015-10-15 13:17:21 +02:00
|
|
|
}
|
2016-03-09 08:59:08 +01:00
|
|
|
|
|
|
|
$em = $client->getContainer()->get('doctrine.orm.entity_manager');
|
|
|
|
$user = $em
|
|
|
|
->getRepository('WallabagUserBundle:User')
|
|
|
|
->findOneByUsername('admin');
|
|
|
|
|
|
|
|
$date = new \DateTime();
|
|
|
|
$user->addTrustedComputer('ABCDEF', $date->add(new \DateInterval('P1M')));
|
|
|
|
$this->assertTrue($user->isTrustedComputer('ABCDEF'));
|
|
|
|
$this->assertFalse($user->isTrustedComputer('FEDCBA'));
|
2015-10-14 17:10:12 +02:00
|
|
|
}
|
|
|
|
}
|