Commit f0ee6fd3 authored by Gladys Forte's avatar Gladys Forte

save or submit initial

parent f150778f
...@@ -2,6 +2,9 @@ from app.entities import models ...@@ -2,6 +2,9 @@ from app.entities import models
from rest_framework import serializers from rest_framework import serializers
from django.db.models import Q from django.db.models import Q
from drf_writable_nested import WritableNestedModelSerializer from drf_writable_nested import WritableNestedModelSerializer
from app.applicationlayer.cms.utils_cr import (get_account_details,
get_dept_details,
get_companies_details)
class ChangeRequestFormApproversSerializer( class ChangeRequestFormApproversSerializer(
...@@ -12,13 +15,17 @@ class ChangeRequestFormApproversSerializer( ...@@ -12,13 +15,17 @@ class ChangeRequestFormApproversSerializer(
try: try:
user = instance.user user = instance.user
user_details = get_account_details(user) user_details = get_account_details(user.code)
name = user_details['name'] name = user_details.values_list('name', flat=True)[0]
group = user_details['groups'][0]['name'] dept_code = user_details.values_list('department', flat=True)[0]
company = user_details['groups'][0]['company__name'] department_details = get_dept_details(dept_code)
department = department_details.values_list('name', flat=True)[0]
comp_code = department_details.values_list('company', flat=True)[0]
company_details = get_companies_details(comp_code)
company = company_details.values_list('name', flat=True)[0]
ret['name'] = name ret['name'] = name
ret['department'] = group ret['department'] = department
ret['company'] = company ret['company'] = company
return ret return ret
...@@ -31,7 +38,7 @@ class ChangeRequestFormApproversSerializer( ...@@ -31,7 +38,7 @@ class ChangeRequestFormApproversSerializer(
class Meta: class Meta:
model = models.ChangeRequestFormApprovers model = models.ChangeRequestFormApprovers
fields = '__all__' fields = '__all__'
read_only_fields = ['created', 'archived_at', 'code'] read_only_fields = ['created', 'code']
class ChangeRequestFormStakeHoldersSerializer( class ChangeRequestFormStakeHoldersSerializer(
...@@ -40,7 +47,7 @@ class ChangeRequestFormStakeHoldersSerializer( ...@@ -40,7 +47,7 @@ class ChangeRequestFormStakeHoldersSerializer(
class Meta: class Meta:
model = models.ChangeRequestFormStakeHolders model = models.ChangeRequestFormStakeHolders
fields = '__all__' fields = '__all__'
read_only_fields = ['created', 'archived_at', 'code'] read_only_fields = ['created', 'code']
class ChangeRequestFormAttachmentsSerializer( class ChangeRequestFormAttachmentsSerializer(
...@@ -49,7 +56,7 @@ class ChangeRequestFormAttachmentsSerializer( ...@@ -49,7 +56,7 @@ class ChangeRequestFormAttachmentsSerializer(
class Meta: class Meta:
model = models.ChangeRequestFormAttachments model = models.ChangeRequestFormAttachments
fields = '__all__' fields = '__all__'
read_only_fields = ['created', 'archived_at', 'code'] read_only_fields = ['created', 'code']
class ChangeRequestFormDetailsSerializer( class ChangeRequestFormDetailsSerializer(
...@@ -58,7 +65,7 @@ class ChangeRequestFormDetailsSerializer( ...@@ -58,7 +65,7 @@ class ChangeRequestFormDetailsSerializer(
class Meta: class Meta:
model = models.ChangeRequestFormDetails model = models.ChangeRequestFormDetails
fields = '__all__' fields = '__all__'
read_only_fields = ['created', 'archived_at', 'code'] read_only_fields = ['created', 'code']
class ChangeRequestFormHeaderSerializer( class ChangeRequestFormHeaderSerializer(
...@@ -77,12 +84,10 @@ class ChangeRequestFormHeaderSerializer( ...@@ -77,12 +84,10 @@ class ChangeRequestFormHeaderSerializer(
ret = super().to_representation(instance) ret = super().to_representation(instance)
try: try:
user = self.context['request'].user user = self.context['request'].user
print(user.code)
id_number = user.code id_number = user.code
current_level = models.ChangeRequestFormApprovers.objects.filter( current_level = models.ChangeRequestFormApprovers.objects.filter(
Q(form_code=ret['form_code']) & Q(form_code=ret['form_code'])
Q(archived_at=None) &
(Q(action='') | Q(action=None)) (Q(action='') | Q(action=None))
).order_by('level') ).order_by('level')
......
...@@ -265,7 +265,6 @@ class ChangeRequestFormsViewset(meviewsets.ModelViewSet): ...@@ -265,7 +265,6 @@ class ChangeRequestFormsViewset(meviewsets.ModelViewSet):
def retrieve(self, request, *args, **kwargs): def retrieve(self, request, *args, **kwargs):
instance = self.queryset.filter( instance = self.queryset.filter(
archived_at=None,
form_code=str(self.kwargs.get('form_code')) form_code=str(self.kwargs.get('form_code'))
).first() ).first()
serializer = self.get_serializer(instance) serializer = self.get_serializer(instance)
...@@ -435,18 +434,41 @@ class ChangeRequestFormsViewset(meviewsets.ModelViewSet): ...@@ -435,18 +434,41 @@ class ChangeRequestFormsViewset(meviewsets.ModelViewSet):
# get request data # get request data
id = request.data['id'] id = request.data['id']
current_user = request.data['user'] current_user = request.data['user']
# current_user = self.request.user
form_code = request.data['form_code'] form_code = request.data['form_code']
delegation = request.data['delegation'] delegation = request.data['delegation']
action = request.data['action'] action = request.data['action']
level = request.data['level'] level = request.data['level']
next_level = int(request.data['level']) + 1 next_level = int(request.data['level']) + 1
remarks = request.data['remarks'] remarks = request.data['remarks']
# get old data
old_instance = models.ChangeRequestFormApprovers.objects.filter(
pk=id).values()
old_instance = list(old_instance)
# update current row in routing table # update current row in routing table
models.ChangeRequestFormApprovers.objects.filter( models.ChangeRequestFormApprovers.objects.filter(
pk=id).update(action=action, pk=id).update(action=action,
remarks=remarks, remarks=remarks,
action_date=datetime.now()) action_date=datetime.now())
# get new data
new_instance = models.ChangeRequestFormApprovers.objects.filter(
pk=id).values()
new_instance = list(new_instance)
crenum = action.upper()
# save history in form approver
crhistory_save(
crenum,
enums.CREntitiesEnum.CR_FRM_APPROVER.value,
form_code,
old_instance,
new_instance
)
# get details of next approver/s # get details of next approver/s
next_approver = models.ChangeRequestFormApprovers.objects.filter( next_approver = models.ChangeRequestFormApprovers.objects.filter(
...@@ -470,8 +492,7 @@ class ChangeRequestFormsViewset(meviewsets.ModelViewSet): ...@@ -470,8 +492,7 @@ class ChangeRequestFormsViewset(meviewsets.ModelViewSet):
# LOOP on next approver for sending email # LOOP on next approver for sending email
for n_approver in next_approver: for n_approver in next_approver:
print(n_approver.user.code)
if n_approver.delegation.lower() == 'vendor/implementor': if n_approver.delegation.lower() == 'vendor/implementor':
notification_msg = VENDOR_ACKNOWLEDGE_MESSAGE.split(';')[0] notification_msg = VENDOR_ACKNOWLEDGE_MESSAGE.split(';')[0]
...@@ -479,7 +500,7 @@ class ChangeRequestFormsViewset(meviewsets.ModelViewSet): ...@@ -479,7 +500,7 @@ class ChangeRequestFormsViewset(meviewsets.ModelViewSet):
n_approver.user.code, form_code, delegation, n_approver.user.code, form_code, delegation,
notification_msg notification_msg
) )
# update next approver details # update next approver details
models.ChangeRequestFormApprovers.objects.filter( models.ChangeRequestFormApprovers.objects.filter(
Q(form_code=form_code) & Q(level=str(next_level)) Q(form_code=form_code) & Q(level=str(next_level))
...@@ -489,12 +510,13 @@ class ChangeRequestFormsViewset(meviewsets.ModelViewSet): ...@@ -489,12 +510,13 @@ class ChangeRequestFormsViewset(meviewsets.ModelViewSet):
elif action.lower() == 'rejected': elif action.lower() == 'rejected':
# send email to vendor
if delegation.lower() == 'requestor': if delegation.lower() == 'requestor':
notification_msg = VENDOR_REJECT_MESSAGE.split(';')[0] notification_msg = VENDOR_REJECT_MESSAGE.split(';')[0]
send_mail_vendor( send_mail_vendor(
current_user, form_code, delegation, current_user, form_code, delegation,
requestor_notification_msg, action, notification_msg, action,
remarks, level remarks, level
) )
...@@ -511,37 +533,29 @@ class ChangeRequestFormsViewset(meviewsets.ModelViewSet): ...@@ -511,37 +533,29 @@ class ChangeRequestFormsViewset(meviewsets.ModelViewSet):
elif action.lower() == 'completed': elif action.lower() == 'completed':
models.ChangeRequestFormApprovers.objects.filter(
Q(archived_at=None) & Q(level=str(next_level))
).update(
date_sent=datetime.now().strftime('%Y-%m-%d, %H:%M:%S')
)
# EMAIL CODE FOR REQUESTOR # EMAIL CODE FOR REQUESTOR
requestor_notification_msg = REQUESTOR_COMPLETION_MESSAGE.split(';')[0] requestor_notification_msg = REQUESTOR_COMPLETION_MESSAGE.split(';')[0]
requestor_email_code = REQUESTOR_COMPLETION_MESSAGE.split(';')[1]
send_mail_requestor( send_mail_requestor(
current_user, form_code, delegation, current_user, form_code, delegation,
requestor_notification_msg, action, requestor_email_code, requestor_notification_msg, action,
remarks, level remarks, level
) )
elif action.lower() == 'acknowledged': models.ChangeRequestFormApprovers.objects.filter(
Q(level=str(next_level))
).update(
date_sent=datetime.now()
)
# models.ChangeRequestFormApprovers.objects.filter( elif action.lower() == 'acknowledged':
# level=str(next_level)
# ).update(
# date_sent=datetime.now().strftime('%Y-%m-%d, %H:%M:%S')
# )
# EMAIL CODE FOR REQUESTOR # EMAIL CODE FOR REQUESTOR
requestor_notification_msg = REQUESTOR_ACKNOWLEDGE_MESSAGE.split(';')[0] requestor_notification_msg = REQUESTOR_ACKNOWLEDGE_MESSAGE.split(';')[0]
requestor_email_code = REQUESTOR_ACKNOWLEDGE_MESSAGE.split(';')[1]
send_mail_requestor( send_mail_requestor(
current_user, form_code, delegation, current_user, form_code, delegation,
requestor_notification_msg, action, requestor_email_code, requestor_notification_msg, action,
remarks, level remarks, level
) )
...@@ -549,29 +563,50 @@ class ChangeRequestFormsViewset(meviewsets.ModelViewSet): ...@@ -549,29 +563,50 @@ class ChangeRequestFormsViewset(meviewsets.ModelViewSet):
# EMAIL CODE FOR VENDOR # EMAIL CODE FOR VENDOR
requestor_notification_msg = VENDOR_ACCEPTANCE_MESSAGE.split(';')[0] requestor_notification_msg = VENDOR_ACCEPTANCE_MESSAGE.split(';')[0]
requestor_email_code = VENDOR_ACCEPTANCE_MESSAGE.split(';')[1]
send_mail_vendor( send_mail_vendor(
current_user, form_code, delegation, current_user, form_code, delegation,
requestor_notification_msg, action, requestor_email_code, requestor_notification_msg, action,
remarks, level remarks, level
) )
# elif action.lower() == 'cancelled': elif action.lower() == 'cancelled':
# changed form status to cancelled
# action_cancelled(self, request, *args, **kwargs) models.ChangeRequestFormHeader.objects.filter(
form_code=form_code).update(status='Cancelled')
# headers = self.get_success_headers(serializer.data) return Response(
"Action performed",
status=status.HTTP_200_OK
)
# return Response( @action(
# serializer.data, status=status.HTTP_201_CREATED methods=['PATCH'], detail=True,
# ) url_path='save', url_name='save'
)
def save(self, request, *args, **kwargs):
form_code = kwargs['form_code']
return Response( return Response(
"Action performed", "Change request form successfully re routed",
status=status.HTTP_200_OK status=status.HTTP_200_OK
) )
@action(
methods=['PATCH'], detail=True,
url_path='submit', url_name='submit'
)
def submit(self, request, *args, **kwargs):
form_code = kwargs['form_code']
return Response(
"Change request form successfully re routed",
status=status.HTTP_200_OK
)
class ChangeRequestFormApproversViewset(meviewsets.ModelViewSet): class ChangeRequestFormApproversViewset(meviewsets.ModelViewSet):
...@@ -634,9 +669,7 @@ class ChangeRequestFormApproversViewset(meviewsets.ModelViewSet): ...@@ -634,9 +669,7 @@ class ChangeRequestFormApproversViewset(meviewsets.ModelViewSet):
# ) # )
def list(self, request, *args, **kwargs): def list(self, request, *args, **kwargs):
self.queryset = self.queryset.filter(archived_at=None)
self.queryset = QuerySetHelper.Sort(self) self.queryset = QuerySetHelper.Sort(self)
self.queryset = QuerySetHelper.Filter(self)
return super(ChangeRequestFormApproversViewset, self).list(request) return super(ChangeRequestFormApproversViewset, self).list(request)
def retrieve(self, request, *args, **kwargs): def retrieve(self, request, *args, **kwargs):
...@@ -841,17 +874,38 @@ class ChangeRequestFormPost(APIView): ...@@ -841,17 +874,38 @@ class ChangeRequestFormPost(APIView):
requested_to_template_id=generate_tmp) requested_to_template_id=generate_tmp)
# create template approvers # create template approvers
counter = 0
for frm_approver in frm_approvers: for frm_approver in frm_approvers:
frm_approver['form_code'] = frm_id frm_approver['form_code'] = frm_id
counter = counter + 1
data_list_approver.append(frm_approver) data_list_approver.append(frm_approver)
counter = counter + 1
vendor_data = {
'level': counter,
'delegation': 'Vendor/Implementor',
'user': form_header['requested_to_user'],
'form_code': frm_id
}
data_list_approver.append(vendor_data)
counter = counter + 1
requestor_data = {
'level': counter,
'delegation': 'Requestor',
'user': form_header['requested_by_user'],
'form_code': frm_id
}
data_list_approver.append(requestor_data)
serializerApprover = serializers.ChangeRequestFormApproversSerializer( serializerApprover = serializers.ChangeRequestFormApproversSerializer(
data=data_list_approver, many=True) data=data_list_approver, many=True)
if serializerApprover.is_valid(raise_exception=True): if serializerApprover.is_valid(raise_exception=True):
serializerApprover.save() serializerApprover.save()
# create template stakes # create template stakes
for frm_stake in frm_stakes: for frm_stake in frm_stakes:
......
...@@ -91,8 +91,6 @@ class UserList(APIView): ...@@ -91,8 +91,6 @@ class UserList(APIView):
return self.paginator.get_paginated_response(data) return self.paginator.get_paginated_response(data)
class ChangeRequestTemplatesViewset(meviewsets.ModelViewSet): class ChangeRequestTemplatesViewset(meviewsets.ModelViewSet):
queryset = models.ChangeRequestTemplateHeader.objects.all() queryset = models.ChangeRequestTemplateHeader.objects.all()
...@@ -129,7 +127,7 @@ class ChangeRequestTemplatesViewset(meviewsets.ModelViewSet): ...@@ -129,7 +127,7 @@ class ChangeRequestTemplatesViewset(meviewsets.ModelViewSet):
@transaction.atomic @transaction.atomic
def partial_update(self, request, *args, **kwargs): def partial_update(self, request, *args, **kwargs):
partial = kwargs.pop('partial', False) partial = kwargs.pop('partial', False)
instance = self.get_object() instance = self.get_object()
...@@ -141,7 +139,7 @@ class ChangeRequestTemplatesViewset(meviewsets.ModelViewSet): ...@@ -141,7 +139,7 @@ class ChangeRequestTemplatesViewset(meviewsets.ModelViewSet):
if not tmp_no_exists: if not tmp_no_exists:
serializer = self.get_serializer(instance, data=request.data, partial=partial) serializer = self.get_serializer(instance, data=request.data, partial=partial)
serializer.is_valid(raise_exception=True) serializer.is_valid(raise_exception=True)
old_instance = model_to_dict(instance) old_instance = model_to_dict(instance)
self.perform_update(serializer) self.perform_update(serializer)
new_instance = serializer.data new_instance = serializer.data
......
...@@ -88,7 +88,8 @@ class QuerySetHelper: ...@@ -88,7 +88,8 @@ class QuerySetHelper:
def ApproverStatus(status): def ApproverStatus(status):
choices = ["pending", "rejected", "approved", "completed", "cancelled", 'acknowledged', 'accepted'] choices = ["pending", "rejected", "approved", "completed", "cancelled",
'acknowledged', 'accepted']
if status not in choices: if status not in choices:
return False return False
else: else:
...@@ -110,7 +111,7 @@ def get_template_instance(form_code): ...@@ -110,7 +111,7 @@ def get_template_instance(form_code):
return template_instance return template_instance
def send_mail_vendor(current_user, def send_mail_vendor(requestor,
form_code, form_code,
delegation, delegation,
msg, msg,
...@@ -127,54 +128,59 @@ def send_mail_vendor(current_user, ...@@ -127,54 +128,59 @@ def send_mail_vendor(current_user,
requested_to_department = template_instance.requested_to_department.code requested_to_department = template_instance.requested_to_department.code
requested_by_user = template_instance.requested_by_user.code requested_by_user = template_instance.requested_by_user.code
requested_to_priority = template_instance.requested_to_priority requested_to_priority = template_instance.requested_to_priority
status = template_instance.status
vendor_instance = models.ChangeRequestFormApprovers.objects.filter( requested_to_user = template_instance.requested_to_user.code
Q(delegation="Vendor/Implementor") &
Q(form_code=form_code)
).first()
# receiver details # receiver details
vendor = get_account_details(vendor_instance.user) vendor_instance = get_account_details(requested_to_user)
requestor_name = vendor['name'] vendor_name = vendor_instance.values_list('name', flat=True)[0]
requestor_email = vendor['email'] vendor_email = vendor_instance.values_list('email', flat=True)[0]
requestor_account_id = vendor['id_number'] vendor_code = vendor_instance.values_list('code', flat=True)[0]
# sender details # sender details
sender_instance = get_account_details(current_user) sender_instance = get_account_details(requestor)
sender_account_username = sender_instance['username'] sender_name = sender_instance.values_list('name', flat=True)[0]
sender_account_id = sender_instance['id_number'] sender_code = sender_instance.values_list('code', flat=True)[0]
sender_name = sender_instance['name'] sender_email = sender_instance.values_list('email', flat=True)[0]
group = get_dept_details(requested_to_department) # department details
group_name = group['name'] department = get_dept_details(requested_to_department)
dept_name = department.values_list('name', flat=True)[0]
company = get_companies_details(requested_to_company) company = get_companies_details(requested_to_company)
company_name = company['name'] company_name = company.values_list('name', flat=True)[0]
container = receiver_body( # call sender email
sender_account_id, requestor_account_id, code,
requestor_email, app, "False", requestor_name, routing_level,
action, cr_number, template_name, company_name, group_name,
requested_to_priority, cr_link
)
if action.lower() == 'rejected': name = vendor_name
new_body = {"rejected_by": requestor_name, action_by = sender_name
"remarks": remarks} routing_level = routing_level
elif action.lower() == 'accepted': status = status
new_body = {"approved_by": requestor_name} cr_number = cr_number
cr_name = template_name
data = {**container, **new_body} company_requestedto = company_name
email_status = requests.post(EMAIL, data=data) department_requestedto = dept_name
priority_level = requested_to_priority
url = cr_link
remarks = remarks
recipient = vendor_email
action_type = action
delegation_type = delegation
admin = sender_email
args = [name, action_by, routing_level, status, cr_number, cr_name,
company_requestedto, department_requestedto, priority_level,
url, remarks, recipient, action_type, delegation_type, admin]
main_threading(args, sender.routing_table_actions)
message = f"{sender_name} {msg} ({template_name})" message = f"{sender_name} {msg} ({template_name})"
send_notification( # create notification
form_code, cr_number,
requestor_account_id, requestor_name, notification_create(form_code, message, vendor_code,
message, app, sender_code)
sender_account_id, sender_account_username
)
def send_mail_requestor(current_user, def send_mail_requestor(current_user,
...@@ -228,11 +234,12 @@ def send_mail_requestor(current_user, ...@@ -228,11 +234,12 @@ def send_mail_requestor(current_user,
recipient = requestor_email recipient = requestor_email
action_type = action action_type = action
delegation_type = delegation
admin = sender_email admin = sender_email
args = [name, action_by, routing_level, status, cr_number, cr_name, args = [name, action_by, routing_level, status, cr_number, cr_name,
company_requestedto, department_requestedto, priority_level, company_requestedto, department_requestedto, priority_level,
url, recipient, action_type, admin] url, remarks, recipient, action_type, delegation_type, admin]
main_threading(args, sender.routing_table_actions) main_threading(args, sender.routing_table_actions)
......
...@@ -21,20 +21,17 @@ def list_by_user(user_id_number): ...@@ -21,20 +21,17 @@ def list_by_user(user_id_number):
try: try:
approver = models.ChangeRequestFormApprovers.objects.filter( approver = models.ChangeRequestFormApprovers.objects.filter(
Q(user=user_id_number) & Q(user=user_id_number)
Q(archived_at=None)
) )
approver = [data.form_code for data in approver] approver = [data.form_code for data in approver]
stake = models.ChangeRequestFormStakeHolders.objects.filter( stake = models.ChangeRequestFormStakeHolders.objects.filter(
Q(user=user_id_number) & Q(user=user_id_number)
Q(archived_at=None)
) )
stake = [data.form_code for data in stake] stake = [data.form_code for data in stake]
headers = models.ChangeRequestFormHeader.objects.filter( headers = models.ChangeRequestFormHeader.objects.filter(
archived_at=None,
requested_by_user=user_id_number requested_by_user=user_id_number
) )
headers = [data.form_code for data in headers] headers = [data.form_code for data in headers]
...@@ -61,8 +58,7 @@ def list_by_user(user_id_number): ...@@ -61,8 +58,7 @@ def list_by_user(user_id_number):
form_code = list(set(stake + approver + headers)) form_code = list(set(stake + approver + headers))
return_queryset = models.ChangeRequestFormHeader.objects.filter( return_queryset = models.ChangeRequestFormHeader.objects.filter(
form_code__in=form_code, form_code__in=form_code
archived_at=None,
) )
exclude = return_queryset.filter( exclude = return_queryset.filter(
status__iexact='Draft', status__iexact='Draft',
......
...@@ -92,6 +92,12 @@ class CREnum(Enum): ...@@ -92,6 +92,12 @@ class CREnum(Enum):
RESUBMIT = "RESUBMIT" RESUBMIT = "RESUBMIT"
SUBMIT = "SUBMIT" SUBMIT = "SUBMIT"
SAVE = "SAVE" SAVE = "SAVE"
APPROVED = "APPROVED"
COMPLETED = "COMPLETED"
CANCELLED = "CANCELLED"
ACCEPTED = "ACCEPTED"
ACKNOWLEDGED = "ACKNOWLEDGED"
REJECTED = "REJECTED"
class CREntitiesEnum(Enum): class CREntitiesEnum(Enum):
......
...@@ -478,7 +478,9 @@ def admin_changepassword(args): ...@@ -478,7 +478,9 @@ def admin_changepassword(args):
# # html_message=FC # # html_message=FC
# # ) # # )
# RMS-CRAPPROVED ; RMS-CRACKNOWLEDGE ; RMS-CRCOMPLETED ; RMS-CRACCEPTED # RMS-CRAPPROVED ; RMS-CRACKNOWLEDGE ; RMS-CRCOMPLETED ; RMS-CRACCEPTED ;
# RMS-CRREJECTED ; RMS-CRREJECTED-VENDOR
def routing_table_actions(args): def routing_table_actions(args):
name = args[0] name = args[0]
action_by = args[1] action_by = args[1]
...@@ -490,92 +492,31 @@ def routing_table_actions(args): ...@@ -490,92 +492,31 @@ def routing_table_actions(args):
department_requestedto = args[7] department_requestedto = args[7]
priority_level = args[8] priority_level = args[8]
url = args[9] url = args[9]
remarks = args[10]
recipient = args[10] recipient = args[11]
action_type = args[11] action_type = args[12]
admin = args[12] delegation_type = args[13]
admin = args[14]
if action_type.lower() == 'approved': if args[12].lower() == 'approved':
email_template = 'RMS-CRAPPROVED.html' email_template = 'RMS-CRAPPROVED.html'
subject = 'Resource Management System - Change Request Approved' subject = 'Resource Management System - Change Request Approved'
elif action_type.lower() == 'acknowledged': elif args[12].lower() == 'acknowledged':
email_template = 'RMS-CRACKNOWLEDGE.html' email_template = 'RMS-CRACKNOWLEDGE.html'
subject = 'Resource Management System - Change Request Acknowledged' subject = 'Resource Management System - Change Request Acknowledged'
elif action_by.lower() == 'completed': elif args[12].lower() == 'completed':
email_template = 'RMS-CRCOMPLETED.html' email_template = 'RMS-CRCOMPLETED.html'
subject = 'Resource Management System - Change Request Completed' subject = 'Resource Management System - Change Request Completed'
elif action_type.lower() == 'accepted': elif args[12].lower() == 'accepted':
email_template = 'RMS-CRACCEPTED.html' email_template = 'RMS-CRACCEPTED.html'
subject = 'Resource Management System - Change Request Accepted' subject = 'Resource Management System - Change Request Accepted'
elif args[12].lower() == 'rejected':
F = open(os.path.join(settings.EMAIL_TEMPLATES_ROOT, email_template), 'r')
FC = F.read()
FC = FC.replace('{name}', name)
FC = FC.replace('{action_by}', action_by)
FC = FC.replace('{routing_level}', routing_level)
FC = FC.replace('{status}', status)
FC = FC.replace('{cr_number}', cr_number)
FC = FC.replace('{cr_name}', cr_name)
FC = FC.replace('{company_requestedto}', company_requestedto)
FC = FC.replace('{department_requestedto}', department_requestedto)
FC = FC.replace('{priority_level}', priority_level)
FC = FC.replace('{url}', url)
try:
send_mail(
subject=subject,
message='',
from_email=settings.EMAIL_DEFAULT_SENDER,
recipient_list=(recipient,),
html_message=FC,
fail_silently=False
)
models.EmailLogs.objects.create(
template=email_template,
recipients=recipient,
content=FC,
is_sent=True,
createdby=admin,
modifiedby=admin
)
except Exception as e:
models.EmailLogs.objects.create(
template=email_template,
recipients=recipient,
content=FC,
is_sent=False,
createdby=admin,
modifiedby=admin
)
return True
# RMS-CRREJECTED ; RMS-CRREJECTED-VENDOR
def routing_table_actions_rejected(args):
name = args[0]
action_by = args[1]
routing_level = args[2]
status = args[3]
cr_number = args[4]
cr_name = args[5]
company_requestedto = args[6]
department_requestedto = args[7]
priority_level = args[8]
url = args[9]
remarks = args[10]
recipient = args[11]
rejected_type = args[12]
admin = args[13]
if rejected_type == 'requestor':
email_template = 'RMS-CRREJECTED.html'
subject = 'Resource Management System - Change Request Rejected'
elif rejected_type == 'vendor':
email_template = 'RMS-CRREJECTED-VENDOR.html'
subject = 'Resource Management System - Change Request Rejected' subject = 'Resource Management System - Change Request Rejected'
if args[13].lower() == 'requestor':
email_template = 'RMS-CRREJECTED.html'
elif args[13].lower() == 'vendor/implementor':
email_template = 'RMS-CRREJECTED-VENDOR.html'
F = open(os.path.join(settings.EMAIL_TEMPLATES_ROOT, email_template), 'r') F = open(os.path.join(settings.EMAIL_TEMPLATES_ROOT, email_template), 'r')
...@@ -591,7 +532,9 @@ def routing_table_actions_rejected(args): ...@@ -591,7 +532,9 @@ def routing_table_actions_rejected(args):
FC = FC.replace('{department_requestedto}', department_requestedto) FC = FC.replace('{department_requestedto}', department_requestedto)
FC = FC.replace('{priority_level}', priority_level) FC = FC.replace('{priority_level}', priority_level)
FC = FC.replace('{url}', url) FC = FC.replace('{url}', url)
FC = FC.replace('{remarks}', remarks)
if args[11].lower() == 'rejected':
FC = FC.replace('{remarks}', remarks)
try: try:
send_mail( send_mail(
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment