SEBWIN-376: Fixed error with browser request filtering and improved logging if request is blocked. Also fixed error in configuration value mapping for content request filter.
This commit is contained in:
parent
50e671c40c
commit
24c5d91fe4
3 changed files with 27 additions and 17 deletions
|
@ -72,8 +72,11 @@ namespace SafeExamBrowser.Browser.Handlers
|
|||
}
|
||||
|
||||
if (Block(request))
|
||||
{
|
||||
if (request.ResourceType == ResourceType.MainFrame)
|
||||
{
|
||||
RequestBlocked?.Invoke(request.Url);
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
@ -105,20 +108,31 @@ namespace SafeExamBrowser.Browser.Handlers
|
|||
|
||||
private bool Block(IRequest request)
|
||||
{
|
||||
if (settings.Filter.ProcessMainRequests)
|
||||
var block = false;
|
||||
|
||||
if (settings.Filter.ProcessMainRequests && request.ResourceType == ResourceType.MainFrame)
|
||||
{
|
||||
var result = filter.Process(new Request { Url = request.Url });
|
||||
var block = result == FilterResult.Block;
|
||||
|
||||
if (block)
|
||||
if (result == FilterResult.Block)
|
||||
{
|
||||
logger.Info($"Blocked main request for '{request.Url}'.");
|
||||
block = true;
|
||||
logger.Info($"Blocked main request for '{request.Url}' ({request.ResourceType}, {request.TransitionType}).");
|
||||
}
|
||||
}
|
||||
|
||||
if (settings.Filter.ProcessContentRequests && request.ResourceType != ResourceType.MainFrame)
|
||||
{
|
||||
var result = filter.Process(new Request { Url = request.Url });
|
||||
|
||||
if (result == FilterResult.Block)
|
||||
{
|
||||
block = true;
|
||||
logger.Info($"Blocked content request for '{request.Url}' ({request.ResourceType}, {request.TransitionType}).");
|
||||
}
|
||||
}
|
||||
|
||||
return block;
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -72,18 +72,14 @@ namespace SafeExamBrowser.Browser.Handlers
|
|||
|
||||
protected override bool OnResourceResponse(IWebBrowser chromiumWebBrowser, IBrowser browser, IFrame frame, IRequest request, IResponse response)
|
||||
{
|
||||
var abort = true;
|
||||
|
||||
if (RedirectToDisablePdfToolbar(request, response, out var url))
|
||||
{
|
||||
chromiumWebBrowser.Load(url);
|
||||
}
|
||||
else
|
||||
{
|
||||
abort = base.OnResourceResponse(chromiumWebBrowser, browser, frame, request, response);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
return abort;
|
||||
return base.OnResourceResponse(chromiumWebBrowser, browser, frame, request, response);
|
||||
}
|
||||
|
||||
private void AppendCustomHeaders(IRequest request)
|
||||
|
@ -121,7 +117,7 @@ namespace SafeExamBrowser.Browser.Handlers
|
|||
if (result == FilterResult.Block)
|
||||
{
|
||||
block = true;
|
||||
logger.Info($"Blocked content request for '{request.Url}'.");
|
||||
logger.Info($"Blocked content request for '{request.Url}' ({request.ResourceType}, {request.TransitionType}).");
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -350,7 +350,7 @@ namespace SafeExamBrowser.Configuration.ConfigurationData.DataMapping
|
|||
private void MapRequestFilter(IDictionary<string, object> rawData, AppSettings settings)
|
||||
{
|
||||
var processMainRequests = rawData.TryGetValue(Keys.Browser.Filter.EnableMainRequestFilter, out var value) && value as bool? == true;
|
||||
var processContentRequests = rawData.TryGetValue(Keys.Browser.UserAgentModeMobile, out value) && value as bool? == true;
|
||||
var processContentRequests = rawData.TryGetValue(Keys.Browser.Filter.EnableContentRequestFilter, out value) && value as bool? == true;
|
||||
|
||||
settings.Browser.Filter.ProcessMainRequests = processMainRequests;
|
||||
settings.Browser.Filter.ProcessContentRequests = processMainRequests && processContentRequests;
|
||||
|
|
Loading…
Reference in a new issue