Makspll.Pathfinder
0.1.0
See the version list below for details.
dotnet add package Makspll.Pathfinder --version 0.1.0
NuGet\Install-Package Makspll.Pathfinder -Version 0.1.0
<PackageReference Include="Makspll.Pathfinder" Version="0.1.0" />
paket add Makspll.Pathfinder --version 0.1.0
#r "nuget: Makspll.Pathfinder, 0.1.0"
// Install Makspll.Pathfinder as a Cake Addin #addin nuget:?package=Makspll.Pathfinder&version=0.1.0 // Install Makspll.Pathfinder as a Cake Tool #tool nuget:?package=Makspll.Pathfinder&version=0.1.0
Pathfinder
<p align="center"> <img src="Pathfinder.jpg" alt="Pathfinder" width="300"/> </p>
Finds and outputs all API routes found in a .NET assembly in textual or JSON format.
Features
- Attribute based routing
- Conventional routing (templates + defaults have to be specified in a config file)
- .NET core support
- .NET framework support
- JSON and Text output
- Configurable backing lib for projects with custom routing mechanisms
Usage
dotnet build test_assemblies/dotnet8
dotnet run --project src/app **/bin/**/dotnet8.dll -o Text
Configuration
Config file
The program is configured via pathfinder.json
files found in your project. If the file is not found you can specify a path via the -c
flag.
Currently the file needs to specify all your conventional routing configuration (anything that isn't attribute based).
.NET framework
In .NET framework projects, you will need to specify whether each of your routes is an MVC or API route. This is done by adding a Type
field to each route in the config file.
{
"ConventionalRoutes": [
{
"Template": "conventionalprefix/{controller}/{action}",
"Type": "MVC"
},
{
"Template": "conventionalprefix2/{controller}",
"Defaults": {
"action": "DefaultAction"
},
"Type": "MVC"
},
{
"Template": "conventionalwithnoactionspecs",
"Defaults": {
"controller": "DefaultConventional",
"action": "DefaultAction"
},
"Type": "MVC"
},
{
"Template": "apiconventionalprefix/{controller}/{action}",
"Type": "API"
},
{
"Template": "apiconventionalprefix2/{controller}",
"Defaults": {
"action": "DefaultAction"
},
"Type": "API"
},
{
"Template": "apiconventionalwithnoactionspecs",
"Defaults": {
"controller": "ApiDefaultConventionalApi",
"action": "DefaultAction"
},
"Type": "API"
}
]
}
.NET core
.NET core does not make such a distinction, you shouldn't specify the type of controller:
{
"ConventionalRoutes": [
{
"Template": "conventionalprefix/{controller}/{action}"
},
{
"Template": "conventionalprefix2/{controller}",
"Defaults": {
"action": "DefaultAction"
}
},
{
"Template": "conventionalwithnoactionspecs",
"Defaults": {
"controller": "DefaultConventional",
"action": "DefaultAction"
}
}
]
}
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
-
net8.0
- Makspll.PathfinderLib (>= 0.1.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.