aboutsummaryrefslogtreecommitdiff
path: root/Timeline/Startup.cs
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2020-08-20 00:39:09 +0800
committercrupest <crupest@outlook.com>2020-08-20 00:39:09 +0800
commit3fb134b1d27a0c1069f14dc2608f25295e85eaa9 (patch)
tree3f880e221724cf4252aa429049a99caad157dd87 /Timeline/Startup.cs
parent7694e50a3cfc5068a8e7c476ba5ced78638ff8f6 (diff)
downloadtimeline-3fb134b1d27a0c1069f14dc2608f25295e85eaa9.tar.gz
timeline-3fb134b1d27a0c1069f14dc2608f25295e85eaa9.tar.bz2
timeline-3fb134b1d27a0c1069f14dc2608f25295e85eaa9.zip
...
Diffstat (limited to 'Timeline/Startup.cs')
-rw-r--r--Timeline/Startup.cs22
1 files changed, 22 insertions, 0 deletions
diff --git a/Timeline/Startup.cs b/Timeline/Startup.cs
index be2377b9..3e5dd24d 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;
@@ -95,6 +97,23 @@ 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"));
+ });
+
if (!disableFrontEnd)
{
if (useMockFrontEnd)
@@ -129,6 +148,9 @@ namespace Timeline
});
}
+ app.UseOpenApi();
+ app.UseSwaggerUi3();
+
app.UseAuthentication();
app.UseAuthorization();