2015-02-24 18:05:19 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* @author Clark Tomlinson <fallen013@gmail.com>
|
|
|
|
* @since 3/5/15, 10:53 AM
|
|
|
|
* @link http:/www.clarkt.com
|
|
|
|
* @copyright Clark Tomlinson © 2015
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace OCA\Encryption\Tests;
|
|
|
|
|
|
|
|
|
|
|
|
use OCA\Encryption\KeyManager;
|
|
|
|
use Test\TestCase;
|
|
|
|
|
|
|
|
class KeyManagerTest extends TestCase {
|
|
|
|
/**
|
|
|
|
* @var KeyManager
|
|
|
|
*/
|
|
|
|
private $instance;
|
2015-03-30 21:01:50 +00:00
|
|
|
/**
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
private $userId;
|
2015-02-24 18:05:19 +00:00
|
|
|
|
2015-03-31 18:30:54 +00:00
|
|
|
/** @var string */
|
|
|
|
private $systemKeyId;
|
|
|
|
|
|
|
|
/** @var \PHPUnit_Framework_MockObject_MockObject */
|
|
|
|
private $keyStorageMock;
|
|
|
|
|
|
|
|
/** @var \PHPUnit_Framework_MockObject_MockObject */
|
|
|
|
private $cryptMock;
|
|
|
|
|
|
|
|
/** @var \PHPUnit_Framework_MockObject_MockObject */
|
|
|
|
private $userMock;
|
|
|
|
|
|
|
|
/** @var \PHPUnit_Framework_MockObject_MockObject */
|
|
|
|
private $sessionMock;
|
|
|
|
|
|
|
|
/** @var \PHPUnit_Framework_MockObject_MockObject */
|
|
|
|
private $logMock;
|
|
|
|
|
|
|
|
/** @var \PHPUnit_Framework_MockObject_MockObject */
|
|
|
|
private $utilMock;
|
|
|
|
|
|
|
|
/** @var \PHPUnit_Framework_MockObject_MockObject */
|
|
|
|
private $configMock;
|
|
|
|
|
2015-02-24 18:05:19 +00:00
|
|
|
public function setUp() {
|
|
|
|
parent::setUp();
|
2015-03-31 18:30:54 +00:00
|
|
|
$this->userId = 'user1';
|
|
|
|
$this->systemKeyId = 'systemKeyId';
|
|
|
|
$this->keyStorageMock = $this->getMock('OCP\Encryption\Keys\IStorage');
|
|
|
|
$this->cryptMock = $this->getMockBuilder('OCA\Encryption\Crypto\Crypt')
|
2015-02-24 18:05:19 +00:00
|
|
|
->disableOriginalConstructor()
|
|
|
|
->getMock();
|
2015-03-31 18:30:54 +00:00
|
|
|
$this->configMock = $this->getMock('OCP\IConfig');
|
|
|
|
$this->configMock->expects($this->any())
|
|
|
|
->method('getAppValue')
|
|
|
|
->willReturn($this->systemKeyId);
|
|
|
|
$this->userMock = $this->getMock('OCP\IUserSession');
|
|
|
|
$this->sessionMock = $this->getMockBuilder('OCA\Encryption\Session')
|
|
|
|
->disableOriginalConstructor()
|
|
|
|
->getMock();
|
|
|
|
$this->logMock = $this->getMock('OCP\ILogger');
|
|
|
|
$this->utilMock = $this->getMockBuilder('OCA\Encryption\Util')
|
2015-03-30 21:01:50 +00:00
|
|
|
->disableOriginalConstructor()
|
|
|
|
->getMock();
|
2015-04-01 17:07:54 +00:00
|
|
|
|
|
|
|
$this->instance = new KeyManager(
|
2015-03-31 18:30:54 +00:00
|
|
|
$this->keyStorageMock,
|
|
|
|
$this->cryptMock,
|
|
|
|
$this->configMock,
|
|
|
|
$this->userMock,
|
|
|
|
$this->sessionMock,
|
|
|
|
$this->logMock,
|
|
|
|
$this->utilMock);
|
2015-04-01 17:07:54 +00:00
|
|
|
}
|
2015-03-30 21:01:50 +00:00
|
|
|
|
2015-04-01 17:07:54 +00:00
|
|
|
public function testDeleteShareKey() {
|
|
|
|
$this->keyStorageMock->expects($this->any())
|
|
|
|
->method('deleteFileKey')
|
|
|
|
->with($this->equalTo('/path'), $this->equalTo('keyId.shareKey'))
|
|
|
|
->willReturn(true);
|
|
|
|
|
2015-03-31 18:30:54 +00:00
|
|
|
$this->assertTrue(
|
2015-04-01 17:07:54 +00:00
|
|
|
$this->instance->deleteShareKey('/path', 'keyId')
|
2015-03-31 18:30:54 +00:00
|
|
|
);
|
2015-02-24 18:05:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testGetPrivateKey() {
|
2015-03-31 18:30:54 +00:00
|
|
|
$this->keyStorageMock->expects($this->any())
|
|
|
|
->method('getUserKey')
|
|
|
|
->with($this->equalTo($this->userId), $this->equalTo('privateKey'))
|
|
|
|
->willReturn('privateKey');
|
2015-04-01 17:07:54 +00:00
|
|
|
|
2015-03-31 18:30:54 +00:00
|
|
|
|
|
|
|
$this->assertSame('privateKey',
|
2015-04-01 17:07:54 +00:00
|
|
|
$this->instance->getPrivateKey($this->userId)
|
2015-03-31 18:30:54 +00:00
|
|
|
);
|
2015-02-24 18:05:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testGetPublicKey() {
|
2015-03-31 18:30:54 +00:00
|
|
|
$this->keyStorageMock->expects($this->any())
|
|
|
|
->method('getUserKey')
|
|
|
|
->with($this->equalTo($this->userId), $this->equalTo('publicKey'))
|
|
|
|
->willReturn('publicKey');
|
2015-04-01 17:07:54 +00:00
|
|
|
|
2015-03-31 18:30:54 +00:00
|
|
|
|
|
|
|
$this->assertSame('publicKey',
|
2015-04-01 17:07:54 +00:00
|
|
|
$this->instance->getPublicKey($this->userId)
|
2015-03-31 18:30:54 +00:00
|
|
|
);
|
2015-02-24 18:05:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testRecoveryKeyExists() {
|
2015-03-31 18:30:54 +00:00
|
|
|
$this->keyStorageMock->expects($this->any())
|
|
|
|
->method('getSystemUserKey')
|
|
|
|
->with($this->equalTo($this->systemKeyId . '.publicKey'))
|
|
|
|
->willReturn('recoveryKey');
|
2015-04-01 17:07:54 +00:00
|
|
|
|
2015-03-31 18:30:54 +00:00
|
|
|
|
2015-04-01 17:07:54 +00:00
|
|
|
$this->assertTrue($this->instance->recoveryKeyExists());
|
2015-02-24 18:05:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testCheckRecoveryKeyPassword() {
|
2015-03-31 18:30:54 +00:00
|
|
|
$this->keyStorageMock->expects($this->any())
|
|
|
|
->method('getSystemUserKey')
|
|
|
|
->with($this->equalTo($this->systemKeyId . '.privateKey'))
|
|
|
|
->willReturn('recoveryKey');
|
|
|
|
$this->cryptMock->expects($this->any())
|
|
|
|
->method('decryptPrivateKey')
|
|
|
|
->with($this->equalTo('recoveryKey'), $this->equalTo('pass'))
|
|
|
|
->willReturn('decryptedRecoveryKey');
|
|
|
|
|
2015-04-01 17:07:54 +00:00
|
|
|
$this->assertTrue($this->instance->checkRecoveryPassword('pass'));
|
2015-02-24 18:05:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testSetPublicKey() {
|
2015-03-31 18:30:54 +00:00
|
|
|
$this->keyStorageMock->expects($this->any())
|
|
|
|
->method('setUserKey')
|
|
|
|
->with(
|
|
|
|
$this->equalTo($this->userId),
|
|
|
|
$this->equalTo('publicKey'),
|
|
|
|
$this->equalTo('key'))
|
|
|
|
->willReturn(true);
|
2015-04-01 17:07:54 +00:00
|
|
|
|
2015-03-31 18:30:54 +00:00
|
|
|
|
|
|
|
$this->assertTrue(
|
2015-04-01 17:07:54 +00:00
|
|
|
$this->instance->setPublicKey($this->userId, 'key')
|
2015-03-31 18:30:54 +00:00
|
|
|
);
|
2015-02-24 18:05:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testSetPrivateKey() {
|
2015-03-31 18:30:54 +00:00
|
|
|
$this->keyStorageMock->expects($this->any())
|
|
|
|
->method('setUserKey')
|
|
|
|
->with(
|
|
|
|
$this->equalTo($this->userId),
|
|
|
|
$this->equalTo('privateKey'),
|
|
|
|
$this->equalTo('key'))
|
|
|
|
->willReturn(true);
|
2015-04-01 17:07:54 +00:00
|
|
|
|
2015-03-31 18:30:54 +00:00
|
|
|
|
|
|
|
$this->assertTrue(
|
2015-04-01 17:07:54 +00:00
|
|
|
$this->instance->setPrivateKey($this->userId, 'key')
|
2015-03-31 18:30:54 +00:00
|
|
|
);
|
2015-02-24 18:05:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testUserHasKeys() {
|
2015-03-31 18:30:54 +00:00
|
|
|
$this->keyStorageMock->expects($this->exactly(2))
|
|
|
|
->method('getUserKey')
|
|
|
|
->with($this->equalTo($this->userId), $this->anything())
|
|
|
|
->willReturn('key');
|
2015-04-01 17:07:54 +00:00
|
|
|
|
2015-03-31 18:30:54 +00:00
|
|
|
|
|
|
|
$this->assertTrue(
|
2015-04-01 17:07:54 +00:00
|
|
|
$this->instance->userHasKeys($this->userId)
|
2015-03-31 18:30:54 +00:00
|
|
|
);
|
2015-02-24 18:05:19 +00:00
|
|
|
}
|
|
|
|
|
2015-03-24 21:29:10 +00:00
|
|
|
public function testInit() {
|
2015-03-31 18:30:54 +00:00
|
|
|
$this->keyStorageMock->expects($this->any())
|
|
|
|
->method('getUserKey')
|
|
|
|
->with($this->equalTo($this->userId), $this->equalTo('privateKey'))
|
|
|
|
->willReturn('privateKey');
|
|
|
|
$this->cryptMock->expects($this->any())
|
|
|
|
->method('decryptPrivateKey')
|
|
|
|
->with($this->equalTo('privateKey'), $this->equalTo('pass'))
|
|
|
|
->willReturn('decryptedPrivateKey');
|
2015-04-01 17:07:54 +00:00
|
|
|
|
2015-03-31 18:30:54 +00:00
|
|
|
|
|
|
|
$this->assertTrue(
|
2015-04-01 17:07:54 +00:00
|
|
|
$this->instance->init($this->userId, 'pass')
|
2015-03-31 18:30:54 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testSetRecoveryKey() {
|
|
|
|
$this->keyStorageMock->expects($this->exactly(2))
|
|
|
|
->method('setSystemUserKey')
|
|
|
|
->willReturn(true);
|
|
|
|
$this->cryptMock->expects($this->any())
|
|
|
|
->method('symmetricEncryptFileContent')
|
|
|
|
->with($this->equalTo('privateKey'), $this->equalTo('pass'))
|
|
|
|
->willReturn('decryptedPrivateKey');
|
2015-04-01 17:07:54 +00:00
|
|
|
|
2015-03-31 18:30:54 +00:00
|
|
|
|
|
|
|
$this->assertTrue(
|
2015-04-01 17:07:54 +00:00
|
|
|
$this->instance->setRecoveryKey('pass', array('publicKey' => 'publicKey', 'privateKey' => 'privateKey'))
|
2015-03-31 18:30:54 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2015-04-02 08:26:40 +00:00
|
|
|
public function testSetSystemPrivateKey() {
|
2015-03-31 18:30:54 +00:00
|
|
|
$this->keyStorageMock->expects($this->exactly(1))
|
|
|
|
->method('setSystemUserKey')
|
|
|
|
->with($this->equalTo('keyId.privateKey'), $this->equalTo('key'))
|
|
|
|
->willReturn(true);
|
2015-04-01 17:07:54 +00:00
|
|
|
|
2015-03-31 18:30:54 +00:00
|
|
|
|
|
|
|
$this->assertTrue(
|
2015-04-01 17:07:54 +00:00
|
|
|
$this->instance->setSystemPrivateKey('keyId', 'key')
|
2015-03-31 18:30:54 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2015-04-02 08:26:40 +00:00
|
|
|
public function testGetSystemPrivateKey() {
|
2015-03-31 18:30:54 +00:00
|
|
|
$this->keyStorageMock->expects($this->exactly(1))
|
2015-04-02 08:26:40 +00:00
|
|
|
->method('getSystemUserKey')
|
2015-03-31 18:30:54 +00:00
|
|
|
->with($this->equalTo('keyId.privateKey'))
|
|
|
|
->willReturn('systemPrivateKey');
|
2015-04-01 17:07:54 +00:00
|
|
|
|
2015-03-31 18:30:54 +00:00
|
|
|
|
|
|
|
$this->assertSame('systemPrivateKey',
|
2015-04-01 17:07:54 +00:00
|
|
|
$this->instance->getSystemPrivateKey('keyId')
|
2015-03-31 18:30:54 +00:00
|
|
|
);
|
2015-03-24 21:29:10 +00:00
|
|
|
}
|
2015-02-24 18:05:19 +00:00
|
|
|
}
|