SEBWIN-309, SEBWIN-358: Corrected usage of salt value for browser exam key.
This commit is contained in:
parent
1a840ffac5
commit
6ad5d062db
4 changed files with 12 additions and 10 deletions
|
@ -130,13 +130,16 @@ namespace SafeExamBrowser.Browser.Handlers
|
||||||
|
|
||||||
private string ComputeBrowserExamKey()
|
private string ComputeBrowserExamKey()
|
||||||
{
|
{
|
||||||
var hash = algorithm.ComputeHash(Encoding.UTF8.GetBytes(settings.ExamKeySalt + appConfig.CodeSignatureHash + appConfig.ProgramBuildVersion + settings.ConfigurationKey));
|
using (var algorithm = new HMACSHA256(settings.ExamKeySalt))
|
||||||
|
{
|
||||||
|
var hash = algorithm.ComputeHash(Encoding.UTF8.GetBytes(appConfig.CodeSignatureHash + appConfig.ProgramBuildVersion + settings.ConfigurationKey));
|
||||||
var key = BitConverter.ToString(hash).ToLower().Replace("-", string.Empty);
|
var key = BitConverter.ToString(hash).ToLower().Replace("-", string.Empty);
|
||||||
|
|
||||||
browserExamKey = key;
|
browserExamKey = key;
|
||||||
|
|
||||||
return browserExamKey;
|
return browserExamKey;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private bool IsMailtoUrl(string url)
|
private bool IsMailtoUrl(string url)
|
||||||
{
|
{
|
||||||
|
|
|
@ -6,7 +6,6 @@
|
||||||
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using SafeExamBrowser.Settings;
|
using SafeExamBrowser.Settings;
|
||||||
using SafeExamBrowser.Settings.Browser;
|
using SafeExamBrowser.Settings.Browser;
|
||||||
|
@ -281,7 +280,7 @@ namespace SafeExamBrowser.Configuration.ConfigurationData.DataMapping
|
||||||
{
|
{
|
||||||
if (value is byte[] salt)
|
if (value is byte[] salt)
|
||||||
{
|
{
|
||||||
settings.Browser.ExamKeySalt = BitConverter.ToString(salt).ToLower().Replace("-", string.Empty);
|
settings.Browser.ExamKeySalt = salt;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -94,7 +94,7 @@ namespace SafeExamBrowser.Settings.Browser
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// The salt value for the calculation of the exam key which is used for integrity checks with server applications (see also <see cref="SendExamKey"/>).
|
/// The salt value for the calculation of the exam key which is used for integrity checks with server applications (see also <see cref="SendExamKey"/>).
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public string ExamKeySalt { get; set; }
|
public byte[] ExamKeySalt { get; set; }
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// The settings to be used for the browser request filter.
|
/// The settings to be used for the browser request filter.
|
||||||
|
|
|
@ -574,14 +574,14 @@ namespace SebWindowsConfig.Utilities
|
||||||
{
|
{
|
||||||
var executable = Assembly.GetExecutingAssembly();
|
var executable = Assembly.GetExecutingAssembly();
|
||||||
var certificate = executable.Modules.First().GetSignerCertificate();
|
var certificate = executable.Modules.First().GetSignerCertificate();
|
||||||
var salt = BitConverter.ToString((byte[])SEBSettings.settingsCurrent[SEBSettings.KeyExamKeySalt]).ToLower().Replace("-", string.Empty);
|
var salt = (byte[]) SEBSettings.settingsCurrent[SEBSettings.KeyExamKeySalt];
|
||||||
var signature = certificate?.GetCertHashString();
|
var signature = certificate?.GetCertHashString();
|
||||||
var version = FileVersionInfo.GetVersionInfo(executable.Location).FileVersion;
|
var version = FileVersionInfo.GetVersionInfo(executable.Location).FileVersion;
|
||||||
var configurationKey = ComputeConfigurationKey();
|
var configurationKey = ComputeConfigurationKey();
|
||||||
|
|
||||||
using (var algorithm = new SHA256Managed())
|
using (var algorithm = new HMACSHA256(salt))
|
||||||
{
|
{
|
||||||
var hash = algorithm.ComputeHash(Encoding.UTF8.GetBytes(salt + signature + version + configurationKey));
|
var hash = algorithm.ComputeHash(Encoding.UTF8.GetBytes(signature + version + configurationKey));
|
||||||
var key = BitConverter.ToString(hash).ToLower().Replace("-", string.Empty);
|
var key = BitConverter.ToString(hash).ToLower().Replace("-", string.Empty);
|
||||||
|
|
||||||
return key;
|
return key;
|
||||||
|
|
Loading…
Reference in a new issue