aboutsummaryrefslogtreecommitdiff
path: root/Timeline/Startup.cs
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2020-08-21 23:47:10 +0800
committerGitHub <noreply@github.com>2020-08-21 23:47:10 +0800
commit733b8291855d1498e0ba9bc36a47a1b5f8b612ad (patch)
tree4885b9f7e828ec3f0ae7e2acacf348c9f5c158d9 /Timeline/Startup.cs
parentdc363ad8ae654af056c9ffa551008dbbf52b5d57 (diff)
parentf1c70edd559c72dcb47ff647f3f03ba5ae9a56cc (diff)
downloadtimeline-733b8291855d1498e0ba9bc36a47a1b5f8b612ad.tar.gz
timeline-733b8291855d1498e0ba9bc36a47a1b5f8b612ad.tar.bz2
timeline-733b8291855d1498e0ba9bc36a47a1b5f8b612ad.zip
Merge pull request #149 from crupest/swagger
Swagger/OpenAPI
Diffstat (limited to 'Timeline/Startup.cs')
-rw-r--r--Timeline/Startup.cs26
1 files changed, 26 insertions, 0 deletions
diff --git a/Timeline/Startup.cs b/Timeline/Startup.cs
index be2377b9..86bdaf54 100644
--- a/Timeline/Startup.cs
+++ b/Timeline/Startup.cs
@@ -7,6 +7,8 @@ using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.DependencyInjection.Extensions;
using Microsoft.Extensions.Hosting;
+using NSwag;
+using NSwag.Generation.Processors.Security;
using System;
using System.ComponentModel;
using System.Text.Json.Serialization;
@@ -18,6 +20,7 @@ using Timeline.Helpers;
using Timeline.Models.Converters;
using Timeline.Routes;
using Timeline.Services;
+using Timeline.Swagger;
namespace Timeline
{
@@ -46,6 +49,7 @@ namespace Timeline
services.AddControllers(setup =>
{
setup.InputFormatters.Add(new StringInputFormatter());
+ setup.InputFormatters.Add(new BytesInputFormatter());
setup.UseApiRoutePrefix("api");
})
.AddJsonOptions(options =>
@@ -95,6 +99,25 @@ namespace Timeline
options.UseSqlite($"Data Source={pathProvider.GetDatabaseFilePath()}");
});
+ services.AddSwaggerDocument(document =>
+ {
+ document.DocumentName = "Timeline";
+ document.Title = "Timeline REST API Reference";
+ document.Version = typeof(Startup).Assembly.GetName().Version?.ToString() ?? "unknown version";
+ document.DocumentProcessors.Add(
+ new SecurityDefinitionAppender("JWT",
+ new OpenApiSecurityScheme
+ {
+ Type = OpenApiSecuritySchemeType.ApiKey,
+ Name = "Authorization",
+ In = OpenApiSecurityApiKeyLocation.Header,
+ Description = "Type into the textbox: Bearer {your JWT token}."
+ }));
+ document.OperationProcessors.Add(new AspNetCoreOperationSecurityScopeProcessor("JWT"));
+ document.OperationProcessors.Add(new DefaultDescriptionOperationProcessor());
+ document.OperationProcessors.Add(new ByteDataRequestOperationProcessor());
+ });
+
if (!disableFrontEnd)
{
if (useMockFrontEnd)
@@ -129,6 +152,9 @@ namespace Timeline
});
}
+ app.UseOpenApi();
+ app.UseSwaggerUi3();
+
app.UseAuthentication();
app.UseAuthorization();