Skip to Content
Menu
This question has been flagged
2934 Views

Hello,

I have made some code for document expiry module, that when notification date comes then the email will be triggered  till the expiry date laps. A person can stop the email notification send for any particular document by marking check on Disable Notification check box. It's working fine but fails at one place when Notification date is not come and If Expiry Date laps then for both these case mail is triggered, but it should not be happened.

Here is my code:

class Employee(models.Model):

_inherit = 'hr.employee'

document_lines_ids = fields.One2many('document.lines', 'employee_id', string='Document Lines')

@api.model

def scheduler_document_expiration(self):

employee_obj = self.env['hr.employee'].search([])

template_id = self.env['ir.model.data'].get_object_reference('document_expiry_control', 'email_template_document_expiration')[1]

template_browse = self.env['mail.template'].browse(template_id)

DATE_FORMAT = '%Y-%m-%d'

today_date = datetime.strptime(

str(datetime.today().date()), DATE_FORMAT).date()

if template_browse:

for data in employee_obj:

documents = data.document_lines_ids.filtered(lambda r: not r.disable_notification)

for lines in documents.filtered(lambda r: today_date >= datetime.strptime(

str(r.notification_from), DATE_FORMAT).date() and today_date <= datetime.strptime(

str(r.expiry_date), DATE_FORMAT).date()):

if any(documents.filtered(lambda r: today_date >= datetime.strptime(

str(r.notification_from), DATE_FORMAT).date() and today_date <= datetime.strptime(

str(r.expiry_date), DATE_FORMAT).date())):

values = template_browse.generate_email(data.id, fields=None)

mail_mail_obj = self.env['mail.mail']

msg_id = mail_mail_obj.create(values)

if msg_id:

msg_id.send()

return True

Template:

<data noupdate="1">

<record id="email_template_document_expiration" model="mail.template">

<field name="name">Document Expiration Notification</field>

<field name="email_from">abc@gmail.com</field>

<field name="subject">Document Expiration</field>

<field name="email_to">xyz@gmail.com</field>

<field name="lang">${object.lang}</field>

<field name="model_id" ref="document_expiry_control.model_hr_employee"/>

<field name="auto_delete" eval="True"/>

<field name="body_html"><![CDATA[

<div style="font-family: 'Lucica Grande', Ubuntu, Arial, Verdana, sans-serif; font-size: 12px; color: rgb(34, 34, 34); background-color: #FFF; ">

<p>Hi,</p>

% for data in object.document_lines_ids:

% if data.disable_notification == False:

<p>The ${data.document_type.name} of ${object.name} is going to expire on ${data.expiry_date}.</p>

% endif

% endfor

<p>Kindly proceed with the renewal.</P>

<p>Best Regards,</p>

</div>

]]></field>

</record>

</data>

Avatar
Discard
Related Posts Replies Views Activity
1
Jan 22
29463
1
Jun 18
15952
1
Mar 18
4476
2
Oct 23
6999
3
Oct 23
6511