Refitter.SourceGenerator 0.7.3

There is a newer version of this package available.
See the version list below for details.
dotnet add package Refitter.SourceGenerator --version 0.7.3                
NuGet\Install-Package Refitter.SourceGenerator -Version 0.7.3                
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="Refitter.SourceGenerator" Version="0.7.3">
  <PrivateAssets>all</PrivateAssets>
  <IncludeAssets>runtime; build; native; contentfiles; analyzers</IncludeAssets>
</PackageReference>                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Refitter.SourceGenerator --version 0.7.3                
#r "nuget: Refitter.SourceGenerator, 0.7.3"                
#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 Refitter.SourceGenerator as a Cake Addin
#addin nuget:?package=Refitter.SourceGenerator&version=0.7.3

// Install Refitter.SourceGenerator as a Cake Tool
#tool nuget:?package=Refitter.SourceGenerator&version=0.7.3                

Source Generator

Refitter is available as a C# Source Generator that uses the Refitter.Core library for generating a REST API Client using the Refit library. Refitter can generate the Refit interface from OpenAPI specifications

The Refitter source generator is a bit untraditional in a sense that it creates a folder called Generated in the same location as the .refitter file and generates files to disk under the Generated folder. The source generator output should be included in the project and committed to source control. This is done because there is no other way to trigger the Refit source generator to pickup the Refitter generated code

