Предварительное условие иногда терпит неудачу, иногда проходит - PullRequest
0 голосов
/ 29 января 2019

Я пытаюсь получать сообщения из учетной записи Gmail.Моя проверка подлинности работает, и иногда код работает правильно и получает запрашиваемый идентификатор сообщения.Но иногда это не так.Это кажется совершенно случайным, один час работает, следующий час возвращает

"error": {
"errors": [
{
     "domain": "global",
     "reason": "failedPrecondition",
     "message": "Bad Request"
     }
 ],
    "code": 400,
    "message": "Bad Request"
 }

}

, иногда он работает правильно и отправляет идентификатор сообщения.Почему противоречивое поведение?

function getEmails(email, searchEmail) {

    Logger.log('starting getEmails');
    var emailGetSuccessfully = false;
    var service = getDomainWideDelegationService('Gmail: ', email);
    if (!service.hasAccess()) {

         Logger.log('failed to authenticate as user ' + email);
         Logger.log(service.getLastError());
         emailGetSuccessfully = service.getLastError();
         return emailGetSuccessfully;

     } else Logger.log('successfully authenticated as user ' + email);

    var requestBody                = {};
    requestBody.headers            = {'Authorization': 'Bearer ' + 
    service.getAccessToken()};
    requestBody.contentType        = "application/json";
    requestBody.method             = "GET";
    requestBody.muteHttpExceptions = true;

    var emailForUrl = encodeURIComponent(email);

    var url = 'https://www.googleapis.com/gmail/v1/users/me/messages?maxResults=1&q=to:' + searchEmail + ' OR from:' + searchEmail; //maxResults=1&
    var emailGetSuccessfully = UrlFetchApp.fetch(url, requestBody);
    var JSONemails = JSON.parse(emailGetSuccessfully);
    Logger.log(emailGetSuccessfully);
    var messages = JSONemails['messages']


    if (!messages) {return [email, "FAILED", 0, 0]; }

    var messageID = messages[0]['id'];
    var url = 'https://www.googleapis.com/gmail/v1/users/'+email+'/messages/'+messageID;
    var msgRequest = UrlFetchApp.fetch(url, requestBody);
    var msgInfo = JSON.parse(msgRequest);
    var headerInfo = msgInfo['payload']['headers'];
    var date = convertDate(msgInfo['internalDate']);
    var toFrom = toFroms(cleanJSON(headerInfo));
    var to = toFrom[0];
    var from = toFrom[1];
    var cc = toFrom[2];

    return [from, to, cc, date];
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...