-
Notifications
You must be signed in to change notification settings - Fork 1
Tutorial on How to Write and Use Swagger API
Mücahit Erdoğan Ünlü edited this page May 1, 2024
·
4 revisions
Swagger provides a way to document APIs in a machine-readable format, typically using JSON or YAML. The documentation includes details such as available endpoints, request parameters, response formats, authentication methods, and more. This tutorial is a step-by-step guide on how to specify these details using openapi
library. For openapi specifications, refer to Open API Specifications
- Swagger UI can currently be accessed on
<host>/user/swagger
- You can read the description of the API.
- You can read the response codes that the API can return and their descriptions.
- You can use the API by clicking the button
Try it out
on the right upper corner. - After that, you can send JSON data.
- Here is an example Swagger UI:
pip install drf_yasg
- add
'drf_yasg',
toINSTALLED_APPS = [ ... ]
in settings.py - in
urls.py
add
schema_view = get_schema_view(
openapi.Info(
title="Your title",
default_version='your version',
description="your description",
#terms_of_service="https://www.google.com/policies/terms/",
#contact=openapi.Contact(email="[email protected]"),
#license=openapi.License(name="BSD License"),
),
public=True,
)
and path('swagger/', schema_view.with_ui('swagger', cache_timeout=0), name='schema-swagger-ui')
to urlpatterns
list.
-
- in
views.py
filefrom drf_yasg.utils import swagger_auto_schema
andfrom drf_yasg import openapi
and at the beginning of each API endpoint, add swagger_auto_schema:
- in
@swagger_auto_schema(
method='post', # whether it is post or get etc
operation_summary="your summary",
operation_description="your description.",
request_body=openapi.Schema(
type=openapi.TYPE_OBJECT,
properties={
'property1': openapi.Schema(type=openapi.TYPE_STRING),
'property2': openapi.Schema(type=openapi.TYPE_INT)
},
required=['property2']
), responses={
201: "Created",
400: "Bad Request"
},
operation_id='op_id',
)
Turquiz App
DONE
- Lab Report #1
- Lab Report #2
- Lab Report #3
- Lab Report #4
- Lab Report #5
- Lab Report #6
- Lab Report #7
- Lab Report for Lab 9
- Lab Meeting #1
- Meeting #1
- Lab Meeting #2
- Meeting #2
- Project Plan Meeting
- Frontend Meeting #1
- Lab Meeting #3
- Meeting #3
- Meeting #4
- Lab Meeting #4
- Meeting #5
- Meeting #6
- Meeting #7
- Meeting #8
- User Scenario 1 - Explore and Register
- User Scenario 2 - Search for a Quiz & Create a Quiz
- User Scenario 3 - Take & Review a Quiz
- User Scenario 4 - Search Forum & Bookmark & Upvote & Answer
- User Scenario 5 - User Badges
- User Scenario Template
- User Stories