İçereği Atla
Menü
Bu soru işaretlendi
1 Cevapla
14382 Görünümler

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

Avatar
Vazgeç

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.

Üretici En İyi Yanıt

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
Vazgeç

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

İlgili Gönderiler Cevaplar Görünümler Aktivite
1
Tem 25
511
5
May 25
17885
0
Nis 25
985
1
Nis 25
1414
0
Mar 25
1287