Skip ke Konten
Menu
Pertanyaan ini telah diberikan tanda
1 Balas
14380 Tampilan

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

Avatar
Buang

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.

Penulis Jawaban Terbai

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
Buang

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

Post Terkait Replies Tampilan Aktivitas
1
Jul 25
508
5
Mei 25
17879
0
Apr 25
985
1
Apr 25
1413
0
Mar 25
1287