diff options
author | crupest <crupest@outlook.com> | 2020-10-27 19:21:35 +0800 |
---|---|---|
committer | crupest <crupest@outlook.com> | 2020-10-27 19:21:35 +0800 |
commit | ac769e656b122ff569c3f1534701b71e00fed586 (patch) | |
tree | 72966645ff1e25139d3995262e1c4349f2c14733 /Timeline/Routes | |
parent | 14e5848c23c643cea9b5d709770747d98c3d75e2 (diff) | |
download | timeline-ac769e656b122ff569c3f1534701b71e00fed586.tar.gz timeline-ac769e656b122ff569c3f1534701b71e00fed586.tar.bz2 timeline-ac769e656b122ff569c3f1534701b71e00fed586.zip |
Split front and back end.
Diffstat (limited to 'Timeline/Routes')
-rw-r--r-- | Timeline/Routes/ApiRoutePrefixConvention.cs | 46 | ||||
-rw-r--r-- | Timeline/Routes/UnknownEndpointMiddleware.cs | 39 |
2 files changed, 0 insertions, 85 deletions
diff --git a/Timeline/Routes/ApiRoutePrefixConvention.cs b/Timeline/Routes/ApiRoutePrefixConvention.cs deleted file mode 100644 index ca38a0d9..00000000 --- a/Timeline/Routes/ApiRoutePrefixConvention.cs +++ /dev/null @@ -1,46 +0,0 @@ -using Microsoft.AspNetCore.Mvc;
-using Microsoft.AspNetCore.Mvc.ApplicationModels;
-using Microsoft.AspNetCore.Mvc.Infrastructure;
-using Microsoft.AspNetCore.Mvc.Routing;
-using System.Linq;
-
-namespace Timeline.Routes
-{
- public static class MvcOptionsExtensions
- {
- public static void UseApiRoutePrefix(this MvcOptions opts, IRouteTemplateProvider routeAttribute)
- {
- opts.Conventions.Add(new ApiRoutePrefixConvention(routeAttribute));
- }
-
- public static void UseApiRoutePrefix(this MvcOptions opts, string prefix)
- {
- opts.UseApiRoutePrefix(new RouteAttribute(prefix));
- }
- }
-
- public class ApiRoutePrefixConvention : IApplicationModelConvention
- {
- private readonly AttributeRouteModel _routePrefix;
-
- public ApiRoutePrefixConvention(IRouteTemplateProvider route)
- {
- _routePrefix = new AttributeRouteModel(route);
- }
-
- public void Apply(ApplicationModel application)
- {
- foreach (var selector in application.Controllers.Where(c => c.Filters.Any(f => f is IApiBehaviorMetadata)).SelectMany(c => c.Selectors))
- {
- if (selector.AttributeRouteModel != null)
- {
- selector.AttributeRouteModel = AttributeRouteModel.CombineAttributeRouteModel(_routePrefix, selector.AttributeRouteModel);
- }
- else
- {
- selector.AttributeRouteModel = _routePrefix;
- }
- }
- }
- }
-}
diff --git a/Timeline/Routes/UnknownEndpointMiddleware.cs b/Timeline/Routes/UnknownEndpointMiddleware.cs deleted file mode 100644 index 25ec563c..00000000 --- a/Timeline/Routes/UnknownEndpointMiddleware.cs +++ /dev/null @@ -1,39 +0,0 @@ -using Microsoft.AspNetCore.Builder;
-using Microsoft.AspNetCore.Http;
-using System;
-using System.Net.Mime;
-using System.Text.Json;
-using Timeline.Models.Http;
-
-namespace Timeline.Routes
-{
- public static class UnknownEndpointMiddleware
- {
- public static void Attach(IApplicationBuilder app)
- {
- app.Use(async (context, next) =>
- {
- if (context.GetEndpoint() != null)
- {
- await next();
- return;
- }
-
- if (context.Request.Path.StartsWithSegments("/api", StringComparison.OrdinalIgnoreCase))
- {
- context.Response.StatusCode = StatusCodes.Status400BadRequest;
- context.Response.ContentType = MediaTypeNames.Application.Json;
-
- var body = JsonSerializer.SerializeToUtf8Bytes(ErrorResponse.Common.UnknownEndpoint(), new JsonSerializerOptions { PropertyNamingPolicy = JsonNamingPolicy.CamelCase });
-
- context.Response.ContentLength = body.Length;
- await context.Response.Body.WriteAsync(body);
- await context.Response.CompleteAsync();
- return;
- }
-
- await next();
- });
- }
- }
-}
|