Обработка ошибок API

API календаря возвращает два уровня информации об ошибках:

  • Коды ошибок HTTP и сообщения в заголовке
  • Объект JSON в теле ответа с дополнительной информацией, которая поможет вам определить, как обрабатывать ошибку.

Остальная часть этой страницы содержит справочник по ошибкам Календаря и некоторые рекомендации по их устранению в вашем приложении.

Реализовать экспоненциальную задержку

В документации по облачным API содержится хорошее объяснение экспоненциальной задержки и того, как ее использовать с API Google.

Ошибки и предлагаемые действия

В этом разделе представлено полное JSON-представление каждой из перечисленных ошибок, а также предлагаемые действия для их устранения.

400: Неверный запрос

Ошибка пользователя. Это может означать, что обязательное поле или параметр не указаны, предоставленное значение недопустимо или комбинация предоставленных полей недопустима.

{
 "error": {
  "errors": [
   {
    "domain": "calendar",
    "reason": "timeRangeEmpty",
    "message": "The specified time range is empty.",
    "locationType": "parameter",
    "location": "timeMax",
   }
  ],
  "code": 400,
  "message": "The specified time range is empty."
 }
}

Рекомендуемое действие: Поскольку это постоянная ошибка, не повторяйте попытку. Вместо этого прочитайте сообщение об ошибке и измените свой запрос соответствующим образом.

401: Недействительные учетные данные

Недопустимый заголовок авторизации. Используемый вами токен доступа либо устарел, либо недействителен.

{
 "error": {
  "errors": [
   {
    "domain": "global",
    "reason": "authError",
    "message": "Invalid Credentials",
    "locationType": "header",
    "location": "Authorization",
   }
  ],
  "code": 401,
  "message": "Invalid Credentials"
 }
}

Предлагаемые действия:

403: Превышен лимит количества пользователей

Достигнут один из лимитов Консоли разработчика.

{
 "error": {
  "errors": [
   {
    "domain": "usageLimits",
    "reason": "userRateLimitExceeded",
    "message": "User Rate Limit Exceeded"
   }
  ],
  "code": 403,
  "message": "User Rate Limit Exceeded"
 }
}

Предлагаемые действия:

403: Превышен лимит скорости

Пользователь достиг максимальной частоты запросов API Календаря Google на календарь или на одного аутентифицированного пользователя.

{
 "error": {
  "errors": [
   {
    "domain": "usageLimits",
    "reason": "rateLimitExceeded",
    "message": "Rate Limit Exceeded"
   }
  ],
  "code": 403,
  "message": "Rate Limit Exceeded"
 }
}

Рекомендуемое действие: ошибки rateLimitExceeded могут возвращать коды 403 или 429 — в настоящее время они функционально схожи и должны обрабатываться одинаково, с использованием экспоненциальной задержки . Кроме того, убедитесь, что ваше приложение соответствует рекомендациям из раздела «Управление квотами» .

403: Превышен лимит использования календаря

Пользователь достиг одного из ограничений Календаря Google, установленных для защиты пользователей и инфраструктуры Google от злоупотреблений.

{
 "error": {
  "errors": [
   {
    "domain": "usageLimits",
    "message": "Calendar usage limits exceeded.",
    "reason": "quotaExceeded"
   }
  ],
  "code": 403,
  "message": "Calendar usage limits exceeded."
 }
}

Предлагаемые действия:

403: Запрещено для неорганизаторов

Запрос на обновление события пытается установить одно из общих свойств события в копии, которая не принадлежит организатору. Общие свойства (например, guestsCanInviteOthers , guestsCanModify или guestsCanSeeOtherGuests ) могут быть установлены только организатором.

{
 "error": {
  "errors": [
   {
    "domain": "calendar",
    "reason": "forbiddenForNonOrganizer",
    "message": "Shared properties can only be changed by the organizer of the event."
   }
  ],
  "code": 403,
  "message": "Shared properties can only be changed by the organizer of the event."
 }
}

Предлагаемые действия:

  • Если вы используете Events: insert , Events: import или Events: update , и ваш запрос не содержит общих свойств, это эквивалентно попытке установить для них значения по умолчанию. Вместо этого рассмотрите возможность использования Events: patch .
  • Если ваш запрос имеет общие свойства, убедитесь, что вы пытаетесь изменить эти свойства только в том случае, если вы обновляете копию организатора.

404: Не найдено

