Microsoft.OpenApi.OData 1.6.0-preview.4

Prefix Reserved
This is a prerelease version of Microsoft.OpenApi.OData.
There is a newer version of this package available.
See the version list below for details.
dotnet add package Microsoft.OpenApi.OData --version 1.6.0-preview.4
                    
NuGet\Install-Package Microsoft.OpenApi.OData -Version 1.6.0-preview.4
                    
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="Microsoft.OpenApi.OData" Version="1.6.0-preview.4" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Microsoft.OpenApi.OData" Version="1.6.0-preview.4" />
                    
Directory.Packages.props
<PackageReference Include="Microsoft.OpenApi.OData" />
                    
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 Microsoft.OpenApi.OData --version 1.6.0-preview.4
                    
#r "nuget: Microsoft.OpenApi.OData, 1.6.0-preview.4"
                    
#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.
#:package Microsoft.OpenApi.OData@1.6.0-preview.4
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=Microsoft.OpenApi.OData&version=1.6.0-preview.4&prerelease
                    
Install as a Cake Addin
#tool nuget:?package=Microsoft.OpenApi.OData&version=1.6.0-preview.4&prerelease
                    
Install as a Cake Tool

nuget

Convert OData to OpenAPI.NET

Introduction

The Microsoft.OpenAPI.OData.Reader library helps represent an OData service metadata as an OpenApi description. It converts OData CSDL, the XML representation of the Entity Data Model (EDM) describing an OData service into Open API based on OpenAPI.NET object model.

The conversion is based on the mapping doc from OASIS OData OpenAPI v1.0 and uses the following :

  1. Capabilities vocabulary annotation
  2. Authorization vocabulary annotation
  3. Core vocabulary annotation
  4. Navigation property path
  5. Edm operation and operation import path

Overview

The image below is generic overview of how this library can convert the EDM model to an OpenAPI.NET document object.

Convert OData CSDL to OpenAPI

For more information on the CSDL and Entity Data model, please refer to http://www.odata.org/documentation. For more information about the Open API object of model, please refer to http://github.com/microsoft/OpenAPI.NET

Sample code

The following sample code illustrates the use of the library

public static void GenerateOpenApiDescription()
{
    IEdmModel model = GetEdmModel();
    OpenApiDocument document = model.ConvertToOpenApi();
    var outputJSON = document.SerializeAsJson(OpenApiSpecVersion.OpenApi3_0);
    var outputYAML = document.SerializeAsYaml(OpenApiSpecVersion.OpenApi3_0);
}

public static IEdmModel GetEdmModel()
{
    // load EDM model here...
}

Or with the convert settings:

public static void GenerateOpenApiDescription()
{
    IEdmModel model = GetEdmModel();
    OpenApiConvertSettings settings = new OpenApiConvertSettings
    {
        // configuration
    };
    OpenApiDocument document = model.ConvertToOpenApi(settings);
    var outputJSON = document.SerializeAsJson(OpenApiSpecVersion.OpenApi3_0);
    var outputYAML = document.SerializeAsYaml(OpenApiSpecVersion.OpenApi3_0);
}

public static IEdmModel GetEdmModel()
{
    // load EDM model here...
}

The GetEdmModel() method can load a model in 3 ways:

  1. Create the Edm model from scratch. For details refer building a basic model

  2. Load the Edm model from CSDL file. The following shows a code sample that loads a model from a csdl file.

    public static IEdmModel GetEdmModel()
    {
        string csdlFilePath = @"c:\csdl.xml";
        string csdl = System.IO.File.ReadAllText(csdlFilePath);
        IEdmModel model = CsdlReader.Parse(XElement.Parse(csdl).CreateReader());
        return model;
    }
    
  3. Create the Edm model using Web API OData model builder. For details refer to the web api model builder article

Nuget packages

The OpenAPI.OData.reader nuget package is at: https://www.nuget.org/packages/Microsoft.OpenApi.OData/


Contributing

This project welcomes contributions and suggestions. Most contributions require you to agree to a Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us the rights to use your contribution. For details, visit https://cla.microsoft.com.

When you submit a pull request, a CLA-bot will automatically determine whether you need to provide a CLA and decorate the PR appropriately (e.g., label, comment). Simply follow the instructions provided by the bot. You will only need to do this once across all repos using our CLA.

You can also open an issue directly on this repo via this link.

This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  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.  net9.0 was computed.  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. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (7)

Showing the top 5 NuGet packages that depend on Microsoft.OpenApi.OData:

Package Downloads
DT-ESA.Elevate.SecureConnectors

Generates DTO classes and provides wrappers for resource access.

Swashbuckle.AspNetCore.Community.OData

Provides support for Microsoft.AspNetCore.OData in Swashbuckle

Microsoft.Restier.AspNetCore.Swagger

Package Description

DT-ESA.SecureConnectors

Generates DTO classes and provides wrappers for resource access.

Eternet.OpenApi.Client

Package Description

GitHub repositories (5)

Showing the top 5 popular GitHub repositories that depend on Microsoft.OpenApi.OData:

