Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/unchase/Unchase.OpenAPI.Connectedservice
:scroll: Visual Studio extension to generate OpenAPI (Swagger) web service reference.
https://github.com/unchase/Unchase.OpenAPI.Connectedservice
nswag nswagstudio odata openapi openapi-client openapi-codegen openapi3 scaffolding swagger visual-studio visual-studio-extension vsix vsix-extensions
Last synced: 4 months ago
JSON representation
:scroll: Visual Studio extension to generate OpenAPI (Swagger) web service reference.
- Host: GitHub
- URL: https://github.com/unchase/Unchase.OpenAPI.Connectedservice
- Owner: unchase
- License: apache-2.0
- Created: 2019-03-30T18:26:16.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2023-06-20T19:36:54.000Z (over 1 year ago)
- Last Synced: 2024-08-02T16:52:21.445Z (7 months ago)
- Topics: nswag, nswagstudio, odata, openapi, openapi-client, openapi-codegen, openapi3, scaffolding, swagger, visual-studio, visual-studio-extension, vsix, vsix-extensions
- Language: C#
- Homepage: https://marketplace.visualstudio.com/items?itemName=unchase.unchaseOpenAPIConnectedService
- Size: 8.79 MB
- Stars: 106
- Watchers: 2
- Forks: 17
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Funding: .github/FUNDING.yml
- License: LICENSE.md
Awesome Lists containing this project
README
data:image/s3,"s3://crabby-images/3dd8a/3dd8a61b44f3f9e057f29e36884bfd5fae573b61" alt="Logo"
[Unchase OpenAPI (Swagger) Connected Service](https://marketplace.visualstudio.com/items?itemName=Unchase.unchaseOpenAPIConnectedService) is a Visual Studio 2017/2019/2022 extension to generate `C#` (`TypeScript`) `HttpClient` (or `C#` `Controllers`) code for `OpenAPI` (formerly [`Swagger API`](https://swagger.io/docs/specification/about/)) web service with [NSwag](https://github.com/RSuter/NSwag).
> Starting from Visual Studio Community 2019 v16.1.3 extensions based on `Microsoft Connected Services` now work fine.
> The project is developed and maintained by [Nikolay Chebotov (**Unchase**)](https://github.com/unchase).
## Getting Started
#### **[Read How-To on medium.com](https://medium.com/@unchase/how-to-generate-c-or-typescript-client-code-for-openapi-swagger-specification-d882d59e3b77)**
Install from `Tools -> Extensions and Updates` menu inside [Visual Studio](https://visualstudio.microsoft.com/vs/) 2017 (for [VisualStudio](https://visualstudio.microsoft.com/vs/) 2019: `Extensions -> Manage Extensions`) or [download](http://vsixgallery.com/extensions/Unchase.OpenAPI.ConnectedService.63199638-6211-4285-ba8f-75b1f0326c2a/extension.vsix) as `VSIX` package from VSGallery or [download](https://marketplace.visualstudio.com/items?itemName=unchase.unchaseOpenAPIConnectedService) as `VSIX` package from [Visual Studio Marketplace](https://marketplace.visualstudio.com/items?itemName=Unchase.unchaseopenapiconnectedservice):
data:image/s3,"s3://crabby-images/af1b6/af1b61db867a592f58781821ff341234777c2eaa" alt="Adding Unchase OpenAPI (Swagger) Connected Service in Visual Studio"
## Builds status
|Status|Value|
|:----|:---:|
|Build|[data:image/s3,"s3://crabby-images/f210a/f210a4d0e292567d3cdd1dcf2857ed75affebf95" alt="Build status"](https://ci.appveyor.com/project/unchase/unchase.openapi.connectedservice)
|Buid History|data:image/s3,"s3://crabby-images/ce7a8/ce7a8a4fe6ee26bf07751e13085173a8f017d249" alt="Build history"
|GitHub Release|[data:image/s3,"s3://crabby-images/822a0/822a0bf2558d8d23fc8c4c80882accb94158d544" alt="GitHub release"](https://github.com/unchase/Unchase.OpenAPI.Connectedservice/releases/latest)
|GitHub Release Date|[data:image/s3,"s3://crabby-images/14724/14724ff968985608d2b98723f15f8d9697d16c3d" alt="GitHub Release Date"](https://github.com/unchase/Unchase.OpenAPI.Connectedservice/releases/latest)
|GitHub Release Downloads|[data:image/s3,"s3://crabby-images/5c544/5c54496de9df642c20978824906c9ee9260380f8" alt="Github Releases"](https://github.com/unchase/Unchase.OpenAPI.Connectedservice/releases/latest)
|VS Marketplace|[data:image/s3,"s3://crabby-images/1ed0d/1ed0db8f777d334fd7d1c50e01aa5432ae27a69f" alt="VS Marketplace"](https://marketplace.visualstudio.com/items?itemName=unchase.unchaseOpenAPIConnectedService)
|VS Marketplace Downloads|[data:image/s3,"s3://crabby-images/88483/88483927e73aa86a4c9d81aa040e8934490aceea" alt="VS Marketplace Downloads"](https://marketplace.visualstudio.com/items?itemName=unchase.unchaseOpenAPIConnectedService)
|VS Marketplace Installs|[data:image/s3,"s3://crabby-images/e2bfa/e2bfa486d945bc3f652f224f24dfa38ae536ba0e" alt="VS Marketplace Installs"](https://marketplace.visualstudio.com/items?itemName=unchase.unchaseOpenAPIConnectedService)## Features
- Generate `C#` or `TypeScript` clients/proxies (client code) from Swagger 2.0 and OpenAPI 3.0 specifications
- Generate `C#` ASP.NET Controller from Swagger 2.0 and OpenAPI 3.0 specifications
- **Experimental**: Generate `C#` or `TypeScript` clients/proxies (client code) or ASP.NET Controller from OData specification converted to OpenAPI based on [OpenAPI.NET.OData](https://github.com/microsoft/OpenAPI.NET.OData)
- Generate `.nswag` file for using in [`NSwagStudio`](https://github.com/NSwag/NSwag/wiki/NSwagStudio) (no need to install for generating)
- Add required dependencies for the `C#` client (before generating):
- Library targeting .NET Standard 1.4+:
1. Newtonsoft.Json ([NuGet](https://www.nuget.org/packages/Newtonsoft.Json))
2. System.Net.Http ([NuGet](https://www.nuget.org/packages/System.Net.Http))
3. System.ComponentModel.Annotations ([NuGet](https://www.nuget.org/packages/System.ComponentModel.Annotations))
- Library targeting the full .NET:
1. Newtonsoft.Json ([NuGet](https://www.nuget.org/packages/Newtonsoft.Json))
2. System.Runtime.Serialization (GAC)
3. System.ComponentModel.DataAnnotations (GAC)
- Library targeting PCL 259 (Portable Class Library):
1. Newtonsoft.Json ([NuGet](https://www.nuget.org/packages/Newtonsoft.Json))
2. Microsoft.Net.Http ([NuGet](https://www.nuget.org/packages/Microsoft.Net.Http))
3. Portable.DataAnnotations ([NuGet](https://www.nuget.org/packages/Portable.DataAnnotations))
- Add Required dependences for the `C#` controller (before generating):
1. Microsoft.AspNetCore.Mvc ([NuGet](https://www.nuget.org/packages/Microsoft.AspNetCore.MVC))
- **Command** to open generated `.nswag` and `.nswag.json` files in [NSWagStudio](https://github.com/NSwag/NSwag/wiki/NSwagStudio)
- **Command** to compare `.nswag.json` specification file with another `.nswag.json` specification file (or specification given by `endpoint`)
- Storage of the last 10 endpoints (specification path)## Settings Meaning
Meaning of the Unchase [OpenAPI (Swagger) Connected Service](https://marketplace.visualstudio.com/items?itemName=unchase.unchaseOpenAPIConnectedService) settings according to [NSwagStudio](https://github.com/NSwag/NSwag/wiki/NSwagStudio):
data:image/s3,"s3://crabby-images/bcf7e/bcf7ee08b7917b9223bf040893a1a9ce81e44651" alt="Unchase OpenAPI (Swagger) Connected Service settings meaning"
## Exclude type names
Since [v1.4.0](https://github.com/unchase/Unchase.OpenAPI.Connectedservice/releases/tag/v1.4.0) you can exclude type names in separate Window for C# client code generation:
data:image/s3,"s3://crabby-images/5f734/5f734e776e03cfd0408c9155636af6453defa8af" alt="Unchase OpenAPI (Swagger) Connected Service - exclude type names"
## Generate code from OData specification converted to OpenAPI specification
Since [v1.5.0](https://github.com/unchase/Unchase.OpenAPI.Connectedservice/releases/tag/v1.4.0) you can generate code from OData specification converted to OpenAPI specification:
data:image/s3,"s3://crabby-images/668e2/668e2ee92dcc89b7c6f9fec2d5f5450c69742860" alt="Unchase OpenAPI (Swagger) Connected Service - generate from OData"
## Custom Commands
### `Open in NSwagStudio` Command
Since *v1.1.** have been added menu command embedded in Visual Studio Solution Explorer context menu lets you open generated `.nswag` and `.nswag.json` files in [NSwagStudio](https://github.com/NSwag/NSwag/wiki/NSwagStudio).
This extension is for those times where you generate `.nswag` and `.nswag.json` files and you want to be able to quickly open it in [NSwagStudio](https://github.com/NSwag/NSwag/wiki/NSwagStudio).
#### Prerequisite
> In order to use this extension, you must have [Visual Studio](https://visualstudio.microsoft.com/vs/) 2017/2019, this connected service as well as [NSwagStudio](https://github.com/NSwag/NSwag/wiki/NSwagStudio) installed.
#### Solution Explorer
You can open `.nswag` and `.nswag.json` files in [NSWagStudio](https://github.com/NSwag/NSwag/wiki/NSwagStudio) by simply right-clicking it in Solution Explorer and select **Open in NSwagStudio**:
data:image/s3,"s3://crabby-images/7fbbc/7fbbc639876a7055732a5f12dde118c995ab1b1b" alt="Open in NSwagStudio menu Command"
#### Path to NSwagStudio.exe
If you installed [NSwagStudio](https://github.com/NSwag/NSwag/wiki/NSwagStudio) at a non-default location, a prompt will ask for the path to `NSwagStudio.exe`.
You can always change the location in *Tools -> Options -> Web -> Unchase OpenAPI (Swagger) Connected Service*:
data:image/s3,"s3://crabby-images/f26d0/f26d00583b11672c092c05c7cc160c8192739098" alt="Open in NSwagStudio Option"
### `Compare OpenAPI-specifications...` Command
Since *v1.2.** have been added menu command embedded in Visual Studio Solution Explorer context menu lets you compare generated `.nswag.json` specification-file with another `.nswag.json` specification-file (or with specification given by `endpoint`).
This extension is for those times where you generate `.nswag.json` file and you want to quickly compare it with another specification or specification given by `endpoint`.
#### Prerequisite
> In order to use this extension, you must have [Visual Studio](https://visualstudio.microsoft.com/vs/) 2017/2019 as well as this connected service.
#### Solution Explorer
You can compare `.nswag.json` specification-file with another `.nswag.json` specification-file (or with specification given by `endpoint`) by simply selecting one or two files and right-clicking them in Solution Explorer and select **Compare OpenAPI-specifications...**:
data:image/s3,"s3://crabby-images/2363f/2363fae04e979da9e9cf4f123c8dca1cff2d76f7" alt="Compare OpenAPI Specifications Command" data:image/s3,"s3://crabby-images/7d27a/7d27a9ef53a378af96121919e818853dfeb61c00" alt="Compare OpenAPI Specifications Command"
#### Path to the specification `Endpoint`
You can always change the specification Endpoint to compare with in *Tools -> Options -> Web -> Unchase OpenAPI (Swagger) Connected Service*:
data:image/s3,"s3://crabby-images/86b14/86b14d88d4ba8896dfa37b76b67cd5a016a76979" alt="Compare OpenAPI Specifications Option"
#### Compare View
data:image/s3,"s3://crabby-images/30adf/30adfa6daaa71008d8bf260363a7d2197e01a2dd" alt="Compare OpenAPI Specifications Command result"
## HowTos
- [ ] Add HowTos in a future
- [ ] ... [request for HowTo you need](https://github.com/unchase/Unchase.OpenAPI.Connectedservice/issues/new?title=DOC)## Troubleshooting
### Can't open .nswag file in NSwagStudio
- You can use **Open in NSwagStudio** menu command
- If generated code corrupted, try to open `.nswag` file in [`NSwagStudio`](https://github.com/RSuter/NSwag/wiki/NSwagStudio) (Windows GUI for editing .*nswag files)
- If it doesn't open, try to create new `.nswag` file in [`NSwagStudio`](https://github.com/RSuter/NSwag/wiki/NSwagStudio) for the same API service link and check the differences### Installation completes but I can't see the Service in the list of connected services (Visual Studio 2019)
- Relevant [bug report](https://developercommunity.visualstudio.com/content/problem/468751/vs2019-preview-cannot-install-connected-service-ex.html). `Connected Services` restored in the v16.1.3 update to [Visual Studio](https://visualstudio.microsoft.com/vs/) 2019.
## Roadmap
See the [changelog](CHANGELOG.md) for the further development plans and version history.
## Feedback
Please feel free to add your [review](https://marketplace.visualstudio.com/items?itemName=unchase.unchaseOpenAPIConnectedService&ssr=false#review-details), [request a feature](https://github.com/unchase/Unchase.OpenAPI.Connectedservice/issues/new?title=FEATURE), [ask a question](https://marketplace.visualstudio.com/items?itemName=unchase.unchaseOpenAPIConnectedService&ssr=false#qna) or [report a bug](https://github.com/unchase/Unchase.OpenAPI.Connectedservice/issues/new?title=BUG) including in connected service:
data:image/s3,"s3://crabby-images/ca743/ca743d0b88cec31926cfb5eb4b9d911f0cfd4cf8" alt="Unchase OpenAPI Connected Service Report a Bug"
Thank you in advance!
## Thank me!
If you like what I am doing and you would like to thank me, please consider:
[data:image/s3,"s3://crabby-images/7989e/7989e8457abd478792bd816bfac4c76dc54fe6eb" alt="Buy me a coffe!"](https://www.buymeacoffee.com/nikolaychebotov)
Thank you for your support!
----------
Copyright © 2019 [Nikolay Chebotov (**Unchase**)](https://github.com/unchase) - Provided under the [Apache License 2.0](LICENSE.md).