Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/stefh/restease-client-generator
A Visual Studio Extension to generate a RestEase compatible client based on a Swagger / OpenAPI specification files
https://github.com/stefh/restease-client-generator
Last synced: 4 months ago
JSON representation
A Visual Studio Extension to generate a RestEase compatible client based on a Swagger / OpenAPI specification files
- Host: GitHub
- URL: https://github.com/stefh/restease-client-generator
- Owner: StefH
- License: mit
- Created: 2019-12-22T08:37:20.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2022-12-25T09:49:43.000Z (about 2 years ago)
- Last Synced: 2024-04-14T05:43:43.372Z (10 months ago)
- Language: C#
- Size: 17.2 MB
- Stars: 24
- Watchers: 3
- Forks: 4
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
README
# RestEase-Client-Generator
Generate a [RestEase](https://github.com/canton7/RestEase) compatible client (Interface & Models) based on a [Swagger / OpenApi](https://swagger.io/specification/) or [RAML](https://raml.org/) specification.## :one: NuGet Package
[data:image/s3,"s3://crabby-images/fa58a/fa58adb9b8bbd3faa5a192f7b4ec9c9024ef798b" alt="NuGet Badge"](https://www.nuget.org/packages/RestEaseClientGenerator)## :two: dotnet tool
[data:image/s3,"s3://crabby-images/6c551/6c55183f82ea864ea06ff60a605b9a6a13b781de" alt="NuGet Badge dotnet-resteaseclientgenerator"](https://www.nuget.org/packages/dotnet-resteaseclientgenerator)
#### [Installation & Usage](https://github.com/StefH/RestEase-Client-Generator/wiki/Tool)
## :three: Visual Studio Extension
[data:image/s3,"s3://crabby-images/792a9/792a9e49456c4a749a2cb61a5c39034230fba49b" alt="Version"](https://marketplace.visualstudio.com/items?itemName=StefHeyenrath.RestEaseClientGenerator)
[data:image/s3,"s3://crabby-images/fe6fb/fe6fb341b273329729737ffd6c2b04987cf38b1f" alt="Installs"](https://marketplace.visualstudio.com/items?itemName=StefHeyenrath.RestEaseClientGenerator)
[data:image/s3,"s3://crabby-images/f7985/f798539acd3701946e95352216479e0ba3366105" alt="Rating"](https://marketplace.visualstudio.com/items?itemName=StefHeyenrath.RestEaseClientGenerator)### Features
- Supports Visual Studio 2017 and 2019
- Add New RestEase API Client to a project from an OpenAPI specification URL (e.g https://petstore.swagger.io/v2/swagger.json)
- Define custom namespace for the generated file
- Auto-updating of generated code file when changes are made to the specification file (.json, .yml, .yaml, .raml)
- This Visual Studio Extension will automatically add the required nuget packages that the generated code depends on.#### [Installation & Usage](https://github.com/StefH/RestEase-Client-Generator/wiki/NuGet)
## Options
See https://github.com/StefH/RestEase-Client-Generator/wiki/Options
---
# Demo
[Blazor WebAssembly Demo](https://stefh.github.io/RestEase-Client-Generator/)# Example
### Input Yaml file 'PetStore.yaml'
Excerpt...
``` yml
paths:
/pet:
post:
tags:
- pet
summary: Add a new pet to the store
description: ''
operationId: addPet
consumes:
- application/json
- application/xml
produces:
- application/xml
- application/json
parameters:
- in: body
name: body
description: Pet object that needs to be added to the store
required: true
schema:
$ref: '#/definitions/Pet'
```
([Full example](https://github.com/StefH/RestEase-Client-Generator/blob/master/examples/RestEaseClientGeneratorConsoleApp/petstore.yaml)).### Generate file 'PetStore.cs'
Excerpt...
``` c#
namespace RestEaseClientGeneratorConsoleApp.PetStoreJson.Api
{
public interface IPetStoreApi
{
///
/// Add a new pet to the store
///
/// A pet for sale in the pet store
[Post("/pet")]
Task AddPetAsync([Body] Pet pet);// More methods ...
}
}namespace RestEaseClientGeneratorConsoleApp.PetStoreJson.Models
{
public class Pet
{
public long Id { get; set; }// More properties ...
}
}
```
([Full example](https://github.com/StefH/RestEase-Client-Generator/blob/master/examples/RestEaseClientGeneratorConsoleApp/PetStoreJson/PetStoreJson.cs)).### Create a Client and call methods
``` c#
var petStoreApi = RestClient.For("https://petstore.swagger.io/v2");var findPetsByTags = await petStoreApi.FindPetsByTagsAsync(new[] { "cat" });
```## Screenshots
### Add new specification and generate client code
data:image/s3,"s3://crabby-images/55639/55639f81335e6a46db74d924ec6e039fee3e9d9e" alt="Add from OpenAPI Specification"
data:image/s3,"s3://crabby-images/742b8/742b8a3c4963cb7926964445998e212d5dfda1e9" alt="Enter URL to OpenAPI Specification"### Generate client code for existing .json, .yml or .yaml file
data:image/s3,"s3://crabby-images/72c0f/72c0f10cdbcb15da3e41b845db2a180e40eb5ff9" alt="Solution Explorer Context Menus"## Credits
- Project source code is based on [REST API Client Code Generator](https://github.com/christianhelle/apiclientcodegen)
- Code used from https://raw.githubusercontent.com/andeart/CaseConversions/master/CaseConversions/CaseConversion.cs
- Code used from https://www.codeproject.com/articles/6294/description-enum-typeconverter