Repository Stars
microsoft/OpenAPI.NET
The OpenAPI.NET SDK contains a useful object model for OpenAPI documents in .NET along with common serializers to extract raw OpenAPI JSON and YAML documents from the model.
OData/AspNetCoreOData
ASP.NET Core OData: A server library built upon ODataLib and ASP.NET Core
OData/RESTier
A turn-key library for building RESTful services
unchase/Unchase.OpenAPI.Connectedservice
:scroll: Visual Studio extension to generate OpenAPI (Swagger) web service reference.
christianhelle/httpgenerator
Generate .http files from OpenAPI (Swagger) specifications
Version Downloads Last Updated
2.0.0 419 7/10/2025
2.0.0-preview.18 468 7/2/2025
2.0.0-preview.17 141 7/2/2025
2.0.0-preview.16 110 7/2/2025
2.0.0-preview.15 765 6/3/2025
2.0.0-preview.14 677 5/14/2025
2.0.0-preview.13 651 4/17/2025
2.0.0-preview.12 919 4/2/2025
2.0.0-preview.11 216 3/19/2025
2.0.0-preview.10 713 3/18/2025
2.0.0-preview.7 3,914 10/28/2024
2.0.0-preview.6 745 10/17/2024
2.0.0-preview.5 199 10/11/2024
2.0.0-preview.4 132 10/10/2024
2.0.0-preview.3 397 10/3/2024
2.0.0-preview.2 1,173 8/23/2024
2.0.0-preview.1 121 8/16/2024
1.7.5 19,640 3/31/2025
1.7.4 13,084 1/28/2025
1.7.3 1,264 1/22/2025
1.7.2 1,020 1/20/2025
1.7.1 1,761 1/15/2025
1.7.0 3,141 1/2/2025
1.6.9 2,091 12/24/2024
1.6.8 56,065 7/24/2024
1.6.7 7,785 6/26/2024
1.6.6 10,677 6/11/2024
1.6.5 3,570 5/27/2024
1.6.4 3,640 5/21/2024
1.6.3 4,610 4/29/2024
1.6.2 1,177 4/26/2024
1.6.1 9,520 3/28/2024
1.6.0 10,984 3/18/2024
1.6.0-preview.10 519 3/4/2024
1.6.0-preview.9 150 3/1/2024
1.6.0-preview.8 173 2/13/2024
1.6.0-preview.7 306 2/5/2024
1.6.0-preview.6 93 2/2/2024
1.6.0-preview.5 112 2/1/2024
1.6.0-preview.4 208 1/25/2024
1.6.0-preview.3 123 1/23/2024
1.6.0-preview.2 214 1/16/2024
1.6.0-preview.1 99 1/9/2024
1.5.0 38,754 12/8/2023
1.5.0-preview9 2,231 11/13/2023
1.5.0-preview8 458 11/6/2023
1.5.0-preview7 737 10/26/2023
1.5.0-preview6 255 10/24/2023
1.5.0-preview5 722 10/4/2023
1.5.0-preview4 1,084 9/5/2023
1.5.0-preview3 372 9/1/2023
1.5.0-preview2 975 6/14/2023
1.5.0-preview1 379 6/2/2023
1.4.0 116,455 5/3/2023
1.4.0-preview7 364 5/2/2023
1.4.0-preview6 388 4/27/2023
1.4.0-preview5 855 4/20/2023
1.4.0-preview4 336 4/18/2023
1.4.0-preview3 468 4/17/2023
1.4.0-preview2 936 4/13/2023
1.4.0-preview1 581 4/5/2023
1.3.0 12,406 3/29/2023
1.3.0-preview4 537 3/22/2023
1.3.0-preview3 468 3/21/2023
1.3.0-preview2 944 2/28/2023
1.3.0-preview1 431 2/1/2023
1.2.0 30,498 1/20/2023
1.2.0-preview9 2,344 12/15/2022
1.2.0-preview8 1,083 11/17/2022
1.2.0-preview7 505 11/8/2022
1.2.0-preview6 1,006 11/1/2022
1.2.0-preview5 551 10/24/2022
1.2.0-preview4 783 10/6/2022
1.2.0-preview3 401 10/3/2022
1.2.0-preview2 423 9/28/2022
1.2.0-preview1 394 9/28/2022
1.1.0 59,467 9/14/2022
1.0.11 37,581 7/18/2022
1.0.11-preview5 712 7/8/2022
1.0.11-preview4 612 7/6/2022
1.0.11-preview3 1,226 6/22/2022
1.0.11-preview2 846 6/6/2022
1.0.11-preview1 453 5/30/2022
1.0.10 23,909 5/10/2022
1.0.10-preview3 1,838 3/29/2022
1.0.10-preview2 1,216 3/3/2022
1.0.10-preview1 658 2/25/2022
1.0.9 76,863 10/7/2021
1.0.8 102,334 5/6/2021
1.0.7 20,020 4/13/2021
1.0.6 27,195 2/11/2021
1.0.5 1,265 2/6/2021
1.0.4 58,451 7/21/2020
1.0.2 8,038 5/25/2020
1.0.1 44,252 10/10/2019
1.0.0 2,488 9/25/2019
1.0.0-beta9 16,517 8/13/2019
1.0.0-beta8 3,021 8/6/2019
1.0.0-beta7 5,775 9/24/2018
1.0.0-beta6 1,220 9/19/2018
1.0.0-beta5 1,169 9/7/2018
1.0.0-beta4 1,807 5/30/2018

- Reads annotations on structural properties of stream types for media entity paths #399
- Updates the format of the request body schema of a collection of complex property #423
- Adds a delete operation and a required @id query parameter to collection-valued navigation property paths with $ref #453
- Fixes inconsistency of nullability of schemas of properties that are a collection of structured types #467