Documenting your RESTful C# ASP.Net Core Web Api using Swashbuckle & Swagger
data:image/s3,"s3://crabby-images/84ed3/84ed34c38cc8f27469961c7fdc806d0332868332" alt="Documenting your RESTful C# ASP.Net Core Web Api using Swashbuckle & Swagger"
RESTful Api Endpoints
How often have you been in a situation where you’re having to code against an undocumented API? Perhaps your team is building an API and publishing it to another group of developers. Understanding the API endpoints without the correct documentation can be a challenge…
data:image/s3,"s3://crabby-images/9354c/9354c17b3e3997285bfe42f1c168f19523a54379" alt="C# ASP.Net Core Web Api - Swashbuckle Swagger"
C# ASP.Net Core Web Api - Swashbuckle Swagger
Enter “Swagger”…
Swagger enables you o generate interactive documentation as a readable representation of a RESTful API.
In order to generate Swagger documents for our C# ASP.Net Core Web Api application, we need to utilise Swashbuckle - An open source project.
data:image/s3,"s3://crabby-images/1665a/1665acab0d7a36ca1de32a2a22e93ea6df168a2f" alt="C# ASP.Net Core Web Api - Swashbuckle Swagger"
C# ASP.Net Core Web Api - Swashbuckle Swagger
Let’s Code…
I’ve implemented a basic C# ASP.Net Core Web Api solution with 2 public endpoints for us to document.
data:image/s3,"s3://crabby-images/9177d/9177df43f08dbc2490c315786e0df8cc9a2c8cba" alt="C# ASP.Net Core Web Api - Swashbuckle Swagger"
C# ASP.Net Core Web Api - Swashbuckle Swagger
Now to pull in the required Swashbuckle packages from Nuget.
data:image/s3,"s3://crabby-images/04d99/04d9988a692b3985771686e21de58d36dc6de10a" alt="C# ASP.Net Core Web Api - Swashbuckle Swagger"
C# ASP.Net Core Web Api - Swashbuckle Swagger
Now to add our configuration into the appsettings file.
data:image/s3,"s3://crabby-images/2592c/2592ce02c46fed15cfd798a24a17507d79246a3a" alt="C# ASP.Net Core Web Api - Swashbuckle Swagger"
C# ASP.Net Core Web Api - Swashbuckle Swagger
Head to your Startup.cs file and let’s configure our Swagger middleware. Our previously added configuration details can now be made use of.
data:image/s3,"s3://crabby-images/a9aa1/a9aa12840a276fe3c64df090dfe6e8a4e4a22899" alt="C# ASP.Net Core Web Api - Swashbuckle Swagger"
C# ASP.Net Core Web Api - Swashbuckle Swagger
Now to make use of the variables and configure our Swagger service.
data:image/s3,"s3://crabby-images/5152f/5152f982bcf7fb1ef37b0ec09b9caa62e172cfe3" alt="C# ASP.Net Core Web Api - Swashbuckle Swagger"
C# ASP.Net Core Web Api - Swashbuckle Swagger
We can now configure our Swagger endpoint.
data:image/s3,"s3://crabby-images/cd5ad/cd5ad712386c3f1158992b058721fa5fcf99030c" alt="C# ASP.Net Core Web Api - Swashbuckle Swagger"
C# ASP.Net Core Web Api - Swashbuckle Swagger
Finally let’s head to the endpoint URL -
data:image/s3,"s3://crabby-images/990c6/990c63649c7b68c6b18aa6bac7173373b15a54e1" alt="C# ASP.Net Core Web Api - Swashbuckle Swagger"
C# ASP.Net Core Web Api - Swashbuckle Swagger
…and here’s the result!
data:image/s3,"s3://crabby-images/4b8c1/4b8c1a9e42ea8e5c7fd66f9f4f34ed584a81d065" alt="C# ASP.Net Core Web Api - Swashbuckle Swagger"
C# ASP.Net Core Web Api - Swashbuckle Swagger
Enjoy!