To understand why i'm publishing this fork on NuGet.org: read here
Generates Swagger (2.0) for WCF services and also provides swagger-ui.
With an API described in Swagger you can use multiple Swagger tools like client generators, see swagger-codegen for more details.
This project is a fork of abelsilva/swaggerwcf which has started as a fork from superstator/Swaggeratr to implement version 2.0 of Swagger.
Install-Package KornSW.SwaggerWcf
Add the route in the Application_Start
method inside Global.asax
protected void Application_Start(object sender, EventArgs e)
{
// [.......]
RouteTable.Routes.Add(new ServiceRoute("api-docs", new WebServiceHostFactory(), typeof(SwaggerWcfEndpoint)));
}
Note: You might need to add a reference to System.ServiceModel.Activation
Edit Web.config
and add the following (if it doesn't exist yet) inside the system.serviceModel
block
<serviceHostingEnvironment aspNetCompatibilityEnabled="true" multipleSiteBindingsEnabled="true"/>
Edit again Web.config
and add the following (if it doesn't exist yet) inside the system.webServer
block
<modules runAllManagedModulesForAllRequests="true"/>
Add an endpoint to your App.config file.
<services>
<service name="SwaggerWcf.SwaggerWcfEndpoint">
<endpoint address="http://localhost/docs" binding="webHttpBinding" contract="SwaggerWcf.ISwaggerWcfEndpoint" />
</service>
</services>
Create a WebServiceHost
var swaggerHost = new WebServiceHost(typeof(SwaggerWcfEndpoint));
swaggerHost.Open();
Add the following to your config file.
This will allow the WCF service to accept requests and send replies based on the Content-Type
headers.
<system.serviceModel>
<behaviors>
<endpointBehaviors>
<behavior>
<webHttp automaticFormatSelectionEnabled="true" />
</behavior>
</endpointBehaviors>
<!-- [.......] -->
</behaviors>
</system.serviceModel>
Add the following to your config file and change the values accordingly
<configSections>
<section name="swaggerwcf" type="SwaggerWcf.Configuration.SwaggerWcfSection, SwaggerWcf" />
</configSections>
<swaggerwcf>
<tags>
<tag name="LowPerformance" visible="false" />
</tags>
<settings>
<setting name="InfoDescription" value="Sample Service to test SwaggerWCF" />
<setting name="InfoVersion" value="0.0.1" />
<setting name="InfoTermsOfService" value="Terms of Service" />
<setting name="InfoTitle" value="SampleService" />
<setting name="InfoContactName" value="Abel Silva" />
<setting name="InfoContactUrl" value="http://github.com/abelsilva" />
<setting name="InfoContactEmail" value="no@e.mail" />
<setting name="InfoLicenseUrl" value="https://github.com/abelsilva/SwaggerWCF/blob/master/LICENSE" />
<setting name="InfoLicenseName" value="Apache License" />
</settings>
</swaggerwcf>
Notes:
- make sure the
configSections
block is the first child ofconfiguration
tags
will be described further down
Configure the base properties via code. New: You can add security settings to your api (see also the new Security-Methodattribute)
var info = new Info
{
Description = "Sample Service to test SwaggerWCF",
Version = "0.0.1"
// etc
};
var security = new SecurityDefinitions
{
{
"api-gateway", new SecurityAuthorization
{
Type = "oauth2",
Name = "api-gateway",
Description = "Forces authentication with credentials via an api gateway",
Flow = "password",
Scopes = new Dictionary<string, string="">
{
{ "author", "use author scope"},
{ "admin", "use admin scope"},
},
AuthorizationUrl = "http://yourapi.net/oauth/token"
}
}
};
SwaggerWcfEndpoint.Configure(info, security);
For each method, configure the WebInvoke
or WebGet
attribute, and add a SwaggerWcfPath
attribute.
[ServiceContract]
public interface IStore
{
[SwaggerWcfPath("Create book", "Create a book on the store")]
[WebInvoke(UriTemplate = "/books",
BodyStyle = WebMessageBodyStyle.Bare,
Method = "POST",
RequestFormat = WebMessageFormat.Json,
ResponseFormat = WebMessageFormat.Json)]
[OperationContract]
Book CreateBook(Book value);
// [.......]
}
Add the SwaggerWcf
and AspNetCompatibilityRequirements
attributes to the class providing the base path for the service (the same as used in step 2).
Optinally, for each method, add the SwaggerWcfTag
to categorize the method and the SwaggerWcfResponse
for each possible response from the service.
[AspNetCompatibilityRequirements(RequirementsMode = AspNetCompatibilityRequirementsMode.Allowed)]
[SwaggerWcf("/v1/rest")]
public class BookStore : IStore
{
[SwaggerWcfTag("Books")]
[SwaggerWcfResponse(HttpStatusCode.Created, "Book created, value in the response body with id updated")]
[SwaggerWcfResponse(HttpStatusCode.BadRequest, "Bad request", true)]
[SwaggerWcfResponse(HttpStatusCode.InternalServerError,
"Internal error (can be forced using ERROR_500 as book title)", true)]
public Book CreateBook(Book value)
{
// [.......]
}
// [.......]
}
[DataContract(Name = "book")]
[Description("Book with title, first publish date, author and language")]
[SwaggerWcfDefinition(ExternalDocsUrl = "http://en.wikipedia.org/wiki/Book", ExternalDocsDescription = "Description of a book")]
public class Book
{
[DataMember(Name = "id")]
[Description("Book ID")]
public string Id { get; set; }
// [.......]
}
Note: make sure you add at least the DataContract
and DataMember
attributes in classes and properties
Attribute | Used in | Description | Options |
---|---|---|---|
SwaggerWcf |
Class , Interface |
Enable parsing WCF service | ServicePath |
SwaggerWcfHidden |
Class , Method , Property , Parameter |
Hide element from Swagger | |
SwaggerWcfTag |
Class , Method , Property , Parameter |
Add a tag to an element | TagName , HideFromSpec |
SwaggerWcfHeader |
Method |
Configure method HTTP headers | Name , Required , Description , DefaultValue |
SwaggerWcfPath |
Method |
Configure a method in Swagger | Summary , Description , OperationId , ExternalDocsDescription , ExternalDocsUrl , Deprecated |
SwaggerWcfParameter |
Parameter |
Configure method parameters | Required , Description , ParameterType |
SwaggerWcfProperty |
Property |
Configure property parameters | Required , Description , Minimum , Maximum , Default , ... |
SwaggerWcfResponse |
Method |
Configure method return value | Code , Description , EmptyResponseOverride , Headers |
SwaggerWcfDefinition |
Class |
Configure a data type | ExternalDocsDescription , ExternalDocsUrl |
SwaggerWcfReturnType |
Method |
Override method return type | ReturnType |
SwaggerWcfContentTypes |
Method |
Override consume/produce content-types | ConsumeTypes , ProduceTypes |
SwaggerWcfSecurity |
Method |
Add security background to this method | SecurityDefinitionName , params Scopes |
Tags are used to create categories in Swagger UI.
In SwaggerWcf they can also be used to hide or show elements from the Swagger output using the configuration file.
Using the configuration from step 4, any elements with the tag LowPerformance
will be hidden from Swagger.
When a SwaggerWcfTag
is added to an element, it may be configured with HideFromSpec
.
This will prevent this tag to be displayed in the Swagger output.
When combined with SwaggerWcfHidden
, if the tag has the value visible
as true
in web.config
file, the element will be visible
To specify query parameters to a function you may use the following syntax
[WebGet(UriTemplate = "/books?filter={filter}", BodyStyle = WebMessageBodyStyle.Bare)]
Book[] ReadBooks(string filter = null);
To specify a paramter as optional for swagger-ui provide a default value for the parameter on the interface.
public string Foo(string bar = null);
To mark a property as optional or required, use the IsRequired
parameter on the DataMember
attribute.
- Add some options to configuration in
Web.config
- Tests
Fork this project KornSW/swaggerwcf and submit pull requests.
Since pull requests and issues are not processed within the origin repo abelsilva/swaggerwcf i was forced to do further bug-fixing by my own!
I hope, that the origin repo will come back to live - because then i could revet to it...