(Translation: I couldn't for the life of me figure how to get that to work, sorry)

Installation

The source generator is distributed as a NuGet package and should be installed to the project that will contain the generated code

dotnet add package Refitter.SourceGenerator

Usage

This source generator generates code based on any .refitter file included to the project as AdditionalFiles.

The generator can automatically detect all .refitter files inside the project that referenced the Refitter.SourceGenerator package and there is no need to include them manually as AdditionalFiles

.Refitter File format

The following is an example .refitter file

{
  "openApiPath": "/path/to/your/openAPI", // Required
  "namespace": "Org.System.Service.Api.GeneratedCode", // Optional. Default=GeneratedCode
  "naming": {
    "useOpenApiTitle": false, // Optional. Default=true
    "interfaceName": "MyApiClient" // Optional. Default=ApiClient
  },
  "generateContracts": true, // Optional. Default=true
  "generateXmlDocCodeComments": true, // Optional. Default=true
  "addAutoGeneratedHeader": true, // Optional. Default=true
  "addAcceptHeaders": true, // Optional. Default=true
  "returnIApiResponse": false, // Optional. Default=false
  "generateOperationHeaders": true, // Optional. Default=true
  "typeAccessibility": "Public", // Optional. Values=Public|Internal. Default=Public
  "useCancellationTokens": false, // Optional. Default=false
  "useIsoDateFormat": false, // Optional. Default=false
  "multipleInterfaces": "ByEndpoint", // Optional. May be one of "ByEndpoint" or "ByTag"
  "additionalNamespaces": [ // Optional
    "Namespace1",
    "Namespace2"
  ]
}
  • openApiPath - points to the OpenAPI Specifications file. This can be the path to a file stored on disk, relative to the .refitter file. This can also be a URL to a remote file that will be downloaded over HTTP/HTTPS
  • namespace - the namespace used in the generated code. If not specified, this defaults to GeneratedCode
  • naming.useOpenApiTitle - a boolean indicating whether the OpenApi title should be used. Default is true
  • naming.interfaceName - the name of the generated interface. The generated code will automatically prefix this with I so if this set to MyApiClient then the generated interface is called IMyApiClient. Default is ApiClient
  • generateContracts - a boolean indicating whether contracts should be generated. A use case for this is several API clients use the same contracts. Default is true
  • generateXmlDocCodeComments - a boolean indicating whether XML doc comments should be generated. Default is true
  • addAutoGeneratedHeader - a boolean indicating whether XML doc comments should be generated. Default is true
  • addAcceptHeaders - a boolean indicating whether to add accept headers [Headers("Accept: application/json")]. Default is true
  • returnIApiResponse - a boolean indicating whether to return IApiResponse<T> objects. Default is false
  • generateOperationHeaders - a boolean indicating whether to use operation headers in the generated methods. Default is true
  • typeAccessibility - the generated type accessibility. Possible values are Public and Internal. Default is Public
  • useCancellationTokens - Use cancellation tokens in the generated methods. Default is false
  • useIsoDateFormat - Set to true to explicitly format date query string parameters in ISO 8601 standard date format using delimiters (for example: 2023-06-15). Default is false
  • multipleInterfaces - Set to ByEndpoint to generate an interface for each endpoint, or ByTag to group Endpoints by their Tag (like SwaggerUI groups them).
  • additionalNamespaces - A collection of additional namespaces to include in the generated file. A use case for this is when you want to reuse contracts from a different namespace than the generated code. Default is empty
There are no supported framework assets in this package.

Learn more about Target Frameworks and .NET Standard.

  • .NETStandard 2.0

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories (1)

Showing the top 1 popular GitHub repositories that depend on Refitter.SourceGenerator:

Repository Stars
christianhelle/refitter
A tool for generating Refit interfaces and contracts from OpenAPI specifications
Version Downloads Last updated
1.4.1-preview.62 40 11/4/2024
1.4.0 3,155 10/14/2024
1.4.0-preview.61 39 10/7/2024
1.3.2 1,261 9/23/2024
1.3.2-preview.60 43 9/23/2024
1.3.1 527 9/20/2024
1.3.0 781 9/14/2024
1.2.1-preview.59 50 9/13/2024
1.2.1-preview.58 123 9/11/2024
1.2.1-preview.57 56 9/11/2024
1.2.1-preview.56 49 9/9/2024
1.2.1-preview.55 46 9/2/2024
1.2.1-preview.54 45 8/29/2024
1.2.0 2,627 8/12/2024
1.2.0-preview.53 32 8/4/2024
1.2.0-preview.52 45 7/29/2024
1.1.3 19,563 7/19/2024
1.1.3-preview.51 47 7/19/2024
1.1.2 24,829 7/17/2024 1.1.2 is deprecated because it has critical bugs.
1.1.2-preview.50 41 7/16/2024
1.1.2-preview.49 56 7/11/2024
1.1.1 187,254 7/6/2024
1.1.1-preview.48 46 7/4/2024
1.1.1-preview.47 53 7/1/2024
1.1.1-preview.46 56 6/28/2024
1.1.0.45-preview 92 6/25/2024
1.0.2 237,805 6/13/2024
1.0.1 48,491 6/7/2024
1.0.0 246,637 5/3/2024
0.9.9.44-preview 77 4/29/2024
0.9.9 10,236 3/7/2024
0.9.8 2,086 2/27/2024
0.9.7 73,348 2/7/2024
0.9.6 280 1/29/2024
0.9.5 33,705 1/15/2024
0.9.4.43-preview 154 1/15/2024
0.9.4 32,166 1/12/2024
0.9.3.42-preview 146 1/10/2024
0.9.2 20,208 1/10/2024
0.9.1 4,099 1/9/2024
0.9.0 8,039 1/9/2024
0.8.7.41-preview 157 1/3/2024
0.8.7.40-preview 234 12/20/2023
0.8.7 59,366 12/18/2023
0.8.6.39-preview 440 12/14/2023
0.8.6.38-preview 130 12/14/2023
0.8.6 10,408 12/11/2023
0.8.5 629 11/23/2023
0.8.4 814 11/7/2023
0.8.3 209 10/31/2023
0.8.2 2,412 10/9/2023
0.8.1 225 10/4/2023
0.8.0 7,260 9/23/2023
0.7.5 206 9/7/2023
0.7.4 190 9/6/2023
0.7.3.37-preview 251 8/25/2023
0.7.3.36-preview 158 8/25/2023
0.7.3.35-preview 214 8/21/2023
0.7.3.34-preview 191 8/15/2023
0.7.3.33-preview 330 8/12/2023
0.7.3 882 8/26/2023
0.7.2.32-preview 289 8/7/2023 0.7.2.32-preview is deprecated because it has critical bugs.
0.7.2 266 8/7/2023 0.7.2 is deprecated because it has critical bugs.
0.7.1.31-preview 281 8/2/2023 0.7.1.31-preview is deprecated because it has critical bugs.
0.7.1.30-preview 275 8/2/2023 0.7.1.30-preview is deprecated because it has critical bugs.
0.7.1.29-preview 173 8/1/2023 0.7.1.29-preview is deprecated because it has critical bugs.
0.7.1 240 8/3/2023 0.7.1 is deprecated because it has critical bugs.
0.7.0.28-preview 239 7/28/2023 0.7.0.28-preview is deprecated because it has critical bugs.
0.7.0.27-preview 248 7/28/2023 0.7.0.27-preview is deprecated because it has critical bugs.
0.7.0.26-preview 255 7/27/2023 0.7.0.26-preview is deprecated because it has critical bugs.
0.7.0.23-preview 265 7/27/2023 0.7.0.23-preview is deprecated because it has critical bugs.
0.7.0.22-preview 241 7/27/2023 0.7.0.22-preview is deprecated because it has critical bugs.
0.7.0.21-preview 207 7/27/2023 0.7.0.21-preview is deprecated because it has critical bugs.
0.7.0.20-preview 217 7/27/2023 0.7.0.20-preview is deprecated because it has critical bugs.
0.7.0 174 7/31/2023 0.7.0 is deprecated because it has critical bugs.
0.6.3.10 199 7/26/2023 0.6.3.10 is deprecated because it has critical bugs.
0.6.3.9 177 7/26/2023 0.6.3.9 is deprecated because it has critical bugs.
0.6.3.8 238 7/26/2023 0.6.3.8 is deprecated because it has critical bugs.
0.6.3.7-preview 235 7/26/2023 0.6.3.7-preview is deprecated because it has critical bugs.
0.6.3.6-preview 202 7/26/2023 0.6.3.6-preview is deprecated because it has critical bugs.
0.6.3.5-preview 252 7/26/2023 0.6.3.5-preview is deprecated because it has critical bugs.
0.6.3.4-preview 248 7/26/2023 0.6.3.4-preview is deprecated because it has critical bugs.