Scalar.AspNetCore 2.3.1

dotnet add package Scalar.AspNetCore --version 2.3.1
                    
NuGet\Install-Package Scalar.AspNetCore -Version 2.3.1
                    
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="Scalar.AspNetCore" Version="2.3.1" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Scalar.AspNetCore" Version="2.3.1" />
                    
Directory.Packages.props
<PackageReference Include="Scalar.AspNetCore" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add Scalar.AspNetCore --version 2.3.1
                    
#r "nuget: Scalar.AspNetCore, 2.3.1"
                    
#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.
#addin nuget:?package=Scalar.AspNetCore&version=2.3.1
                    
Install Scalar.AspNetCore as a Cake Addin
#tool nuget:?package=Scalar.AspNetCore&version=2.3.1
                    
Install Scalar.AspNetCore as a Cake Tool

Scalar .NET API Reference Integration

Version Downloads Discord

This .NET package Scalar.AspNetCore provides an easy way to render beautiful API references based on OpenAPI/Swagger documents.

Made possible by the wonderful work of @captainsafia on building the integration and docs written for the Scalar & .NET integration. Thanks to @xC0dex for making it awesome.

Features

  • Stunning API Reference
  • Compatible with .NET 8 and above
  • Independent of OpenAPI document generators
  • Fully AOT (Ahead-of-Time) compatible

dotnet

Migration Guide

If you are upgrading from 2.1.x to 2.2.x, please refer to the migration guide. If you are upgrading from 1.x.x to 2.x.x, please refer to the migration guide.

Usage

  1. Install the package
dotnet add package Scalar.AspNetCore
  1. Add the using directive
using Scalar.AspNetCore;
  1. Configure your application

Add the following to Program.cs based on your OpenAPI generator:

For Microsoft.AspNetCore.OpenApi:

builder.Services.AddOpenApi();

if (app.Environment.IsDevelopment())
{
    app.MapOpenApi();
    app.MapScalarApiReference();
}

For Swashbuckle:

builder.Services.AddEndpointsApiExplorer();
builder.Services.AddSwaggerGen();

if (app.Environment.IsDevelopment())
{
    app.UseSwagger(options =>
    {
        options.RouteTemplate = "/openapi/{documentName}.json";
    });
    app.MapScalarApiReference();
}

For NSwag:

builder.Services.AddEndpointsApiExplorer();
builder.Services.AddOpenApiDocument();

if (app.Environment.IsDevelopment())
{
    app.UseOpenApi(options =>
    {
        options.Path = "/openapi/{documentName}.json";
    });
    app.MapScalarApiReference();
}

For FastEndpoints:

builder.Services.SwaggerDocument();

if (app.Environment.IsDevelopment())
{
    app.UseSwaggerGen(options =>
    {
        options.Path = "/openapi/{documentName}.json";
    });
    app.MapScalarApiReference();
}

You’re all set! 🎉 Visit /scalar to see the API Reference for the default OpenAPI document (v1).

If you have multiple OpenAPI documents, you can set them up with AddDocument or AddDocuments (see Multiple OpenAPI Documents).
To view a specific document, go to /scalar/{documentName} (like /scalar/v1 or /scalar/v2-beta).

Configuration

For detailed configuration options, refer to the integration documentation. This documentation focuses on the features provided by the package.

For more realistic examples and advanced usage scenarios, such as authentication, API versioning, and handling multiple documents, check out our extended examples documentation. This documentation is also useful if you need more context on what Scalar.AspNetCore is for.

OpenAPI extensions

Scalar provides additional packages to enhance OpenAPI document generation:

  • Scalar.AspNetCore.Microsoft: Implements transformers for Microsoft.AspNetCore.OpenApi
  • Scalar.AspNetCore.Swashbuckle: Implements filters for Swashbuckle

These packages enable advanced features like stability indicators and API Reference exclusions. See the dotnet integration documentation for details.

Development

Local

  1. Download .NET 9.0
  2. Jump to the package folder: cd integrations/aspnetcore
  3. Do a fresh build: dotnet build
  4. Run the tests: dotnet test

And see it in action here:

  1. Switch to the playground: cd playground/Scalar.AspNetCore.Playground
  2. Start the playground: dotnet run
  3. Open this URL in the browser: http://localhost:5056/scalar/

Docker

If you don't have the SDK installed or want to run the playground under a subpath, you can use Docker Compose:

  1. Run Docker Compose: docker compose up --build
  2. Open this URL in the browser: http://localhost:8080/api/scalar/

Community

We are API nerds. You too? Let’s chat on Discord: https://discord.gg/scalar

License

The source code in this repository is licensed under MIT.

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

    • No dependencies.
  • net9.0

    • No dependencies.

NuGet packages (44)

Showing the top 5 NuGet packages that depend on Scalar.AspNetCore:

Package Downloads
Rystem.Api.Server

Rystem.Api helps you to integrate Api Server and Automated Client for Aspect-Oriented programming.

devprime.stack.web

DevPrime Web

Mii.Rinjani.Gateway.Commons

Package Description

ShayganTadbir.Framework.Core

Package description

NForza.Cyrus.Core

Opiniated source generation framework for CQRS webapps

GitHub repositories (3)

Showing the top 3 popular GitHub repositories that depend on Scalar.AspNetCore:

