brotherton-erpnext/erpnext/patches/before_jan_2012/deploy_email_digest.py
2012-03-12 14:34:55 +05:30

113 lines
3.2 KiB
Python

# ERPNext - web based ERP (http://erpnext.com)
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
import webnotes
def execute():
"""
* Reload email_digest doctype
* Create default email digest
"""
from webnotes.modules import reload_doc
# Minor fix in print_format doctype
#reload_doc('core', 'doctype', 'print_format')
#reload_doc('setup', 'doctype', 'email_digest')
#global create_default_email_digest
#create_default_email_digest()
global enabled_default_email_digest
enabled_default_email_digest()
def enabled_default_email_digest():
"""
Enables the created email digest
"""
from webnotes.model.doc import Document
from webnotes.model.code import get_obj
companies_list = webnotes.conn.sql("SELECT company_name FROM `tabCompany`", as_list=1)
for company in companies_list:
if company and company[0]:
edigest = Document('Email Digest', 'Default Weekly Digest - ' + company[0])
if edigest:
edigest.enabled = 1
edigest.save()
ed_obj = get_obj(doc=edigest)
ed_obj.on_update()
def create_default_email_digest():
"""
* Weekly Digest
* For all companies
* Recipients: System Managers
* Full content
* Disabled by default
"""
from webnotes.model.doc import Document
companies_list = webnotes.conn.sql("SELECT company_name FROM `tabCompany`", as_list=1)
global get_system_managers
system_managers = get_system_managers()
for company in companies_list:
if company and company[0]:
edigest = Document('Email Digest')
edigest.name = "Default Weekly Digest - " + company[0]
edigest.company = company[0]
edigest.frequency = 'Weekly'
edigest.recipient_list = system_managers
edigest.new_leads = 1
edigest.new_enquiries = 1
edigest.new_quotations = 1
edigest.new_sales_orders = 1
edigest.new_purchase_orders = 1
edigest.new_transactions = 1
edigest.payables = 1
edigest.payments = 1
edigest.expenses_booked = 1
edigest.invoiced_amount = 1
edigest.collections = 1
edigest.income = 1
edigest.bank_balance = 1
exists = webnotes.conn.sql("""\
SELECT name FROM `tabEmail Digest`
WHERE name = %s""", edigest.name)
if (exists and exists[0]) and exists[0][0]:
continue
else:
edigest.save(1)
def get_system_managers():
"""
Returns a string of system managers' email addresses separated by \n
"""
system_managers_list = webnotes.conn.sql("""\
SELECT DISTINCT p.name
FROM tabUserRole ur, tabProfile p
WHERE
ur.parent = p.name AND
ur.role='System Manager' AND
p.docstatus<2 AND
p.enabled=1 AND
p.name not in ('Administrator', 'Guest')""", as_list=1)
return "\n".join([sysman[0] for sysman in system_managers_list])