brotherton-erpnext/erpnext/patches/v4_0/apply_user_permissions.py

51 lines
2.0 KiB
Python
Raw Normal View History

# Copyright (c) 2015, Frappe Technologies Pvt. Ltd. and Contributors
2014-05-28 18:49:13 +05:30
# License: GNU General Public License v3. See license.txt
from __future__ import unicode_literals
import frappe
2014-05-29 20:07:10 +05:30
from erpnext.hr.doctype.employee.employee import EmployeeUserDisabledError
2014-05-28 18:49:13 +05:30
def execute():
update_hr_permissions()
update_permissions()
remove_duplicate_user_permissions()
frappe.clear_cache()
def update_hr_permissions():
# add set user permissions rights to HR Manager
frappe.db.sql("""update `tabDocPerm` set `set_user_permissions`=1 where parent in ('Employee', 'Leave Application')
and role='HR Manager' and permlevel=0 and `read`=1""")
2018-04-05 12:10:46 +05:30
docperm_meta = frappe.get_meta('DocPerm')
if docperm_meta.get_field('apply_user_permissions'):
# apply user permissions on Employee and Leave Application
frappe.db.sql("""update `tabDocPerm` set `apply_user_permissions`=1 where parent in ('Employee', 'Leave Application')
and role in ('Employee', 'Leave Approver') and permlevel=0 and `read`=1""")
2014-05-28 18:49:13 +05:30
frappe.clear_cache()
# save employees to run on_update events
2014-05-30 20:37:46 +05:30
for employee in frappe.db.sql_list("""select name from `tabEmployee` where docstatus < 2"""):
2014-05-29 20:07:10 +05:30
try:
2014-06-16 12:14:14 +05:30
emp = frappe.get_doc("Employee", employee)
emp.flags.ignore_mandatory = True
2014-06-16 12:14:14 +05:30
emp.save()
2014-05-29 20:07:10 +05:30
except EmployeeUserDisabledError:
pass
2014-05-28 18:49:13 +05:30
def update_permissions():
# clear match conditions other than owner
frappe.db.sql("""update tabDocPerm set `match`=''
where ifnull(`match`,'') not in ('', 'owner')""")
def remove_duplicate_user_permissions():
# remove duplicate user_permissions (if they exist)
for d in frappe.db.sql("""select parent, defkey, defvalue,
count(*) as cnt from tabDefaultValue
where parent not in ('__global', '__default')
group by parent, defkey, defvalue""", as_dict=1):
if d.cnt > 1:
# order by parenttype so that user permission does not get removed!
frappe.db.sql("""delete from tabDefaultValue where `parent`=%s and `defkey`=%s and
`defvalue`=%s order by parenttype limit %s""", (d.parent, d.defkey, d.defvalue, d.cnt-1))