gpt4 book ai didi

django - 内部和外部 API 的单独文档 (drf_yasg)

转载 作者:行者123 更新时间:2023-12-02 18:46:54 25 4
gpt4 key购买 nike

我有两组 API:内部 API,用于我们团队开发的客户端应用程序;外部 API,供我们的业务合作伙伴使用。我想要一个单一的文档页面,通过身份验证,向我们的开发人员显示内部 API,并向所有其他查看者显示外部 API。我怎样才能做到这一点?

我使用:Django、DRF 和 drf-yasg。

P.S:我知道这个问题很笼统,但我不知道从哪里开始。我只是猜测需要 get_schema_view、我的 View 和 URL 模式中的一些设置。

最佳答案

您可以在get_schema_view(...)函数中设置urlconf参数

from django.urls import path
from rest_framework import permissions
from drf_yasg.views import get_schema_view
from drf_yasg import openapi

schema_view_internal = get_schema_view(
openapi.Info(
title="Snippets API",
default_version='v1',
description="Test description",
),
public=True,
permission_classes=(permissions.AllowAny,),
<b>urlconf="path.to.your.internal_app.urls",</b>
)
schema_view_public = get_schema_view(
openapi.Info(
title="Snippets API",
default_version='v1',
description="Test description",
),
public=True,
permission_classes=(permissions.AllowAny,),
<b>urlconf="path.to.your.public_app.urls",</b>
)

urlpatterns = [
path(
'public/swagger/',
<b>schema_view_public</b>.with_ui('swagger', cache_timeout=0),
name='schema-swagger-ui-internal'
),
path(
'internal/swagger/',
<b>schema_view_internal</b>.with_ui('swagger', cache_timeout=0),
name='schema-swagger-ui-internal'
),
]

或者,您也可以设置 patterns 参数,该参数接受 URL 模式列表

关于django - 内部和外部 API 的单独文档 (drf_yasg),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67313801/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com