邮件转发的时间驱动触发器

时间:2016-04-21 06:38:19

标签: google-apps-script gmail

我试图测试我正在处理的脚本。脚本很好,当我手动触发它时它会成功执行。当我添加每分钟间隔的时间驱动脚本时,抄写员会在几小时后开始抛出异常。

  

异常:服务在一天内被调用了太多次:gmail

我检查了每日电子邮件配额,发现我还有邮件配额

var quota = MailApp.getRemainingDailyQuota();
Logger.log(quota);

此外,我可以收到try catch电子邮件,但邮件不会被转发。

这是因为与触发器相关的执行时间配额吗?以下是代码

function MailForward() {

  try{
    var glabel = createLabel_("Mail-Forwarded");
    var rtm_email = 'abc@abc.com';
    var from_email = Session.getActiveUser().getEmail();
    var threads =  GmailApp.search('in:inbox is:unread newer_than:1d');
    var mForward = 0;

    for (var i=0;i<threads.length;i++) {

      var messages=threads[i].getMessages();
      for (var m = 0; m < messages.length; m++){
        if (messages[m].isUnread()){

        mForward = 0;  
        var mlabels = threads[i].getLabels();
        for (var j = 0; j < mlabels.length; j++) {
          Logger.log(mlabels[j].getName());

          if (mlabels[j].getName() === "Mail-Forwarded") {
          mForward = 1;  
          }
        }

        if (mForward===0) {

        //   Logger.log(messages.length)
        //   Logger.log(messages[m].getFrom());
        var from = messages[m].getFrom();

        //Logger.log(messages[m].getDate());
        var date = messages[m].getDate();

        // Logger.log(messages[m].getSubject());
        var subject = messages[m].getSubject();

        //  Logger.log(messages[m].getTo());
        var to = messages[m].getTo();

        var body = messages[m].getBody();
        var attachment = messages[m].getAttachments();

        var emailoptions = ("---------- Forwarded message ----------" +'<br>'+'From: '+from+ "<'" + from.replace(/^.+<([^>]+)>$/, "$1") +"'>"+'<br>'+ 'Date: '+date+'<br>'+ 'Subject: ' +subject+'<br>'+ 
                        'To: ' +to+ "<'" + to.replace(/^.+<([^>]+)>$/, "$1") +"'>"+'<br>'+'<br>'+'<br>');

        messages[m].forward(rtm_email,{htmlBody: emailoptions + body , Attachment: attachment});

        glabel.addToThread(threads[i]);
        Logger.log(glabel.getName());
        messages[m].markRead();

        mForward = 1;

          }
        }
      }
    }
  } catch(e) {

     MailApp.sendEmail("abc@abc.com", "Exception found in Sript", e );
      Logger.log(e);

  }
}

1 个答案:

答案 0 :(得分:1)

  1. 您使用MailApp.getRemainingDailyQuota();而不是GmailApp检查了配额。这是两种不同的服务。

  2. quota method仅返回“用户当天剩余时间可以发送的剩余电子邮件数量。”但是你要达到的限制是你为什么目的调用服务的次数。

  3. 您正在使用GmailApp来访问现有消息,而不是发送新消息。特别是,您正在检查今天每个线程中的每条消息,并且每分钟。这是很多API调用:getMessagesisUnread等等。

    减少API调用次数的一种方法是进行更有针对性的搜索。 after:搜索参数接受Unix时间戳,这使得可以执行以下操作:

    function doSomethingWithNewEmail() {
      var interval = 5;   // if the script runs every 5 minutes; change to 1 if it runs every minute
      var date = new Date();
      var timeFrom = Math.floor(date.valueOf()/1000) - 60 * interval;
      var threads = GmailApp.search('is:inbox after:' + timeFrom);
      for (var i = 0; i < threads.length; i++) {
        // do something
      }
    }
    

    我成功地使用了上述方法,间隔为5分钟。它也可以使用1分钟,因为大多数时间search将是脚本发出的唯一API调用。