Skip to content

Commit

Permalink
Implement django-rest-knox token authentication
Browse files Browse the repository at this point in the history
  • Loading branch information
nas-tabchiche committed Apr 18, 2024
1 parent 41e98dc commit c41ef28
Show file tree
Hide file tree
Showing 5 changed files with 67 additions and 15 deletions.
21 changes: 15 additions & 6 deletions backend/ciso_assistant/settings.py
Original file line number Diff line number Diff line change
Expand Up @@ -30,12 +30,12 @@

CISO_ASSISTANT_URL = os.environ.get("CISO_ASSISTANT_URL", "http://localhost:5173")


def set_ciso_assistant_url(_, __, event_dict):
event_dict["ciso_assistant_url"] = CISO_ASSISTANT_URL
return event_dict



LOGGING = {
"version": 1,
"disable_existing_loggers": False,
Expand Down Expand Up @@ -112,6 +112,14 @@ def set_ciso_assistant_url(_, __, event_dict):

PAGINATE_BY = os.environ.get("PAGINATE_BY", default=500)

AUTHENTICATION_METHOD = os.environ.get("AUTHENTICATION_METHOD", "session")

AUTHENTICATION_CLASS = {
"session": "rest_framework.authentication.SessionAuthentication",
"knox": "knox.auth.TokenAuthentication",
}

logger.info("AUTHENTICATION_METHOD: %s", AUTHENTICATION_METHOD)

# Application definition

Expand All @@ -130,6 +138,7 @@ def set_ciso_assistant_url(_, __, event_dict):
"library",
"serdes",
"rest_framework",
"knox",
"drf_spectacular",
]

Expand Down Expand Up @@ -180,7 +189,7 @@ def set_ciso_assistant_url(_, __, event_dict):
"rest_framework.renderers.JSONRenderer",
],
"DEFAULT_AUTHENTICATION_CLASSES": [
"rest_framework.authentication.SessionAuthentication",
AUTHENTICATION_CLASS[AUTHENTICATION_METHOD],
],
"DEFAULT_PERMISSION_CLASSES": [
"rest_framework.permissions.IsAuthenticated",
Expand Down Expand Up @@ -306,9 +315,9 @@ def set_ciso_assistant_url(_, __, event_dict):
]

SPECTACULAR_SETTINGS = {
'TITLE': 'CISO Assistant API',
'DESCRIPTION': 'CISO Assistant - API Documentation',
'VERSION': '1.0.0',
'SERVE_INCLUDE_SCHEMA': False,
"TITLE": "CISO Assistant API",
"DESCRIPTION": "CISO Assistant - API Documentation",
"VERSION": "1.0.0",
"SERVE_INCLUDE_SCHEMA": False,
# OTHER SETTINGS
}
22 changes: 16 additions & 6 deletions backend/ciso_assistant/urls.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,16 +14,26 @@
2. Add a URL to urlpatterns: path('blog/', include('blog.urls'))
"""
from django.urls import include, path
from ciso_assistant import settings
from drf_spectacular.views import SpectacularAPIView, SpectacularRedocView, SpectacularSwaggerView

from drf_spectacular.views import (
SpectacularAPIView,
SpectacularRedocView,
SpectacularSwaggerView,
)

# beware of the order of url patterns, this can change de behavior in case of multiple matches and avoid giving identical paths that could cause conflicts
urlpatterns = [
path("api/", include("core.urls")),
path("serdes/", include("serdes.urls")),
path("i18n/", include("django.conf.urls.i18n")),
path('api/schema/', SpectacularAPIView.as_view(), name='schema'),
path('api/schema/swagger/', SpectacularSwaggerView.as_view(url_name='schema'), name='swagger'),
path('api/schema/redoc/', SpectacularRedocView.as_view(url_name='schema'), name='redoc'),
path("api/schema/", SpectacularAPIView.as_view(), name="schema"),
path(
"api/schema/swagger/",
SpectacularSwaggerView.as_view(url_name="schema"),
name="swagger",
),
path(
"api/schema/redoc/",
SpectacularRedocView.as_view(url_name="schema"),
name="redoc",
),
]
Empty file added backend/iam/knox/__init__.py
Empty file.
16 changes: 16 additions & 0 deletions backend/iam/knox/views.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
from django.contrib.auth import login

from rest_framework import permissions
from rest_framework.authtoken.serializers import AuthTokenSerializer
from knox.views import LoginView as KnoxLoginView


class LoginView(KnoxLoginView):
permission_classes = (permissions.AllowAny,)

def post(self, request, format=None):
serializer = AuthTokenSerializer(data=request.data)
serializer.is_valid(raise_exception=True)
user = serializer.validated_data["user"]
login(request, user)
return super(LoginView, self).post(request, format=None)
23 changes: 20 additions & 3 deletions backend/iam/urls.py
Original file line number Diff line number Diff line change
@@ -1,13 +1,26 @@
from django.urls import path

from ciso_assistant.settings import AUTHENTICATION_METHOD
from core.views import FirstConnexionPasswordConfirmView

from .views import *
from .knox.views import LoginView as KnoxLoginView
import knox.views as knox_views

authentication_urls = {
"session": [
path("login/", LoginView.as_view(), name="login"),
path("logout/", LogoutView.as_view(), name="logout"),
path("current-user/", CurrentUserView.as_view(), name="current-user"),
],
"knox": [
path(r"login/", KnoxLoginView.as_view(), name="knox_login"),
path(r"logout/", knox_views.LogoutView.as_view(), name="knox_logout"),
path(r"logoutall/", knox_views.LogoutAllView.as_view(), name="knox_logoutall"),
],
}

urlpatterns = [
path("login/", LoginView.as_view(), name="login"),
path("logout/", LogoutView.as_view(), name="logout"),
path("current-user/", CurrentUserView.as_view(), name="current-user"),
path("change-password/", ChangePasswordView.as_view(), name="change-password"),
path("password-reset/", PasswordResetView.as_view(), name="password-reset"),
path(
Expand All @@ -22,3 +35,7 @@
name="first_connexion_confirm",
),
]

urlpatterns += authentication_urls[AUTHENTICATION_METHOD]

print(urlpatterns)

0 comments on commit c41ef28

Please sign in to comment.