web: use generated API Client (#616)
* api: fix types for config API * api: remove broken swagger UI * admin: re-fix system task enum * events: make event optional * events: fix Schema for notification transport test * flows: use APIView for Flow Executor * core: fix schema for Metrics APIs * web: rewrite to use generated API client * web: generate API Client in CI * admin: use x_cord and y_cord to prevent yaml issues * events: fix linting errors * web: don't lint generated code * core: fix fields not being required in TypeSerializer * flows: fix missing permission_classes * web: cleanup * web: fix rendering of graph on Overview page * web: cleanup imports * core: fix missing background image filter * flows: fix flows not advancing properly * stages/*: fix warnings during get_challenge * web: send Flow response as JSON instead of FormData * web: fix styles for horizontal tabs * web: add base chart class and custom chart for application view * root: generate ts client for e2e tests * web: don't attempt to connect to websocket in selenium tests * web: fix UserTokenList not being included in the build * web: fix styling for static token list * web: fix CSRF Token missing * stages/authenticator_static: fix error when disable static tokens * core: fix display issue when updating user info * web: fix Flow executor not showing spinner when redirecting
This commit is contained in:
		@ -2,6 +2,7 @@
 | 
			
		||||
from django.core.cache import cache
 | 
			
		||||
from django.db.models import QuerySet
 | 
			
		||||
from django.http.response import Http404
 | 
			
		||||
from drf_yasg2.utils import swagger_auto_schema
 | 
			
		||||
from guardian.shortcuts import get_objects_for_user
 | 
			
		||||
from rest_framework.decorators import action
 | 
			
		||||
from rest_framework.fields import SerializerMethodField
 | 
			
		||||
@ -13,7 +14,7 @@ from rest_framework.viewsets import ModelViewSet
 | 
			
		||||
from rest_framework_guardian.filters import ObjectPermissionsFilter
 | 
			
		||||
from structlog.stdlib import get_logger
 | 
			
		||||
 | 
			
		||||
from authentik.admin.api.metrics import get_events_per_1h
 | 
			
		||||
from authentik.admin.api.metrics import CoordinateSerializer, get_events_per_1h
 | 
			
		||||
from authentik.core.api.providers import ProviderSerializer
 | 
			
		||||
from authentik.core.models import Application
 | 
			
		||||
from authentik.events.models import EventAction
 | 
			
		||||
@ -109,6 +110,7 @@ class ApplicationViewSet(ModelViewSet):
 | 
			
		||||
        serializer = self.get_serializer(allowed_applications, many=True)
 | 
			
		||||
        return self.get_paginated_response(serializer.data)
 | 
			
		||||
 | 
			
		||||
    @swagger_auto_schema(responses={200: CoordinateSerializer(many=True)})
 | 
			
		||||
    @action(detail=True)
 | 
			
		||||
    def metrics(self, request: Request, slug: str):
 | 
			
		||||
        """Metrics for application logins"""
 | 
			
		||||
 | 
			
		||||
@ -28,9 +28,9 @@ class MetaNameSerializer(Serializer):
 | 
			
		||||
class TypeCreateSerializer(Serializer):
 | 
			
		||||
    """Types of an object that can be created"""
 | 
			
		||||
 | 
			
		||||
    name = CharField(read_only=True)
 | 
			
		||||
    description = CharField(read_only=True)
 | 
			
		||||
    link = CharField(read_only=True)
 | 
			
		||||
    name = CharField(required=True)
 | 
			
		||||
    description = CharField(required=True)
 | 
			
		||||
    link = CharField(required=True)
 | 
			
		||||
 | 
			
		||||
    def create(self, validated_data: dict) -> Model:
 | 
			
		||||
        raise NotImplementedError
 | 
			
		||||
 | 
			
		||||
@ -16,6 +16,16 @@
 | 
			
		||||
 | 
			
		||||
{% block body %}
 | 
			
		||||
<div class="pf-c-background-image">
 | 
			
		||||
    <svg xmlns="http://www.w3.org/2000/svg" class="pf-c-background-image__filter" width="0" height="0">
 | 
			
		||||
        <filter id="image_overlay">
 | 
			
		||||
            <feComponentTransfer color-interpolation-filters="sRGB" result="duotone">
 | 
			
		||||
                <feFuncR type="table" tableValues="0.0086274509803922 0.63921568627451"></feFuncR>
 | 
			
		||||
                <feFuncG type="table" tableValues="0.0086274509803922 0.63921568627451"></feFuncG>
 | 
			
		||||
                <feFuncB type="table" tableValues="0.0086274509803922 0.63921568627451"></feFuncB>
 | 
			
		||||
                <feFuncA type="table" tableValues="0 1"></feFuncA>
 | 
			
		||||
            </feComponentTransfer>
 | 
			
		||||
        </filter>
 | 
			
		||||
    </svg>
 | 
			
		||||
</div>
 | 
			
		||||
<ak-message-container></ak-message-container>
 | 
			
		||||
<div class="pf-c-login">
 | 
			
		||||
 | 
			
		||||
@ -7,6 +7,7 @@ from django.contrib.auth.mixins import (
 | 
			
		||||
)
 | 
			
		||||
from django.contrib.messages.views import SuccessMessageMixin
 | 
			
		||||
from django.http.response import HttpResponse
 | 
			
		||||
from django.urls import reverse_lazy
 | 
			
		||||
from django.utils.translation import gettext as _
 | 
			
		||||
from django.views.generic import UpdateView
 | 
			
		||||
from django.views.generic.base import TemplateView
 | 
			
		||||
@ -34,7 +35,7 @@ class UserDetailsView(SuccessMessageMixin, LoginRequiredMixin, UpdateView):
 | 
			
		||||
    form_class = UserDetailForm
 | 
			
		||||
 | 
			
		||||
    success_message = _("Successfully updated user.")
 | 
			
		||||
    success_url = "/"
 | 
			
		||||
    success_url = reverse_lazy("authentik_core:user-details")
 | 
			
		||||
 | 
			
		||||
    def get_object(self):
 | 
			
		||||
        return self.request.user
 | 
			
		||||
 | 
			
		||||
		Reference in New Issue
	
	Block a user