SEBWIN-645: Added basic user agent for network resource requests.

This commit is contained in:
Damian Büchel 2023-03-06 17:15:51 +01:00
parent e743d4a564
commit 296f87727d

View file

@ -11,6 +11,7 @@ using System.IO;
using System.Linq; using System.Linq;
using System.Net; using System.Net;
using System.Net.Http; using System.Net.Http;
using System.Net.Http.Headers;
using System.Net.Mime; using System.Net.Mime;
using System.Threading.Tasks; using System.Threading.Tasks;
using SafeExamBrowser.Configuration.Contracts; using SafeExamBrowser.Configuration.Contracts;
@ -21,8 +22,8 @@ namespace SafeExamBrowser.Configuration.DataResources
{ {
public class NetworkResourceLoader : IResourceLoader public class NetworkResourceLoader : IResourceLoader
{ {
private AppConfig appConfig; private readonly AppConfig appConfig;
private ILogger logger; private readonly ILogger logger;
/// <remarks> /// <remarks>
/// See https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/MIME_types. /// See https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/MIME_types.
@ -69,7 +70,7 @@ namespace SafeExamBrowser.Configuration.DataResources
logger.Debug($"Sending GET request for '{uri}'..."); logger.Debug($"Sending GET request for '{uri}'...");
var request = new HttpRequestMessage(HttpMethod.Get, uri); var request = Build(HttpMethod.Get, uri);
var response = Execute(request); var response = Execute(request);
logger.Debug($"Received response '{ToString(response)}'."); logger.Debug($"Received response '{ToString(response)}'.");
@ -86,6 +87,16 @@ namespace SafeExamBrowser.Configuration.DataResources
return LoadStatus.Success; return LoadStatus.Success;
} }
private HttpRequestMessage Build(HttpMethod method, Uri uri)
{
var request = new HttpRequestMessage(method, uri);
var userAgent = new ProductInfoHeaderValue("SEB", appConfig.ProgramInformationalVersion);
request.Headers.UserAgent.Add(userAgent);
return request;
}
private Uri BuildUriFor(Uri resource) private Uri BuildUriFor(Uri resource)
{ {
var scheme = GetSchemeFor(resource); var scheme = GetSchemeFor(resource);
@ -158,7 +169,7 @@ namespace SafeExamBrowser.Configuration.DataResources
{ {
logger.Debug($"Sending HEAD request for '{uri}'..."); logger.Debug($"Sending HEAD request for '{uri}'...");
var request = new HttpRequestMessage(HttpMethod.Head, uri); var request = Build(HttpMethod.Head, uri);
var response = Execute(request); var response = Execute(request);
isAvailable = response.IsSuccessStatusCode || IsUnauthorized(response); isAvailable = response.IsSuccessStatusCode || IsUnauthorized(response);
@ -175,7 +186,7 @@ namespace SafeExamBrowser.Configuration.DataResources
{ {
logger.Debug($"HEAD request was not successful, trying GET request for '{uri}'..."); logger.Debug($"HEAD request was not successful, trying GET request for '{uri}'...");
var request = new HttpRequestMessage(HttpMethod.Get, uri); var request = Build(HttpMethod.Get, uri);
var response = Execute(request); var response = Execute(request);
isAvailable = response.IsSuccessStatusCode || IsUnauthorized(response); isAvailable = response.IsSuccessStatusCode || IsUnauthorized(response);