mirror of
https://github.com/cookiecutter/cookiecutter-django.git
synced 2024-11-15 06:08:38 +03:00
721b86723c
* Adds swagger api documentation when drf is enabled Changes * Integrate drf-spectacular module * Added routes and tests for swagger-ui * Removes swagger ui tests when drf is not enabled * Changes url names and documentation title * Apply suggestions from code review Co-authored-by: Fábio C. Barrionuevo da Luz <bnafta@gmail.com> Co-authored-by: Bruno Alla <browniebroke@users.noreply.github.com> * Fixes typos and linting issues * Update domain in swagger description Co-authored-by: Fábio C. Barrionuevo da Luz <bnafta@gmail.com> Co-authored-by: Fábio C. Barrionuevo da Luz <bnafta@gmail.com> Co-authored-by: Bruno Alla <browniebroke@users.noreply.github.com>
73 lines
2.6 KiB
Python
73 lines
2.6 KiB
Python
from django.conf import settings
|
|
from django.conf.urls.static import static
|
|
from django.contrib import admin
|
|
{%- if cookiecutter.use_async == 'y' %}
|
|
from django.contrib.staticfiles.urls import staticfiles_urlpatterns
|
|
{%- endif %}
|
|
from django.urls import include, path
|
|
from django.views import defaults as default_views
|
|
from django.views.generic import TemplateView
|
|
{%- if cookiecutter.use_drf == 'y' %}
|
|
from drf_spectacular.views import SpectacularAPIView, SpectacularSwaggerView
|
|
from rest_framework.authtoken.views import obtain_auth_token
|
|
{%- endif %}
|
|
|
|
urlpatterns = [
|
|
path("", TemplateView.as_view(template_name="pages/home.html"), name="home"),
|
|
path(
|
|
"about/", TemplateView.as_view(template_name="pages/about.html"), name="about"
|
|
),
|
|
# Django Admin, use {% raw %}{% url 'admin:index' %}{% endraw %}
|
|
path(settings.ADMIN_URL, admin.site.urls),
|
|
# User management
|
|
path("users/", include("{{ cookiecutter.project_slug }}.users.urls", namespace="users")),
|
|
path("accounts/", include("allauth.urls")),
|
|
# Your stuff: custom urls includes go here
|
|
] + static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)
|
|
{%- if cookiecutter.use_async == 'y' %}
|
|
if settings.DEBUG:
|
|
# Static file serving when using Gunicorn + Uvicorn for local web socket development
|
|
urlpatterns += staticfiles_urlpatterns()
|
|
{%- endif %}
|
|
{% if cookiecutter.use_drf == 'y' %}
|
|
# API URLS
|
|
urlpatterns += [
|
|
# API base url
|
|
path("api/", include("config.api_router")),
|
|
# DRF auth token
|
|
path("auth-token/", obtain_auth_token),
|
|
path("api/schema/", SpectacularAPIView.as_view(), name="api-schema"),
|
|
path(
|
|
"api/docs/",
|
|
SpectacularSwaggerView.as_view(url_name="api-schema"),
|
|
name="api-docs",
|
|
),
|
|
]
|
|
{%- endif %}
|
|
|
|
if settings.DEBUG:
|
|
# This allows the error pages to be debugged during development, just visit
|
|
# these url in browser to see how these error pages look like.
|
|
urlpatterns += [
|
|
path(
|
|
"400/",
|
|
default_views.bad_request,
|
|
kwargs={"exception": Exception("Bad Request!")},
|
|
),
|
|
path(
|
|
"403/",
|
|
default_views.permission_denied,
|
|
kwargs={"exception": Exception("Permission Denied")},
|
|
),
|
|
path(
|
|
"404/",
|
|
default_views.page_not_found,
|
|
kwargs={"exception": Exception("Page not Found")},
|
|
),
|
|
path("500/", default_views.server_error),
|
|
]
|
|
if "debug_toolbar" in settings.INSTALLED_APPS:
|
|
import debug_toolbar
|
|
|
|
urlpatterns = [path("__debug__/", include(debug_toolbar.urls))] + urlpatterns
|