Aiursoft.DocGenerator
9.0.1
dotnet add package Aiursoft.DocGenerator --version 9.0.1
NuGet\Install-Package Aiursoft.DocGenerator -Version 9.0.1
<PackageReference Include="Aiursoft.DocGenerator" Version="9.0.1" />
paket add Aiursoft.DocGenerator --version 9.0.1
#r "nuget: Aiursoft.DocGenerator, 9.0.1"
// Install Aiursoft.DocGenerator as a Cake Addin #addin nuget:?package=Aiursoft.DocGenerator&version=9.0.1 // Install Aiursoft.DocGenerator as a Cake Tool #tool nuget:?package=Aiursoft.DocGenerator&version=9.0.1
ASP.NET Core API Document Generator
A basic API document generator for ASP.NET Core applications. Open source, offline and free.
<div align=center> <img src="./demo.png"> </div>
Features
- Generate Markdown
- Generate Json
Supports
- ASP.NET Core 6.0
How to use
First, install Aiursoft.DocGenerator
to your ASP.NET Core project from nuget.org:
dotnet add package Aiursoft.DocGenerator
Simply add this line in your Startup.cs
:
using Aiursoft.DocGenerator.Services;
public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
{
// ...
// your middlewares
// ...
app.UseAiursoftDocGenerator(); // <- Add this.
}
Start your application and browse:
/doc
It just returns your document in JSON format.
[{
"ControllerName": "HomeController",
"ActionName": "Index",
"AuthRequired": false,
"IsPost": false,
"Arguments": [],
"PossibleResponses": ["{\"code\":0,\"message\":\"success.\"}"]
}]
That's all! Happy coding!
Continue? Try runing the example project! Or continue reading.
Customization and API
Change document output address
app.UseAiursoftDocGenerator(options =>
{
// Default value is '/doc'. You can change it to other path.
options.DocAddress = "/my-doc";
});
Change document output format
app.UseAiursoftDocGenerator(options =>
{
// Default format is JSON. You can change it to markdown.
options.Format = DocFormat.Markdown;
});
Set global possible responses
app.UseAiursoftDocGenerator(options =>
{
// Default global possible response is an empty list.
options.GlobalPossibleResponse.Add(new { code = 0, message = "success." });
});
Set possible response for one API
When you can ensure the possible response for one API, add this line to your action:
[Produces(typeof(ResponseModel))] // <- add this in your controller.
public IActionResult HasOutput()
{
var model = new ResponseModel(); // <- your own class and logic
return Json(model);
}
Document generation filter
By default, only controllers and actions with [GenerateDoc]
attributes will be generated.
To mark a controller or action which generates document, add attribute [GenerateDoc]
like this:
using Aiursoft.DocGenerator.Attribute;
[GenerateDoc] // Add this, the entire controller will generate document.
public class HomeController : Controller
{
[GenerateDoc] // Add this, the action will generate document.
public IActionResult MyAPI()
{
return Json(null);
}
}
You can change that logic to your own filter:
app.UseAiursoftDocGenerator(options =>
{
options.IsAPIAction = (action, controller) =>
{
// Your own logic. Return bool.
return action.CustomAttributes.Any(t => t.AttributeType == typeof(GenerateDoc));
};
}
Authorized action detector
If your API is authorized required, we can detect that in the document. And you can customzie the logic:
using Microsoft.AspNetCore.Authorization;
app.UseAiursoftDocGenerator(options =>
{
options.JudgeAuthorized = (action, controller) =>
{
// Your own logic here. Return bool.
return
action.CustomAttributes.Any(t => t.AttributeType == typeof(AuthorizeAttribute)) ||
controller.CustomAttributes.Any(t => t.AttributeType == typeof(AuthorizeAttribute));
};
}
How to contribute
There are many ways to contribute to the project: logging bugs, submitting pull requests, reporting issues, and creating suggestions.
Even if you with push rights on the repository, you should create a personal fork and create feature branches there when you need them. This keeps the main repository clean and your workflow cruft out of sight.
We're also interested in your feedback on the future of this project. You can submit a suggestion or feature request through the issue tracker. To make this process more effective, we're asking that these include more information to help define them more clearly.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net9.0 is compatible. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
-
net9.0
- Aiursoft.DocGenerator.Abstractions (>= 9.0.0)
- Aiursoft.Scanner.Abstractions (>= 9.0.0)
- Markdig (>= 0.40.0)
- Newtonsoft.Json (>= 13.0.3)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
9.0.1 | 71 | 1/11/2025 |
9.0.0 | 78 | 1/2/2025 |
8.0.5 | 92 | 1/1/2025 |
8.0.4 | 103 | 12/19/2024 |
8.0.3 | 81 | 12/18/2024 |
8.0.2 | 164 | 10/26/2024 |
8.0.1 | 548 | 2/19/2024 |
8.0.0 | 139 | 2/19/2024 |
7.0.3 | 147 | 2/2/2024 |
7.0.2 | 126 | 1/30/2024 |
7.0.1 | 1,157 | 11/23/2023 |
7.0.0 | 1,155 | 9/5/2023 |
6.0.26 | 145 | 9/5/2023 |
6.0.25 | 583 | 6/26/2023 |
6.0.24 | 186 | 6/26/2023 |
6.0.22 | 329 | 6/18/2023 |
6.0.21 | 263 | 6/14/2023 |
6.0.20 | 266 | 6/5/2023 |
6.0.19 | 282 | 5/27/2023 |
6.0.18 | 274 | 5/27/2023 |
6.0.17 | 300 | 5/27/2023 |
6.0.16 | 294 | 5/27/2023 |
6.0.15 | 279 | 5/27/2023 |
6.0.14 | 282 | 5/27/2023 |
6.0.13 | 267 | 5/19/2023 |
6.0.12 | 275 | 5/19/2023 |
6.0.11 | 263 | 5/19/2023 |
6.0.10 | 256 | 5/19/2023 |
6.0.9 | 267 | 5/19/2023 |
6.0.8 | 291 | 5/11/2023 |
6.0.7 | 2,352 | 8/4/2022 |
6.0.6 | 886 | 7/6/2022 |
6.0.5 | 1,138 | 5/13/2022 |
6.0.0 | 982 | 3/27/2022 |
5.0.9 | 976 | 5/31/2021 |
5.0.8 | 863 | 5/23/2021 |
5.0.7 | 857 | 5/7/2021 |
5.0.6 | 871 | 4/14/2021 |
5.0.5 | 938 | 2/16/2021 |
5.0.4 | 871 | 1/29/2021 |
5.0.3 | 876 | 1/27/2021 |
5.0.2 | 964 | 12/9/2020 |
5.0.1 | 872 | 11/30/2020 |
5.0.0 | 787 | 11/14/2020 |
3.2.11 | 1,052 | 10/18/2020 |
3.2.10 | 984 | 10/3/2020 |
3.2.9 | 912 | 10/2/2020 |
3.2.8 | 981 | 9/10/2020 |
3.2.7 | 961 | 9/2/2020 |
3.2.6 | 1,033 | 8/12/2020 |
3.2.5 | 1,029 | 7/31/2020 |
3.2.4 | 995 | 7/3/2020 |
3.2.3 | 952 | 6/25/2020 |
3.2.2 | 972 | 6/18/2020 |
3.2.1 | 999 | 6/5/2020 |
3.2.0 | 1,024 | 6/4/2020 |
3.1.14 | 1,213 | 6/4/2020 |
3.1.13 | 1,135 | 5/25/2020 |
3.1.12 | 1,115 | 5/20/2020 |
3.1.11 | 1,082 | 5/18/2020 |
3.1.10 | 1,072 | 5/18/2020 |
3.1.9 | 1,086 | 5/17/2020 |
3.1.8 | 1,092 | 5/12/2020 |
3.1.7 | 1,157 | 5/2/2020 |
3.1.6 | 1,127 | 5/1/2020 |
3.1.5 | 1,106 | 4/21/2020 |
3.1.4 | 848 | 4/19/2020 |
3.1.3 | 1,634 | 4/15/2020 |
3.1.2.2 | 1,813 | 4/6/2020 |
3.1.2.1 | 1,698 | 3/19/2020 |
3.1.2 | 1,764 | 2/21/2020 |
3.1.1.8 | 1,381 | 2/17/2020 |
3.1.1.7 | 1,352 | 2/14/2020 |
3.1.1.6 | 1,155 | 1/28/2020 |
3.1.1.5 | 1,450 | 1/22/2020 |
3.1.1.4 | 1,143 | 1/21/2020 |
3.1.1.2 | 1,151 | 1/20/2020 |
3.1.1 | 923 | 1/17/2020 |