NetCoreUsefullEndpoints 7.2023.1216.1825

dotnet add package NetCoreUsefullEndpoints --version 7.2023.1216.1825
NuGet\Install-Package NetCoreUsefullEndpoints -Version 7.2023.1216.1825
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="NetCoreUsefullEndpoints" Version="7.2023.1216.1825" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add NetCoreUsefullEndpoints --version 7.2023.1216.1825
#r "nuget: NetCoreUsefullEndpoints, 7.2023.1216.1825"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install NetCoreUsefullEndpoints as a Cake Addin
#addin nuget:?package=NetCoreUsefullEndpoints&version=7.2023.1216.1825

// Install NetCoreUsefullEndpoints as a Cake Tool
#tool nuget:?package=NetCoreUsefullEndpoints&version=7.2023.1216.1825

NetCoreUsefullEndpoints

CI build status NuGet Package Project license

What it does

Register endpoints for

  1. See environment variables
  2. See current user ( implies authorization )
  3. See environment
  4. Throw error ( with ILogger or without )
  5. Current Date
  6. Digraph of current endpoints
  7. JSON of current endpoints
  8. Configuration View ( GetDebugView )
  9. Connection details ( remote ip address, local ip address...)
  10. Shutdown( and forced) the app ( use await app.RunAsync(UsefullExtensions.UsefullExtensions.cts.Token);
  11. See the start date of the application
  12. See the list of Hosted services / start all / stop all
  13. When the PC has started ( uptime )

Usage

Add this reference to your csproj in .NET 6

<ItemGroup>
    <PackageReference Include="NetCoreUsefullEndpoints" Version="6.2022.1231.1100" />
  </ItemGroup>

or in .NET 7

<ItemGroup>
    <PackageReference Include="NetCoreUsefullEndpoints" Version="7.2023.1216.1825" />
  </ItemGroup>

then use it in program.cs

using UsefullExtensions;
//code
var app = builder.Build();
app.MapUsefullAll();
app.MapHostedServices(app.Services.GetServices<IHostedService>().ToArray());
//or for just some usefull
app.MapUsefullConfiguration();

For shutdown 418 please add

builder.Services.AddSingleton<MiddlewareShutdown>();
var app = builder.Build();
//ASAP
app.UseMiddleware<MiddlewareShutdown>();

The list of API endpoints is GET=>/api/usefull/date/start GET=>/api/usefull/date/startUTC GET=>/api/usefull/user/authorization GET=>/api/usefull/user/noAuthorization GET=>/api/usefull/environment GET=>/api/usefull/errorWithILogger GET=>/api/usefull/errorPure GET=>/api/usefull/date/now GET=>/api/usefull/date/nowUTC GET=>/api/usefull/endpoints/graph GET=>/api/usefull/endpoints/text GET=>/api/usefull/configuration GET=>/api/usefull/httpContext/Connection POST=>/api/usefull/shutdown POST=>/api/usefull/shutdownForced/{id} GET=>/WeatherForecast

Security

Each function has a default implementation with AllowAnonymous ( a part user ) and without put RequireCors ; If you want a special case here, call the functions with

app.MapUsefullAll("myCors", new string[] {"myAuthPolicy"});
//or
app.MapUsefullConfiguration();

For restarting , the last line should be

await app.RunAsync(UsefullExtensions.UsefullExtensions.cts.Token);

Enjoy!

Product Compatible and additional computed target framework versions.
.NET net7.0 is compatible.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

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
7.2023.1216.1825 684 12/19/2023
7.2023.916.1715 305 9/16/2023
7.2023.402.1715 303 4/2/2023
7.2023.223.1815 1,502 2/23/2023
7.2023.219.2234 275 2/16/2023
7.2023.219.2134 258 2/15/2023
7.2023.219.2034 249 2/14/2023
7.2023.219.1934 337 2/10/2023
7.2023.219.841 286 2/10/2023
7.2023.207.2230 320 2/7/2023
7.2023.126.700 328 1/26/2023
7.2022.1231.1100 316 12/31/2022
7.2022.1203.1551 372 12/3/2022
6.2022.1231.1100 317 12/31/2022
6.2022.1203.1551 309 12/3/2022
6.2022.1026.2112 398 10/26/2022
6.2022.1012.712 591 10/12/2022
6.2022.722.712 483 7/22/2022
6.2022.721.1154 408 7/22/2022