Skip to Content
Menu
This question has been flagged
1 Reply
13708 Views

How to limit the number of email to send per hour when using process email queue?

Avatar
Discard

I've the same problem. I think a cron can make this, but i don't know how. I tell you if I found or tell me if you do.

Author Best Answer

Modify the process_email_queue adding limit argument at the search method (here limit=400)

def process_email_queue(self, cr, uid, ids=None, context=None): """Send immediately queued messages, committing after each message is sent - this is not transactional and should not be called during another transaction!

       :param list ids: optional list of emails ids to send. If passed
                        no search is performed, and these ids are used
                        instead.
       :param dict context: if a 'filters' key is present in context,
                            this value will be used as an additional
                            filter to further restrict the outgoing
                            messages to send (by default all 'outgoing'
                            messages are sent).
    """
    if context is None:
        context = {}
    if not ids:
        filters = ['&', ('state', '=', 'outgoing'), ('type', '=', 'email')]
        if 'filters' in context:
            filters.extend(context['filters'])
        ids = self.search(cr, uid, filters, context=context, limit=400)
    res = None
    try:
        # Force auto-commit - this is meant to be called by
        # the scheduler, and we can't allow rolling back the status
        # of previously sent emails!
        res = self.send(cr, uid, ids, auto_commit=True, context=context)
    except Exception:
        _logger.exception("Failed processing mail queue")
    return res
Avatar
Discard

is this done directly in the code, or is it done in configuration settings?

Related Posts Replies Views Activity
2
Jul 24
607
1
May 24
1205
2
May 24
806
1
Apr 24
1387
1
Feb 24
450