Указанный ресурс не найден. Это может произойти в нескольких случаях. Вот несколько примеров:

  • когда запрашиваемый ресурс (с предоставленным идентификатором) никогда не существовал
  • при доступе к календарю, к которому пользователь не может получить доступ

    { "error": { "errors": [ { "domain": "global", "reason": "notFound", "message": "Не найдено" } ], "code": 404, "message": "Не найдено" } }

Предлагаемое действие: использовать экспоненциальную задержку .

409: Запрошенный идентификатор уже существует

Экземпляр с указанным идентификатором уже существует в хранилище.

{
 "error": {
  "errors": [
   {
    "domain": "global",
    "reason": "duplicate",
    "message": "The requested identifier already exists."
   }
  ],
  "code": 409,
  "message": "The requested identifier already exists."
 }
}

Предлагаемое действие: создайте новый идентификатор, если вы хотите создать новый экземпляр, в противном случае используйте вызов метода обновления .

409: Конфликт

Пакетный элемент внутри операции events.batch не может быть выполнен из-за операционного конфликта с другими запрошенными пакетными элементами.

{
 "error": {
  "errors": [
   {
    "domain": "global",
    "reason": "conflict",
    "message": "Conflict"
   }
  ],
  "code": 409,
  "message": "Conflict"
 }
}

Предлагаемое действие: исключить все успешно завершенные и все определенно невыполненные пакетные элементы и повторить оставшиеся в другом events.batch или соответствующих операциях с одним событием.

410: Ушел

Параметры syncToken или updatedMin больше недействительны. Эта ошибка также может возникнуть, если запрос пытается удалить уже удалённое событие.

{
 "error": {
  "errors": [
   {
    "domain": "calendar",
    "reason": "fullSyncRequired",
    "message": "Sync token is no longer valid, a full sync is required.",
    "locationType": "parameter",
    "location": "syncToken",
    }
  ],
  "code": 410,
  "message": "Sync token is no longer valid, a full sync is required."
 }
}

или

{
 "error": {
  "errors": [
   {
    "domain": "calendar",
    "reason": "updatedMinTooLongAgo",
    "message": "The requested minimum modification time lies too far in the past.",
    "locationType": "parameter",
    "location": "updatedMin",
   }
  ],
  "code": 410,
  "message": "The requested minimum modification time lies too far in the past."
 }
}

или

{
 "error": {
  "errors": [
   {
    "domain": "global",
    "reason": "deleted",
    "message": "Resource has been deleted"
   }
  ],
  "code": 410,
  "message": "Resource has been deleted"
 }
}

Рекомендуемое действие: для параметров syncToken или updatedMin очистите хранилище и выполните повторную синхронизацию. Подробнее см. в разделе «Эффективная синхронизация ресурсов» . Для уже удалённых событий дальнейшие действия не требуются.

412: Предварительное условие не выполнено

Тег etag, указанный в заголовке If-match, больше не соответствует текущему тегу etag ресурса.

{
 "error": {
  "errors": [
   {
    "domain": "global",
    "reason": "conditionNotMet",
    "message": "Precondition Failed",
    "locationType": "header",
    "location": "If-Match",
    }
  ],
  "code": 412,
  "message": "Precondition Failed"
 }
}

Рекомендуемое действие: повторно загрузить объект и повторно применить изменения. Подробнее см. в разделе Получение определённых версий ресурсов .

429: Слишком много запросов

Ошибка rateLimitExceeded возникает, когда пользователь отправил слишком много запросов за определенный промежуток времени.

{
  "error": {
    "errors": [
      {
        "domain": "usageLimits",
        "reason": "rateLimitExceeded",
        "message": "Rate Limit Exceeded"
      }
    ],
    "code": 429,
    "message": "Rate Limit Exceeded"
  }
}

Рекомендуемое действие: ошибки rateLimitExceeded могут возвращать коды 403 или 429 — в настоящее время они функционально схожи и должны обрабатываться одинаково, с использованием экспоненциальной задержки . Кроме того, убедитесь, что ваше приложение соответствует рекомендациям из раздела «Управление квотами» .

500: Ошибка бэкэнда

При обработке запроса произошла непредвиденная ошибка.

{
 "error": {
  "errors": [
   {
    "domain": "global",
    "reason": "backendError",
    "message": "Backend Error",
   }
  ],
  "code": 500,
  "message": "Backend Error"
 }
}

Предлагаемое действие: использовать экспоненциальную задержку .