Files
ihrm/horilla/decorators.py

84 lines
3.3 KiB
Python
Raw Normal View History

from urllib.parse import urlencode
2023-05-10 15:06:57 +05:30
from django.http import HttpResponse,HttpResponseRedirect
from django.shortcuts import redirect
from django.urls import reverse
2023-05-10 15:06:57 +05:30
from employee.models import Employee, EmployeeWorkInformation
from django.contrib import messages
decorator_with_arguments = lambda decorator: lambda *args, **kwargs: lambda func: decorator(func, *args, **kwargs)
@decorator_with_arguments
def permission_required(function, perm):
def _function(request, *args, **kwargs):
if request.user.has_perm(perm):
return function(request, *args, **kwargs)
else:
messages.info(request,'You dont have permission.')
return HttpResponseRedirect(request. META. get('HTTP_REFERER', '/'))
return _function
2023-11-17 14:30:30 +05:30
decorator_with_arguments = lambda decorator: lambda *args, **kwargs: lambda func: decorator(func, *args, **kwargs)
@decorator_with_arguments
def delete_permission(function):
def _function(request, *args, **kwargs):
if request.user.has_perm( kwargs["model"]._meta.app_label + ".delete_" + kwargs["model"]._meta.model_name):
return function(request, *args, **kwargs)
else:
messages.info(request,'You dont have permission for delete.')
return HttpResponseRedirect(request. META. get('HTTP_REFERER', '/'))
return _function
2023-05-10 15:06:57 +05:30
decorator_with_arguments = lambda decorator: lambda *args, **kwargs: lambda func: decorator(func, *args, **kwargs)
@decorator_with_arguments
def manager_can_enter(function, perm):
"""
This method is used to check permission to employee for enter to the function if the employee
do not have permission also checks, has reporting manager.
"""
def _function(request, *args, **kwargs):
user = request.user
employee = Employee.objects.filter(employee_user_id=user).first()
is_manager = EmployeeWorkInformation.objects.filter(reporting_manager_id=employee).exists()
if user.has_perm(perm) or is_manager:
return function(request, *args, **kwargs)
else:
messages.info(request,'You dont have permission.')
return HttpResponseRedirect(request. META. get('HTTP_REFERER', '/'))
return _function
def login_required(view_func):
def wrapped_view(request, *args, **kwargs):
path = request.path
res = path.split('/', 2)[1].capitalize().replace('-',' ').upper()
if res =='PMS':
res ="Performance"
2023-05-10 15:06:57 +05:30
request.session['title'] = res
if path == '' or path == '/':
request.session['title'] = 'Dashboard'.upper()
if not request.user.is_authenticated:
login_url = reverse('login')
params = urlencode(request.GET)
url = f'{login_url}?next={request.path}'
if params:
url += f'&{params}'
return redirect(url)
2023-05-10 15:06:57 +05:30
return view_func(request, *args, **kwargs)
return wrapped_view
def hx_request_required(view_func):
def wrapped_view(request, *args, **kwargs):
key = 'HTTP_HX_REQUEST'
if key not in request.META.keys():
return HttpResponse('method not allowed...')
return view_func(request, *args, **kwargs)
return wrapped_view