Repository Stars
dotnet/AspNetCore.Docs
Documentation for ASP.NET Core
dotnet/eShop
A reference .NET application implementing an eCommerce site
davidfowl/TodoApp
Todo application with ASP.NET Core Blazor WASM, Minimal APIs and Authentication
Version Downloads Last updated
2.3.1 0 5/15/2025
2.3.0 0 5/12/2025
2.2.7 26,357 5/5/2025
2.2.5 17,793 5/1/2025
2.2.4 1,839 5/1/2025
2.2.3 2,955 4/30/2025
2.2.2 6,501 4/29/2025
2.2.1 38,431 4/24/2025
2.2.0 2,906 4/23/2025
2.1.18 13,086 4/22/2025
2.1.17 26,388 4/18/2025
2.1.16 11,304 4/16/2025
2.1.15 2,510 4/16/2025
2.1.14 1,282 4/16/2025
2.1.13 215,286 4/11/2025
2.1.12 2,015 4/11/2025
2.1.11 13,268 4/10/2025
2.1.10 4,868 4/10/2025
2.1.9 13,119 4/9/2025
2.1.8 12,598 4/8/2025
2.1.7 13,311 4/7/2025
2.1.6 20,262 4/4/2025
2.1.5 17,915 4/2/2025
2.1.4 31,490 3/31/2025
2.1.3 23,952 3/28/2025
2.1.2 20,855 3/26/2025
2.1.1 144,746 3/20/2025
2.1.0 28,262 3/19/2025
2.0.36 60,115 3/15/2025
2.0.34 6,581 3/14/2025
2.0.33 3,208 3/14/2025
2.0.30 29,934 3/12/2025
2.0.29 26,228 3/10/2025
2.0.28 2,330 3/10/2025
2.0.27 11,384 3/10/2025
2.0.26 27,685 3/7/2025
2.0.25 8,847 3/6/2025
2.0.24 12,542 3/6/2025
2.0.23 93,892 3/4/2025
2.0.22 14,003 3/3/2025
2.0.21 18,263 3/2/2025
2.0.20 16,333 2/28/2025
2.0.19 3,021 2/28/2025
2.0.18 168,412 2/21/2025
2.0.17 3,655 2/20/2025
2.0.16 9,523 2/20/2025
2.0.15 26,851 2/18/2025
2.0.14 45,489 2/13/2025
2.0.12 82,881 2/6/2025
2.0.11 33,537 2/4/2025
2.0.10 4,824 2/4/2025
2.0.9 53,744 1/30/2025
2.0.8 2,165 1/30/2025
2.0.7 20,880 1/28/2025
2.0.6 2,181 1/28/2025
2.0.5 13,539 1/27/2025
2.0.4 41,919 1/22/2025
2.0.2 30,678 1/20/2025
2.0.1 32,404 1/17/2025
2.0.0 5,137 1/16/2025
1.2.76 76,219 1/13/2025
1.2.75 13,464 1/11/2025
1.2.74 38,749 1/8/2025
1.2.73 7,057 1/7/2025
1.2.72 65,257 12/24/2024
1.2.71 5,553 12/23/2024
1.2.70 7,083 12/22/2024
1.2.69 1,680 12/22/2024
1.2.68 3,238 12/21/2024
1.2.67 943 12/20/2024
1.2.66 7,194 12/20/2024
1.2.65 866 12/19/2024
1.2.64 15,316 12/18/2024
1.2.63 7,109 12/18/2024
1.2.61 3,936 12/17/2024
1.2.60 3,759 12/17/2024
1.2.59 686 12/17/2024
1.2.58 512 12/16/2024
1.2.57 1,470 12/16/2024
1.2.56 17,404 12/15/2024
1.2.55 6,285 12/13/2024
1.2.54 738 12/13/2024
1.2.53 12,170 12/11/2024
1.2.52 1,223 12/11/2024
1.2.51 15,090 12/10/2024
1.2.50 7,644 12/9/2024
1.2.49 17,362 12/6/2024
1.2.48 6,727 12/5/2024
1.2.47 7,404 12/4/2024
1.2.46 1,324 12/4/2024
1.2.45 81,859 11/27/2024
1.2.44 33,320 11/23/2024
1.2.43 1,552 11/22/2024
1.2.42 28,269 11/21/2024
1.2.41 42,465 11/20/2024
1.2.40 1,012 11/19/2024
1.2.39 16,775 11/17/2024
1.2.38 453 11/16/2024
1.2.37 13,891 11/14/2024
1.2.36 22,169 11/13/2024
1.2.35 2,490 11/12/2024
1.2.34 20,597 11/10/2024
1.2.33 2,783 11/8/2024
1.2.32 400 11/7/2024
1.2.31 6,252 11/6/2024
1.2.30 2,243 11/4/2024
1.2.29 7,066 11/1/2024
1.2.28 1,085 11/1/2024
1.2.27 10,154 10/30/2024
1.2.26 5,507 10/30/2024
1.2.25 3,224 10/29/2024
1.2.24 1,585 10/28/2024
1.2.23 5,848 10/27/2024
1.2.22 4,868 10/24/2024
1.2.21 3,615 10/23/2024
1.2.20 725 10/22/2024
1.2.19 192 10/22/2024
1.2.18 6,189 10/20/2024
1.2.17 610 10/20/2024
1.2.16 938 10/19/2024
1.2.15 662 10/19/2024
1.2.14 294 10/18/2024
1.2.13 284 10/18/2024
1.2.12 1,010 10/18/2024
1.2.11 297 10/17/2024
1.2.10 4,901 10/17/2024
1.2.9 22,962 10/7/2024
1.2.8 571 10/7/2024
1.2.7 1,011 10/3/2024
1.2.6 276 10/2/2024
1.2.5 1,801 9/28/2024
1.2.4 4,121 9/22/2024
1.2.3 7,188 9/6/2024
1.1.2 13,251 7/18/2024
1.1.1 5,742 5/21/2024
1.0.1 702 5/15/2024