Gestire gli errori dell'API

L'API Calendar restituisce due livelli di informazioni sugli errori:

  • Codici e messaggi di errore HTTP nell'intestazione
  • Un oggetto JSON nel corpo della risposta con ulteriori dettagli che possono aiutarti a determinare come gestire l'errore.

Il resto di questa pagina fornisce un riferimento agli errori di Calendar, con alcune indicazioni su come gestirli nella tua app.

Implementare il backoff esponenziale

La documentazione delle API Cloud fornisce una buona spiegazione del backoff esponenziale e di come utilizzarlo con le API Google.

Errori e azioni suggerite

Questa sezione fornisce la rappresentazione JSON completa di ogni errore elencato e le azioni suggerite che puoi intraprendere per gestirlo.

400: Bad Request

Errore dell'utente. Ciò può significare che non è stato fornito un parametro o un campo obbligatorio, che il valore fornito non è valido o che la combinazione di campi forniti non è valida.

{
 "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."
 }
}

Azione suggerita: poiché si tratta di un errore permanente, non riprovare. Leggi invece il messaggio di errore e modifica la richiesta di conseguenza.

401: Credenziali non valide

Intestazione di autorizzazione non valida. Il token di accesso che stai utilizzando è scaduto o non è valido.

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

Azioni suggerite:

  • Ottieni un nuovo token di accesso utilizzando il token di aggiornamento a lungo termine.
  • Se la verifica non va a buon fine, invita l'utente a seguire il flusso OAuth, come descritto in Autorizzazione delle richieste con OAuth 2.0.
  • Se vedi questo messaggio per un account di servizio, verifica di aver completato correttamente tutti i passaggi nella pagina dell'account di servizio.

403: limite di frequenza degli utenti superato

È stato raggiunto uno dei limiti di Developers Console.

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

Azioni suggerite:

403: Rate Limit Exceeded

L'utente ha raggiunto la frequenza massima di richieste dell'API Google Calendar per calendario o per utente autenticato.

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

Azione suggerita: gli errori rateLimitExceeded possono restituire codici di errore 403 o 429. Attualmente sono funzionalmente simili e devono essere gestiti allo stesso modo, utilizzando il backoff esponenziale. Inoltre, assicurati che la tua app segua le best practice per la gestione delle quote.

403: limiti di utilizzo di Calendar superati

L'utente ha raggiunto uno dei limiti di Google Calendar previsti per proteggere gli utenti e l'infrastruttura di Google da comportamenti illeciti.

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

Azioni suggerite:

403: accesso vietato per i non organizzatori

La richiesta di aggiornamento dell'evento tenta di impostare una delle proprietà dell'evento condiviso in una copia che non è dell'organizzatore. Le proprietà condivise (ad esempio guestsCanInviteOthers, guestsCanModify o guestsCanSeeOtherGuests) possono essere impostate solo dall'organizzatore.

{
 "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."
 }
}

Azioni suggerite:

  • Se utilizzi Eventi: inserisci, Eventi: importa o Eventi: aggiorna e la tua richiesta non include proprietà condivise, è equivalente a provare a impostarle sui relativi valori predefiniti. Valuta la possibilità di utilizzare Eventi: patch.
  • Se la tua richiesta contiene proprietà condivise, assicurati di provare a modificarle solo se stai aggiornando la copia dell'organizzatore.

404: Non trovata

La risorsa specificata non è stata trovata. Questo può accadere in diversi casi. Ecco alcuni esempi:

  • quando la risorsa richiesta (con l'ID fornito) non è mai esistita
  • quando si accede a un calendario a cui l'utente non può accedere

    { "error": { "errors": [ { "domain": "global", "reason": "notFound", "message": "Not Found" } ], "code": 404, "message": "Not Found" } }

Azione suggerita: utilizza il backoff esponenziale.

409: l'identificatore richiesto esiste già

Nello spazio di archiviazione esiste già un'istanza con l'ID specificato.

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

Azione suggerita: genera un nuovo ID se vuoi creare una nuova istanza, altrimenti utilizza la chiamata al metodo update.

409: conflitto

Un elemento raggruppato all'interno di un'operazione events.batch non può essere eseguito a causa di un conflitto operativo con altri elementi agglomerati richiesti.

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

Azione suggerita: escludi tutti gli elementi aggregati completati correttamente e tutti quelli con errori definitivi e riprova con quelli rimanenti in un'altra events.batch o in operazioni di singoli eventi corrispondenti.

410: Gone

I parametri syncToken o updatedMin non sono più validi. Questo errore può verificarsi anche se una richiesta tenta di eliminare un evento che è già stato eliminato.

{
 "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."
 }
}

o

{
 "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."
 }
}

o

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

Azione suggerita: per i parametri syncToken o updatedMin, resetta il magazzino e esegui nuovamente la sincronizzazione. Per maggiori dettagli, consulta Sincronizzare le risorse in modo efficiente. Per gli eventi già eliminati, non sono necessarie ulteriori azioni.

412: Precondition Failed

L'etag fornito nell'intestazione If-Match non corrisponde più all'etag corrente della risorsa.

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

Azione suggerita: recupera di nuovo l'entità e riapplica le modifiche. Per maggiori dettagli, consulta Ottenere versioni specifiche delle risorse.

429: troppe richieste

Si verifica un errore rateLimitExceeded quando l'utente ha inviato troppe richieste in un determinato periodo di tempo.

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

Azione suggerita: gli errori rateLimitExceeded possono restituire codici di errore 403 o 429. Attualmente sono funzionalmente simili e devono essere gestiti allo stesso modo, utilizzando il backoff esponenziale. Inoltre, assicurati che la tua app segua le best practice per la gestione delle quote.

500: Errore del backend

Si è verificato un errore imprevisto durante l'elaborazione della richiesta.

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

Azione suggerita: utilizza il backoff esponenziale.