
* remove pyright Signed-off-by: Jens Langhammer <jens@goauthentik.io> * remove pylint Signed-off-by: Jens Langhammer <jens@goauthentik.io> * replace pylint with ruff Signed-off-by: Jens Langhammer <jens@goauthentik.io> * ruff fix Signed-off-by: Marc 'risson' Schmitt <marc.schmitt@risson.space> * fix UP038 Signed-off-by: Jens Langhammer <jens@goauthentik.io> * fix DJ012 Signed-off-by: Jens Langhammer <jens@goauthentik.io> * fix default arg Signed-off-by: Jens Langhammer <jens@goauthentik.io> * fix UP031 Signed-off-by: Jens Langhammer <jens@goauthentik.io> * rename stage type to view Signed-off-by: Jens Langhammer <jens@goauthentik.io> * fix DJ008 Signed-off-by: Jens Langhammer <jens@goauthentik.io> * fix remaining upgrade Signed-off-by: Jens Langhammer <jens@goauthentik.io> * fix PLR2004 Signed-off-by: Jens Langhammer <jens@goauthentik.io> * fix B904 Signed-off-by: Jens Langhammer <jens@goauthentik.io> * fix PLW2901 Signed-off-by: Jens Langhammer <jens@goauthentik.io> * fix remaining issues Signed-off-by: Jens Langhammer <jens@goauthentik.io> * prevent ruff from breaking the code Signed-off-by: Jens Langhammer <jens@goauthentik.io> * stages/prompt: refactor field building Signed-off-by: Marc 'risson' Schmitt <marc.schmitt@risson.space> * fix tests Signed-off-by: Jens Langhammer <jens@goauthentik.io> * fix lint Signed-off-by: Jens Langhammer <jens@goauthentik.io> * fully remove isort Signed-off-by: Jens Langhammer <jens@goauthentik.io> --------- Signed-off-by: Jens Langhammer <jens@goauthentik.io> Signed-off-by: Marc 'risson' Schmitt <marc.schmitt@risson.space> Co-authored-by: Marc 'risson' Schmitt <marc.schmitt@risson.space>
34 lines
1.3 KiB
Python
34 lines
1.3 KiB
Python
"""Enterprise license policies"""
|
|
|
|
from django.utils.translation import gettext_lazy as _
|
|
|
|
from authentik.core.models import User, UserTypes
|
|
from authentik.enterprise.license import LicenseKey
|
|
from authentik.policies.types import PolicyRequest, PolicyResult
|
|
from authentik.policies.views import PolicyAccessView
|
|
|
|
|
|
class EnterprisePolicyAccessView(PolicyAccessView):
|
|
"""PolicyAccessView which also checks enterprise licensing"""
|
|
|
|
def check_license(self):
|
|
"""Check license"""
|
|
if not LicenseKey.get_total().is_valid():
|
|
return PolicyResult(False, _("Enterprise required to access this feature."))
|
|
if self.request.user.type != UserTypes.INTERNAL:
|
|
return PolicyResult(False, _("Feature only accessible for internal users."))
|
|
return PolicyResult(True)
|
|
|
|
def user_has_access(self, user: User | None = None) -> PolicyResult:
|
|
user = user or self.request.user
|
|
request = PolicyRequest(user)
|
|
request.http_request = self.request
|
|
result = super().user_has_access(user)
|
|
enterprise_result = self.check_license()
|
|
if not enterprise_result.passing:
|
|
return enterprise_result
|
|
return result
|
|
|
|
def resolve_provider_application(self):
|
|
raise NotImplementedError
|