2021-04-12 10:59:31 +02:00
|
|
|
|
/*
|
2024-03-05 18:37:42 +01:00
|
|
|
|
* Copyright (c) 2024 ETH Zürich, IT Services
|
2021-04-12 10:59:31 +02:00
|
|
|
|
*
|
|
|
|
|
* 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.Net.Http;
|
2024-09-04 15:14:55 +02:00
|
|
|
|
using System.Text;
|
2021-04-12 10:59:31 +02:00
|
|
|
|
using SafeExamBrowser.Settings.Logging;
|
|
|
|
|
|
|
|
|
|
namespace SafeExamBrowser.Server
|
|
|
|
|
{
|
|
|
|
|
internal static class Extensions
|
|
|
|
|
{
|
2024-02-21 18:37:23 +01:00
|
|
|
|
internal static string ToLogString(this HttpResponseMessage response)
|
|
|
|
|
{
|
2024-09-04 15:14:55 +02:00
|
|
|
|
return response == default ? "No Response" : $"{(int) response.StatusCode} {response.StatusCode} {response.ReasonPhrase}";
|
2024-02-21 18:37:23 +01:00
|
|
|
|
}
|
|
|
|
|
|
2021-04-12 10:59:31 +02:00
|
|
|
|
internal static string ToLogType(this LogLevel severity)
|
|
|
|
|
{
|
|
|
|
|
switch (severity)
|
|
|
|
|
{
|
|
|
|
|
case LogLevel.Debug:
|
|
|
|
|
return "DEBUG_LOG";
|
|
|
|
|
case LogLevel.Error:
|
|
|
|
|
return "ERROR_LOG";
|
|
|
|
|
case LogLevel.Info:
|
|
|
|
|
return "INFO_LOG";
|
|
|
|
|
case LogLevel.Warning:
|
|
|
|
|
return "WARN_LOG";
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return "UNKNOWN";
|
|
|
|
|
}
|
|
|
|
|
|
2024-09-04 15:14:55 +02:00
|
|
|
|
internal static string ToSummary(this Exception exception)
|
|
|
|
|
{
|
|
|
|
|
var trimChars = new[] { '.', '!' };
|
|
|
|
|
var summary = new StringBuilder(exception.Message?.TrimEnd(trimChars));
|
|
|
|
|
|
|
|
|
|
for (var inner = exception.InnerException; inner != default; inner = inner.InnerException)
|
|
|
|
|
{
|
|
|
|
|
summary.Append($" -> {inner.Message?.TrimEnd(trimChars)}");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return summary.ToString();
|
|
|
|
|
}
|
|
|
|
|
|
2021-04-12 10:59:31 +02:00
|
|
|
|
internal static long ToUnixTimestamp(this DateTime date)
|
|
|
|
|
{
|
|
|
|
|
return new DateTimeOffset(date).ToUnixTimeMilliseconds();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|