(cherry picked from commit 303fc5d786ccf2ad14c8523fc239696c5d37ea53)pull/3397/head
parent
b1bad2067c
commit
fc79738fcb
@ -0,0 +1,40 @@
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
using Lidarr.Http.Extensions;
|
||||
using Microsoft.AspNetCore.Http;
|
||||
using NzbDrone.Common.EnvironmentInfo;
|
||||
using NzbDrone.Common.Serializer;
|
||||
|
||||
namespace Lidarr.Http.Middleware
|
||||
{
|
||||
public class StartingUpMiddleware
|
||||
{
|
||||
private readonly RequestDelegate _next;
|
||||
private readonly IRuntimeInfo _runtimeInfo;
|
||||
private static readonly string MESSAGE = "Lidarr is starting up, please try again later";
|
||||
|
||||
public StartingUpMiddleware(RequestDelegate next, IRuntimeInfo runtimeInfo)
|
||||
{
|
||||
_next = next;
|
||||
_runtimeInfo = runtimeInfo;
|
||||
}
|
||||
|
||||
public async Task InvokeAsync(HttpContext context)
|
||||
{
|
||||
if (_runtimeInfo.IsStarting)
|
||||
{
|
||||
var isJson = context.Request.IsApiRequest();
|
||||
var message = isJson ? STJson.ToJson(new { ErrorMessage = MESSAGE }) : MESSAGE;
|
||||
var bytes = Encoding.UTF8.GetBytes(message);
|
||||
|
||||
context.Response.StatusCode = 503;
|
||||
context.Response.ContentType = isJson ? "application/json" : "text/plain";
|
||||
await context.Response.Body.WriteAsync(bytes, 0, bytes.Length);
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
await _next(context);
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Reference in new issue