SEBWIN-328: Implemented static user agent to fix issue with as of yet unsupported request interception for requests made by service workers.

This commit is contained in:
dbuechel 2019-05-16 14:41:38 +02:00
parent 2fd4bfa78a
commit e46316a69d
7 changed files with 30 additions and 7 deletions

View file

@ -129,7 +129,7 @@ namespace SafeExamBrowser.Browser
CachePath = appConfig.BrowserCachePath, CachePath = appConfig.BrowserCachePath,
LogFile = appConfig.BrowserLogFile, LogFile = appConfig.BrowserLogFile,
LogSeverity = error ? LogSeverity.Error : (warning ? LogSeverity.Warning : LogSeverity.Info), LogSeverity = error ? LogSeverity.Error : (warning ? LogSeverity.Warning : LogSeverity.Info),
UserAgent = settings.UseCustomUserAgent ? settings.CustomUserAgent : string.Empty UserAgent = InitializeUserAgent()
}; };
cefSettings.CefCommandLineArgs.Add("touch-events", "enabled"); cefSettings.CefCommandLineArgs.Add("touch-events", "enabled");
@ -165,5 +165,24 @@ namespace SafeExamBrowser.Browser
instances.Remove(instances.FirstOrDefault(i => i.Id == id)); instances.Remove(instances.FirstOrDefault(i => i.Id == id));
logger.Info($"Browser instance {id} was terminated."); logger.Info($"Browser instance {id} was terminated.");
} }
/// <summary>
/// TODO: Workaround to correctly set the user agent due to missing support for request interception for requests made by service workers.
/// Remove once CEF fully supports service workers and reactivate the functionality in <see cref="Handlers.RequestHandler"/>!
/// </summary>
private string InitializeUserAgent()
{
var osVersion = $"{Environment.OSVersion.Version.Major}.{Environment.OSVersion.Version.Minor}";
var sebVersion = $"SEB/{appConfig.ProgramVersion}";
if (settings.UseCustomUserAgent)
{
return $"{settings.CustomUserAgent} {sebVersion}";
}
else
{
return $"Mozilla/5.0 (Windows NT {osVersion}) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/{Cef.ChromiumVersion} {sebVersion}";
}
}
} }
} }

View file

@ -13,7 +13,7 @@ using BrowserSettings = SafeExamBrowser.Contracts.Configuration.Settings.Browser
namespace SafeExamBrowser.Browser.Handlers namespace SafeExamBrowser.Browser.Handlers
{ {
/// <remarks> /// <remarks>
/// See https://cefsharp.github.io/api/71.0.0/html/T_CefSharp_IContextMenuHandler.htm. /// See https://cefsharp.github.io/api/73.1.x/html/T_CefSharp_IContextMenuHandler.htm.
/// </remarks> /// </remarks>
internal class ContextMenuHandler : IContextMenuHandler internal class ContextMenuHandler : IContextMenuHandler
{ {

View file

@ -15,7 +15,7 @@ using SafeExamBrowser.Browser.Events;
namespace SafeExamBrowser.Browser.Handlers namespace SafeExamBrowser.Browser.Handlers
{ {
/// <remarks> /// <remarks>
/// See https://cefsharp.github.io/api/71.0.0/html/T_CefSharp_IDisplayHandler.htm. /// See https://cefsharp.github.io/api/73.1.x/html/T_CefSharp_IDisplayHandler.htm.
/// </remarks> /// </remarks>
internal class DisplayHandler : IDisplayHandler internal class DisplayHandler : IDisplayHandler
{ {

View file

@ -19,7 +19,7 @@ using BrowserSettings = SafeExamBrowser.Contracts.Configuration.Settings.Browser
namespace SafeExamBrowser.Browser.Handlers namespace SafeExamBrowser.Browser.Handlers
{ {
/// <remarks> /// <remarks>
/// See https://cefsharp.github.io/api/71.0.0/html/T_CefSharp_IDownloadHandler.htm. /// See https://cefsharp.github.io/api/73.1.x/html/T_CefSharp_IDownloadHandler.htm.
/// </remarks> /// </remarks>
internal class DownloadHandler : IDownloadHandler internal class DownloadHandler : IDownloadHandler
{ {

View file

@ -13,7 +13,7 @@ using SafeExamBrowser.Contracts.UserInterface;
namespace SafeExamBrowser.Browser.Handlers namespace SafeExamBrowser.Browser.Handlers
{ {
/// <remarks> /// <remarks>
/// See https://cefsharp.github.io/api/71.0.0/html/T_CefSharp_IKeyboardHandler.htm. /// See https://cefsharp.github.io/api/73.1.x/html/T_CefSharp_IKeyboardHandler.htm.
/// </remarks> /// </remarks>
internal class KeyboardHandler : IKeyboardHandler internal class KeyboardHandler : IKeyboardHandler
{ {

View file

@ -12,7 +12,7 @@ using SafeExamBrowser.Browser.Events;
namespace SafeExamBrowser.Browser.Handlers namespace SafeExamBrowser.Browser.Handlers
{ {
/// <remarks> /// <remarks>
/// See https://cefsharp.github.io/api/71.0.0/html/T_CefSharp_ILifeSpanHandler.htm. /// See https://cefsharp.github.io/api/73.1.x/html/T_CefSharp_ILifeSpanHandler.htm.
/// </remarks> /// </remarks>
internal class LifeSpanHandler : ILifeSpanHandler internal class LifeSpanHandler : ILifeSpanHandler
{ {

View file

@ -28,7 +28,11 @@ namespace SafeExamBrowser.Browser.Handlers
public override CefReturnValue OnBeforeResourceLoad(IWebBrowser browserControl, IBrowser browser, IFrame frame, IRequest request, IRequestCallback callback) public override CefReturnValue OnBeforeResourceLoad(IWebBrowser browserControl, IBrowser browser, IFrame frame, IRequest request, IRequestCallback callback)
{ {
AppendCustomUserAgent(request); // TODO: CEF does not yet support intercepting requests from service workers, thus the user agent must be statically set at browser
// startup for now. Once CEF has full support of service workers, the static user agent should be removed and the method below
// reactivated. See https://bitbucket.org/chromiumembedded/cef/issues/2622 for the current status of development.
// AppendCustomUserAgent(request);
ReplaceCustomScheme(request); ReplaceCustomScheme(request);
return base.OnBeforeResourceLoad(browserControl, browser, frame, request, callback); return base.OnBeforeResourceLoad(browserControl, browser, frame, request, callback);