webauthn
This commit is contained in:
parent
68f6f3eafe
commit
7514ec6b84
|
@ -1,15 +1,16 @@
|
||||||
<?php
|
<?php
|
||||||
use PHPUnit\Framework\TestCase;
|
namespace LAM\LOGIN\WEBAUTHN;
|
||||||
use \LAM\LOGIN\WEBAUTHN\PublicKeyCredentialSourceRepositorySQLite;
|
|
||||||
use Webauthn\PublicKeyCredentialDescriptor;
|
use \PHPUnit\Framework\TestCase;
|
||||||
|
use \Webauthn\PublicKeyCredentialDescriptor;
|
||||||
use \Webauthn\PublicKeyCredentialUserEntity;
|
use \Webauthn\PublicKeyCredentialUserEntity;
|
||||||
use \Webauthn\PublicKeyCredentialSource;
|
use \Webauthn\PublicKeyCredentialSource;
|
||||||
use Webauthn\TrustPath\CertificateTrustPath;
|
use \Webauthn\TrustPath\CertificateTrustPath;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
||||||
This code is part of LDAP Account Manager (http://www.ldap-account-manager.org/)
|
This code is part of LDAP Account Manager (http://www.ldap-account-manager.org/)
|
||||||
Copyright (C) 2019 Roland Gruber
|
Copyright (C) 2019 - 2020 Roland Gruber
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify
|
This program is free software; you can redistribute it and/or modify
|
||||||
it under the terms of the GNU General Public License as published by
|
it under the terms of the GNU General Public License as published by
|
||||||
|
@ -27,8 +28,87 @@ use Webauthn\TrustPath\CertificateTrustPath;
|
||||||
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
require_once 'lam/lib/modules.inc';
|
require_once __DIR__ . '/../../lib/modules.inc';
|
||||||
require_once 'lam/lib/webauthn.inc';
|
require_once __DIR__ . '/../../lib/webauthn.inc';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Checks the webauthn functionality.
|
||||||
|
*
|
||||||
|
* @author Roland Gruber
|
||||||
|
*/
|
||||||
|
class WebauthnManagerTest extends TestCase {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var \PHPUnit_Framework_MockObject_MockObject|PublicKeyCredentialSourceRepositorySQLite
|
||||||
|
*/
|
||||||
|
private $database;
|
||||||
|
/**
|
||||||
|
* @var \PHPUnit_Framework_MockObject_MockObject|WebauthnManager
|
||||||
|
*/
|
||||||
|
private $manager;
|
||||||
|
|
||||||
|
protected function setup(): void {
|
||||||
|
$this->database = $this
|
||||||
|
->getMockBuilder(PublicKeyCredentialSourceRepositorySQLite::class)
|
||||||
|
->setMethods(array('findOneByCredentialId', 'findAllForUserEntity', 'saveCredentialSource'))
|
||||||
|
->getMock();
|
||||||
|
$this->database->method('findOneByCredentialId')->willReturn(null);
|
||||||
|
$this->database->method('findAllForUserEntity')->willReturn(array());
|
||||||
|
$this->database->method('saveCredentialSource')->willReturn(true);
|
||||||
|
|
||||||
|
$this->manager = $this
|
||||||
|
->getMockBuilder(WebauthnManager::class)
|
||||||
|
->setMethods(array('getDatabase'))
|
||||||
|
->getMock();
|
||||||
|
$this->manager->method('getDatabase')->willReturn($this->database);
|
||||||
|
|
||||||
|
$cfgMain = new \LAMCfgMain();
|
||||||
|
$cfgMain->passwordMinLength = 3;
|
||||||
|
$logFile = tmpfile();
|
||||||
|
$logFilePath = stream_get_meta_data($logFile)['uri'];
|
||||||
|
$cfgMain->logDestination = $logFilePath;
|
||||||
|
$_SESSION['cfgMain'] = $cfgMain;
|
||||||
|
|
||||||
|
$file = tmpfile();
|
||||||
|
$filePath = stream_get_meta_data($file)['uri'];
|
||||||
|
$config = new \LAMConfig($filePath);
|
||||||
|
$config->setTwoFactorAuthenticationDomain('domain');
|
||||||
|
$_SESSION['config'] = $config;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function test_getAuthenticationObject() {
|
||||||
|
$authenticationObj = $this->manager->getAuthenticationObject('userDN', false);
|
||||||
|
$this->assertEquals(40, sizeof($authenticationObj->getChallenge()));
|
||||||
|
$this->assertEquals('domain', $authenticationObj->getRpId());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function test_getRegistrationObject() {
|
||||||
|
$registrationObject = $this->manager->getRegistrationObject('userDn', false);
|
||||||
|
$this->assertEquals(40, sizeof($registrationObject->getChallenge()));
|
||||||
|
$this->assertEquals('domain', $registrationObject->getRp()->getId());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function test_isRegistered() {
|
||||||
|
$this->database->method('findAllForUserEntity')->willReturn(array());
|
||||||
|
$isRegistered = $this->manager->isRegistered('userDN');
|
||||||
|
$this->assertFalse($isRegistered);
|
||||||
|
$this->database->method('findAllForUserEntity')->willReturn(array(
|
||||||
|
new PublicKeyCredentialSource(
|
||||||
|
"id1",
|
||||||
|
PublicKeyCredentialDescriptor::CREDENTIAL_TYPE_PUBLIC_KEY,
|
||||||
|
array(),
|
||||||
|
"atype",
|
||||||
|
new CertificateTrustPath(array('x5c' => 'test')),
|
||||||
|
\Ramsey\Uuid\Uuid::uuid1(),
|
||||||
|
"p1",
|
||||||
|
"uh1",
|
||||||
|
1)
|
||||||
|
));
|
||||||
|
$isRegistered = $this->manager->isRegistered('userDN');
|
||||||
|
$this->assertTrue($isRegistered);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Checks the webauthn database functionality.
|
* Checks the webauthn database functionality.
|
||||||
|
@ -38,7 +118,7 @@ require_once 'lam/lib/webauthn.inc';
|
||||||
class PublicKeyCredentialSourceRepositorySQLiteTest extends TestCase {
|
class PublicKeyCredentialSourceRepositorySQLiteTest extends TestCase {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @var PublicKeyCredentialSourceRepositorySQLite
|
* @var \PHPUnit_Framework_MockObject_MockObject|PublicKeyCredentialSourceRepositorySQLite
|
||||||
*/
|
*/
|
||||||
private $database;
|
private $database;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue