SEBWIN-296: Implemented unit tests for public key hash encryption.
This commit is contained in:
parent
44df65e67a
commit
dd0fc7a09b
11 changed files with 291 additions and 48 deletions
|
@ -0,0 +1,94 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2019 ETH Zürich, Educational Development and Technology (LET)
|
||||||
|
*
|
||||||
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
||||||
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||||
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
||||||
|
*/
|
||||||
|
|
||||||
|
using System;
|
||||||
|
using System.IO;
|
||||||
|
using System.Reflection;
|
||||||
|
using System.Security.Cryptography.X509Certificates;
|
||||||
|
using System.Text;
|
||||||
|
using Microsoft.VisualStudio.TestTools.UnitTesting;
|
||||||
|
using Moq;
|
||||||
|
using SafeExamBrowser.Configuration.Cryptography;
|
||||||
|
using SafeExamBrowser.Contracts.Configuration;
|
||||||
|
using SafeExamBrowser.Contracts.Configuration.Cryptography;
|
||||||
|
using SafeExamBrowser.Contracts.Logging;
|
||||||
|
|
||||||
|
namespace SafeExamBrowser.Configuration.UnitTests.Cryptography
|
||||||
|
{
|
||||||
|
[TestClass]
|
||||||
|
public class PublicKeyHashEncryptionTests
|
||||||
|
{
|
||||||
|
private Mock<ILogger> logger;
|
||||||
|
private Mock<ICertificateStore> store;
|
||||||
|
private X509Certificate2 certificate;
|
||||||
|
|
||||||
|
private PublicKeyHashEncryption sut;
|
||||||
|
|
||||||
|
[TestInitialize]
|
||||||
|
public void Initialize()
|
||||||
|
{
|
||||||
|
logger = new Mock<ILogger>();
|
||||||
|
store = new Mock<ICertificateStore>();
|
||||||
|
|
||||||
|
LoadCertificate();
|
||||||
|
store.Setup(s => s.TryGetCertificateWith(It.IsAny<byte[]>(), out certificate)).Returns(true);
|
||||||
|
|
||||||
|
sut = new PublicKeyHashEncryption(store.Object, logger.Object);
|
||||||
|
}
|
||||||
|
|
||||||
|
[TestMethod]
|
||||||
|
public void MustPerformCorrectly()
|
||||||
|
{
|
||||||
|
var message = Encoding.UTF8.GetBytes("A super secret message!");
|
||||||
|
var saveStatus = sut.Encrypt(new MemoryStream(message), certificate, out var encrypted);
|
||||||
|
var loadStatus = sut.Decrypt(encrypted, out var decrypted, out _);
|
||||||
|
var original = new MemoryStream(message);
|
||||||
|
|
||||||
|
decrypted.Seek(0, SeekOrigin.Begin);
|
||||||
|
original.Seek(0, SeekOrigin.Begin);
|
||||||
|
|
||||||
|
while (original.Position < original.Length)
|
||||||
|
{
|
||||||
|
Assert.AreEqual(original.ReadByte(), decrypted.ReadByte());
|
||||||
|
}
|
||||||
|
|
||||||
|
Assert.AreEqual(SaveStatus.Success, saveStatus);
|
||||||
|
Assert.AreEqual(LoadStatus.Success, loadStatus);
|
||||||
|
}
|
||||||
|
|
||||||
|
[TestMethod]
|
||||||
|
public void MustFailIfCertificateNotFound()
|
||||||
|
{
|
||||||
|
store.Setup(s => s.TryGetCertificateWith(It.IsAny<byte[]>(), out certificate)).Returns(false);
|
||||||
|
|
||||||
|
var buffer = new byte[20];
|
||||||
|
new Random().NextBytes(buffer);
|
||||||
|
var data = new MemoryStream(buffer);
|
||||||
|
var status = sut.Decrypt(data, out _, out _);
|
||||||
|
|
||||||
|
Assert.AreEqual(LoadStatus.InvalidData, status);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// makecert -sv UnitTestCert.pvk -n "CN=Unit Test Certificate" UnitTestCert.cer -r -pe -sky eXchange
|
||||||
|
/// pvk2pfx -pvk UnitTestCert.pvk -spc UnitTestCert.cer -pfx UnitTestCert.pfx -f
|
||||||
|
/// </summary>
|
||||||
|
private void LoadCertificate()
|
||||||
|
{
|
||||||
|
var path = $"{nameof(SafeExamBrowser)}.{nameof(Configuration)}.{nameof(UnitTests)}.UnitTestCert.pfx";
|
||||||
|
|
||||||
|
using (var stream = Assembly.GetAssembly(GetType()).GetManifestResourceStream(path))
|
||||||
|
{
|
||||||
|
var data = new byte[stream.Length];
|
||||||
|
|
||||||
|
stream.Read(data, 0, (int)stream.Length);
|
||||||
|
certificate = new X509Certificate2(data);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,96 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2019 ETH Zürich, Educational Development and Technology (LET)
|
||||||
|
*
|
||||||
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
||||||
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||||
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
||||||
|
*/
|
||||||
|
|
||||||
|
using System;
|
||||||
|
using System.IO;
|
||||||
|
using System.Reflection;
|
||||||
|
using System.Security.Cryptography.X509Certificates;
|
||||||
|
using System.Text;
|
||||||
|
using Microsoft.VisualStudio.TestTools.UnitTesting;
|
||||||
|
using Moq;
|
||||||
|
using SafeExamBrowser.Configuration.Cryptography;
|
||||||
|
using SafeExamBrowser.Contracts.Configuration;
|
||||||
|
using SafeExamBrowser.Contracts.Configuration.Cryptography;
|
||||||
|
using SafeExamBrowser.Contracts.Logging;
|
||||||
|
|
||||||
|
namespace SafeExamBrowser.Configuration.UnitTests.Cryptography
|
||||||
|
{
|
||||||
|
[TestClass]
|
||||||
|
public class PublicKeyHashWithSymmetricKeyEncryptionTests
|
||||||
|
{
|
||||||
|
private Mock<ILogger> logger;
|
||||||
|
private PasswordEncryption passwordEncryption;
|
||||||
|
private Mock<ICertificateStore> store;
|
||||||
|
|
||||||
|
private PublicKeyHashWithSymmetricKeyEncryption sut;
|
||||||
|
private X509Certificate2 certificate;
|
||||||
|
|
||||||
|
[TestInitialize]
|
||||||
|
public void Initialize()
|
||||||
|
{
|
||||||
|
logger = new Mock<ILogger>();
|
||||||
|
passwordEncryption = new PasswordEncryption(logger.Object);
|
||||||
|
store = new Mock<ICertificateStore>();
|
||||||
|
|
||||||
|
LoadCertificate();
|
||||||
|
store.Setup(s => s.TryGetCertificateWith(It.IsAny<byte[]>(), out certificate)).Returns(true);
|
||||||
|
|
||||||
|
sut = new PublicKeyHashWithSymmetricKeyEncryption(store.Object, logger.Object, passwordEncryption);
|
||||||
|
}
|
||||||
|
|
||||||
|
[TestMethod]
|
||||||
|
public void MustPerformCorrectly()
|
||||||
|
{
|
||||||
|
var message = Encoding.UTF8.GetBytes("A super secret message!");
|
||||||
|
var saveStatus = sut.Encrypt(new MemoryStream(message), certificate, out var encrypted);
|
||||||
|
var loadStatus = sut.Decrypt(encrypted, out var decrypted, out _);
|
||||||
|
var original = new MemoryStream(message);
|
||||||
|
|
||||||
|
decrypted.Seek(0, SeekOrigin.Begin);
|
||||||
|
original.Seek(0, SeekOrigin.Begin);
|
||||||
|
|
||||||
|
while (original.Position < original.Length)
|
||||||
|
{
|
||||||
|
Assert.AreEqual(original.ReadByte(), decrypted.ReadByte());
|
||||||
|
}
|
||||||
|
|
||||||
|
Assert.AreEqual(SaveStatus.Success, saveStatus);
|
||||||
|
Assert.AreEqual(LoadStatus.Success, loadStatus);
|
||||||
|
}
|
||||||
|
|
||||||
|
[TestMethod]
|
||||||
|
public void MustFailIfCertificateNotFound()
|
||||||
|
{
|
||||||
|
store.Setup(s => s.TryGetCertificateWith(It.IsAny<byte[]>(), out certificate)).Returns(false);
|
||||||
|
|
||||||
|
var buffer = new byte[20];
|
||||||
|
new Random().NextBytes(buffer);
|
||||||
|
var data = new MemoryStream(buffer);
|
||||||
|
var status = sut.Decrypt(data, out _, out _);
|
||||||
|
|
||||||
|
Assert.AreEqual(LoadStatus.InvalidData, status);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// makecert -sv UnitTestCert.pvk -n "CN=Unit Test Certificate" UnitTestCert.cer -r -pe -sky eXchange
|
||||||
|
/// pvk2pfx -pvk UnitTestCert.pvk -spc UnitTestCert.cer -pfx UnitTestCert.pfx -f
|
||||||
|
/// </summary>
|
||||||
|
private void LoadCertificate()
|
||||||
|
{
|
||||||
|
var path = $"{nameof(SafeExamBrowser)}.{nameof(Configuration)}.{nameof(UnitTests)}.UnitTestCert.pfx";
|
||||||
|
|
||||||
|
using (var stream = Assembly.GetAssembly(GetType()).GetManifestResourceStream(path))
|
||||||
|
{
|
||||||
|
var data = new byte[stream.Length];
|
||||||
|
|
||||||
|
stream.Read(data, 0, (int)stream.Length);
|
||||||
|
certificate = new X509Certificate2(data);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -86,11 +86,14 @@
|
||||||
<Compile Include="ConfigurationRepositoryTests.cs" />
|
<Compile Include="ConfigurationRepositoryTests.cs" />
|
||||||
<Compile Include="Cryptography\HashAlgorithmTests.cs" />
|
<Compile Include="Cryptography\HashAlgorithmTests.cs" />
|
||||||
<Compile Include="Cryptography\PasswordEncryptionTests.cs" />
|
<Compile Include="Cryptography\PasswordEncryptionTests.cs" />
|
||||||
|
<Compile Include="Cryptography\PublicKeyHashEncryptionTests.cs" />
|
||||||
|
<Compile Include="Cryptography\PublicKeyHashWithSymmetricKeyEncryptionTests.cs" />
|
||||||
<Compile Include="Properties\AssemblyInfo.cs" />
|
<Compile Include="Properties\AssemblyInfo.cs" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<None Include="app.config" />
|
<None Include="app.config" />
|
||||||
<None Include="packages.config" />
|
<None Include="packages.config" />
|
||||||
|
<EmbeddedResource Include="UnitTestCert.pfx" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<ProjectReference Include="..\SafeExamBrowser.Configuration\SafeExamBrowser.Configuration.csproj">
|
<ProjectReference Include="..\SafeExamBrowser.Configuration\SafeExamBrowser.Configuration.csproj">
|
||||||
|
|
|
@ -0,0 +1,60 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2019 ETH Zürich, Educational Development and Technology (LET)
|
||||||
|
*
|
||||||
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
||||||
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||||
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
||||||
|
*/
|
||||||
|
|
||||||
|
using System.Linq;
|
||||||
|
using System.Security.Cryptography;
|
||||||
|
using System.Security.Cryptography.X509Certificates;
|
||||||
|
using SafeExamBrowser.Contracts.Configuration.Cryptography;
|
||||||
|
|
||||||
|
namespace SafeExamBrowser.Configuration.Cryptography
|
||||||
|
{
|
||||||
|
internal class CertificateStore : ICertificateStore
|
||||||
|
{
|
||||||
|
private readonly X509Store[] stores = new[]
|
||||||
|
{
|
||||||
|
new X509Store(StoreLocation.CurrentUser),
|
||||||
|
new X509Store(StoreLocation.LocalMachine),
|
||||||
|
new X509Store(StoreName.TrustedPeople)
|
||||||
|
};
|
||||||
|
|
||||||
|
public bool TryGetCertificateWith(byte[] keyHash, out X509Certificate2 certificate)
|
||||||
|
{
|
||||||
|
certificate = default(X509Certificate2);
|
||||||
|
|
||||||
|
using (var algorithm = new SHA1CryptoServiceProvider())
|
||||||
|
{
|
||||||
|
foreach (var store in stores)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
store.Open(OpenFlags.ReadOnly);
|
||||||
|
|
||||||
|
foreach (var current in store.Certificates)
|
||||||
|
{
|
||||||
|
var publicKey = current.PublicKey.EncodedKeyValue.RawData;
|
||||||
|
var publicKeyHash = algorithm.ComputeHash(publicKey);
|
||||||
|
|
||||||
|
if (publicKeyHash.SequenceEqual(keyHash))
|
||||||
|
{
|
||||||
|
certificate = current;
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
finally
|
||||||
|
{
|
||||||
|
store.Close();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -7,10 +7,10 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
using System.IO;
|
using System.IO;
|
||||||
using System.Linq;
|
|
||||||
using System.Security.Cryptography;
|
using System.Security.Cryptography;
|
||||||
using System.Security.Cryptography.X509Certificates;
|
using System.Security.Cryptography.X509Certificates;
|
||||||
using SafeExamBrowser.Contracts.Configuration;
|
using SafeExamBrowser.Contracts.Configuration;
|
||||||
|
using SafeExamBrowser.Contracts.Configuration.Cryptography;
|
||||||
using SafeExamBrowser.Contracts.Logging;
|
using SafeExamBrowser.Contracts.Logging;
|
||||||
|
|
||||||
namespace SafeExamBrowser.Configuration.Cryptography
|
namespace SafeExamBrowser.Configuration.Cryptography
|
||||||
|
@ -19,17 +19,19 @@ namespace SafeExamBrowser.Configuration.Cryptography
|
||||||
{
|
{
|
||||||
protected const int PUBLIC_KEY_HASH_SIZE = 20;
|
protected const int PUBLIC_KEY_HASH_SIZE = 20;
|
||||||
|
|
||||||
|
protected ICertificateStore store;
|
||||||
protected ILogger logger;
|
protected ILogger logger;
|
||||||
|
|
||||||
internal PublicKeyHashEncryption(ILogger logger)
|
internal PublicKeyHashEncryption(ICertificateStore store, ILogger logger)
|
||||||
{
|
{
|
||||||
this.logger = logger;
|
this.logger = logger;
|
||||||
|
this.store = store;
|
||||||
}
|
}
|
||||||
|
|
||||||
internal virtual LoadStatus Decrypt(Stream data, out Stream decryptedData, out X509Certificate2 certificate)
|
internal virtual LoadStatus Decrypt(Stream data, out Stream decryptedData, out X509Certificate2 certificate)
|
||||||
{
|
{
|
||||||
var publicKeyHash = ParsePublicKeyHash(data);
|
var publicKeyHash = ParsePublicKeyHash(data);
|
||||||
var found = TryGetCertificateWith(publicKeyHash, out certificate);
|
var found = store.TryGetCertificateWith(publicKeyHash, out certificate);
|
||||||
|
|
||||||
decryptedData = default(Stream);
|
decryptedData = default(Stream);
|
||||||
|
|
||||||
|
@ -82,45 +84,6 @@ namespace SafeExamBrowser.Configuration.Cryptography
|
||||||
return keyHash;
|
return keyHash;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected bool TryGetCertificateWith(byte[] keyHash, out X509Certificate2 certificate)
|
|
||||||
{
|
|
||||||
var storesToSearch = new[]
|
|
||||||
{
|
|
||||||
new X509Store(StoreLocation.CurrentUser),
|
|
||||||
new X509Store(StoreLocation.LocalMachine),
|
|
||||||
new X509Store(StoreName.TrustedPeople)
|
|
||||||
};
|
|
||||||
|
|
||||||
certificate = default(X509Certificate2);
|
|
||||||
logger.Debug("Searching certificate for decryption...");
|
|
||||||
|
|
||||||
using (var algorithm = new SHA1CryptoServiceProvider())
|
|
||||||
{
|
|
||||||
foreach (var store in storesToSearch)
|
|
||||||
{
|
|
||||||
store.Open(OpenFlags.ReadOnly);
|
|
||||||
|
|
||||||
foreach (var current in store.Certificates)
|
|
||||||
{
|
|
||||||
var publicKey = current.PublicKey.EncodedKeyValue.RawData;
|
|
||||||
var publicKeyHash = algorithm.ComputeHash(publicKey);
|
|
||||||
|
|
||||||
if (publicKeyHash.SequenceEqual(keyHash))
|
|
||||||
{
|
|
||||||
certificate = current;
|
|
||||||
store.Close();
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
store.Close();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected MemoryStream Decrypt(Stream data, long offset, X509Certificate2 certificate)
|
protected MemoryStream Decrypt(Stream data, long offset, X509Certificate2 certificate)
|
||||||
{
|
{
|
||||||
var algorithm = certificate.PrivateKey as RSACryptoServiceProvider;
|
var algorithm = certificate.PrivateKey as RSACryptoServiceProvider;
|
||||||
|
|
|
@ -11,6 +11,7 @@ using System.IO;
|
||||||
using System.Security.Cryptography;
|
using System.Security.Cryptography;
|
||||||
using System.Security.Cryptography.X509Certificates;
|
using System.Security.Cryptography.X509Certificates;
|
||||||
using SafeExamBrowser.Contracts.Configuration;
|
using SafeExamBrowser.Contracts.Configuration;
|
||||||
|
using SafeExamBrowser.Contracts.Configuration.Cryptography;
|
||||||
using SafeExamBrowser.Contracts.Logging;
|
using SafeExamBrowser.Contracts.Logging;
|
||||||
|
|
||||||
namespace SafeExamBrowser.Configuration.Cryptography
|
namespace SafeExamBrowser.Configuration.Cryptography
|
||||||
|
@ -22,7 +23,7 @@ namespace SafeExamBrowser.Configuration.Cryptography
|
||||||
|
|
||||||
private PasswordEncryption passwordEncryption;
|
private PasswordEncryption passwordEncryption;
|
||||||
|
|
||||||
internal PublicKeyHashWithSymmetricKeyEncryption(ILogger logger, PasswordEncryption passwordEncryption) : base(logger)
|
internal PublicKeyHashWithSymmetricKeyEncryption(ICertificateStore store, ILogger logger, PasswordEncryption passwordEncryption) : base(store, logger)
|
||||||
{
|
{
|
||||||
this.passwordEncryption = passwordEncryption;
|
this.passwordEncryption = passwordEncryption;
|
||||||
}
|
}
|
||||||
|
@ -30,7 +31,7 @@ namespace SafeExamBrowser.Configuration.Cryptography
|
||||||
internal override LoadStatus Decrypt(Stream data, out Stream decryptedData, out X509Certificate2 certificate)
|
internal override LoadStatus Decrypt(Stream data, out Stream decryptedData, out X509Certificate2 certificate)
|
||||||
{
|
{
|
||||||
var publicKeyHash = ParsePublicKeyHash(data);
|
var publicKeyHash = ParsePublicKeyHash(data);
|
||||||
var found = TryGetCertificateWith(publicKeyHash, out certificate);
|
var found = store.TryGetCertificateWith(publicKeyHash, out certificate);
|
||||||
|
|
||||||
decryptedData = default(Stream);
|
decryptedData = default(Stream);
|
||||||
|
|
||||||
|
|
|
@ -156,10 +156,10 @@ namespace SafeExamBrowser.Configuration.DataFormats
|
||||||
|
|
||||||
if (prefix == BinaryBlock.PublicKeyHash)
|
if (prefix == BinaryBlock.PublicKeyHash)
|
||||||
{
|
{
|
||||||
return new PublicKeyHashEncryption(logger.CloneFor(nameof(PublicKeyHashEncryption)));
|
return new PublicKeyHashEncryption(new CertificateStore(), logger.CloneFor(nameof(PublicKeyHashEncryption)));
|
||||||
}
|
}
|
||||||
|
|
||||||
return new PublicKeyHashWithSymmetricKeyEncryption(logger.CloneFor(nameof(PublicKeyHashWithSymmetricKeyEncryption)), passwordEncryption);
|
return new PublicKeyHashWithSymmetricKeyEncryption(new CertificateStore(), logger.CloneFor(nameof(PublicKeyHashWithSymmetricKeyEncryption)), passwordEncryption);
|
||||||
}
|
}
|
||||||
|
|
||||||
private PasswordParameters DetermineEncryptionParametersFor(string prefix, PasswordParameters password)
|
private PasswordParameters DetermineEncryptionParametersFor(string prefix, PasswordParameters password)
|
||||||
|
|
|
@ -141,10 +141,10 @@ namespace SafeExamBrowser.Configuration.DataFormats
|
||||||
|
|
||||||
if (parameters.SymmetricEncryption)
|
if (parameters.SymmetricEncryption)
|
||||||
{
|
{
|
||||||
return new PublicKeyHashWithSymmetricKeyEncryption(logger.CloneFor(nameof(PublicKeyHashWithSymmetricKeyEncryption)), passwordEncryption);
|
return new PublicKeyHashWithSymmetricKeyEncryption(new CertificateStore(), logger.CloneFor(nameof(PublicKeyHashWithSymmetricKeyEncryption)), passwordEncryption);
|
||||||
}
|
}
|
||||||
|
|
||||||
return new PublicKeyHashEncryption(logger.CloneFor(nameof(PublicKeyHashEncryption)));
|
return new PublicKeyHashEncryption(new CertificateStore(), logger.CloneFor(nameof(PublicKeyHashEncryption)));
|
||||||
}
|
}
|
||||||
|
|
||||||
private Stream WritePrefix(string prefix, Stream data)
|
private Stream WritePrefix(string prefix, Stream data)
|
||||||
|
|
|
@ -61,6 +61,7 @@
|
||||||
<Compile Include="ConfigurationData\CertificateImporter.cs" />
|
<Compile Include="ConfigurationData\CertificateImporter.cs" />
|
||||||
<Compile Include="ConfigurationData\Keys.cs" />
|
<Compile Include="ConfigurationData\Keys.cs" />
|
||||||
<Compile Include="ConfigurationData\DataValues.cs" />
|
<Compile Include="ConfigurationData\DataValues.cs" />
|
||||||
|
<Compile Include="Cryptography\CertificateStore.cs" />
|
||||||
<Compile Include="DataCompression\GZipCompressor.cs" />
|
<Compile Include="DataCompression\GZipCompressor.cs" />
|
||||||
<Compile Include="Cryptography\PasswordEncryption.cs" />
|
<Compile Include="Cryptography\PasswordEncryption.cs" />
|
||||||
<Compile Include="Cryptography\PublicKeyHashEncryption.cs" />
|
<Compile Include="Cryptography\PublicKeyHashEncryption.cs" />
|
||||||
|
|
|
@ -0,0 +1,24 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2019 ETH Zürich, Educational Development and Technology (LET)
|
||||||
|
*
|
||||||
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
||||||
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||||
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
||||||
|
*/
|
||||||
|
|
||||||
|
using System.Security.Cryptography.X509Certificates;
|
||||||
|
|
||||||
|
namespace SafeExamBrowser.Contracts.Configuration.Cryptography
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Provides functionality to load certificates installed on the computer.
|
||||||
|
/// </summary>
|
||||||
|
public interface ICertificateStore
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Attempts to retrieve the certificate which matches the specified public key hash value.
|
||||||
|
/// Returns <c>true</c> if the certificate was found, otherwise <c>false</c>.
|
||||||
|
/// </summary>
|
||||||
|
bool TryGetCertificateWith(byte[] keyHash, out X509Certificate2 certificate);
|
||||||
|
}
|
||||||
|
}
|
|
@ -58,6 +58,7 @@
|
||||||
<Compile Include="Communication\Events\MessageBoxReplyEventArgs.cs" />
|
<Compile Include="Communication\Events\MessageBoxReplyEventArgs.cs" />
|
||||||
<Compile Include="Communication\Events\MessageBoxRequestEventArgs.cs" />
|
<Compile Include="Communication\Events\MessageBoxRequestEventArgs.cs" />
|
||||||
<Compile Include="Configuration\Cryptography\EncryptionParameters.cs" />
|
<Compile Include="Configuration\Cryptography\EncryptionParameters.cs" />
|
||||||
|
<Compile Include="Configuration\Cryptography\ICertificateStore.cs" />
|
||||||
<Compile Include="Configuration\Cryptography\PasswordParameters.cs" />
|
<Compile Include="Configuration\Cryptography\PasswordParameters.cs" />
|
||||||
<Compile Include="Configuration\Cryptography\PublicKeyHashParameters.cs" />
|
<Compile Include="Configuration\Cryptography\PublicKeyHashParameters.cs" />
|
||||||
<Compile Include="Configuration\DataFormats\FormatType.cs" />
|
<Compile Include="Configuration\DataFormats\FormatType.cs" />
|
||||||
|
|
Loading…
Reference in a new issue