Cada recurso tiene un campo de versión que cambia cada vez que el recurso
cambios: el campo etag
. Las ETags son una parte estándar de HTTP y son
compatible con la API de Calendar en dos casos:
- sobre las modificaciones de los recursos para garantizar que no haya habido más operaciones de escritura en este mientras tanto (modificación condicional)
- en la recuperación de recursos para recuperar solo los datos de estos si estos cambiaron (recuperación condicional)
Modificación condicional
Si quieres actualizar o borrar un recurso solo si no ha cambiado desde
la última vez que lo recuperaste, puedes especificar un encabezado If-Match
que contenga el
valor de la ETag de la recuperación anterior. Esto es muy útil para evitar
la pérdida de modificaciones en los recursos. Los clientes tienen la opción de volver a recuperar el elemento
el recurso y volver a aplicar los cambios.
Si la entrada (y su etag) no cambió desde la última recuperación, el la modificación se realiza con éxito y la nueva versión del recurso con la nueva ETag se que se devuelven. De lo contrario, obtendrás un código de respuesta 412 (error de condición previa).
El fragmento del código de muestra que aparece a continuación demuestra cómo ejecutar reglas con el Biblioteca cliente de Java.
private static void run() throws IOException { // Create a test event. Event event = Utils.createTestEvent(client, "Test Event"); System.out.println(String.format("Event created: %s", event.getHtmlLink())); // Pause while the user modifies the event in the Calendar UI. System.out.println("Modify the event's description and hit enter to continue."); System.in.read(); // Modify the local copy of the event. event.setSummary("Updated Test Event"); // Update the event, making sure that we don't overwrite other changes. int numAttempts = 0; boolean isUpdated = false; do { Calendar.Events.Update request = client.events().update("primary", event.getId(), event); request.setRequestHeaders(new HttpHeaders().setIfMatch(event.getEtag())); try { event = request.execute(); isUpdated = true; } catch (GoogleJsonResponseException e) { if (e.getStatusCode() == 412) { // A 412 status code, "Precondition failed", indicates that the etag values didn't // match, and the event was updated on the server since we last retrieved it. Use // {@link Calendar.Events.Get} to retrieve the latest version. Event latestEvent = client.events().get("primary", event.getId()).execute(); // You may want to have more complex logic here to resolve conflicts. In this sample we're // simply overwriting the summary. latestEvent.setSummary(event.getSummary()); event = latestEvent; } else { throw e; } } numAttempts++; } while (!isUpdated && numAttempts <= MAX_UPDATE_ATTEMPTS); if (isUpdated) { System.out.println("Event updated."); } else { System.out.println(String.format("Failed to update event after %d attempts.", numAttempts)); } }
Recuperación condicional
Si quieres recuperar un recurso solo si cambió desde la última vez
puedes especificar un encabezado If-None-Match
que contenga el
valor de la ETag de la recuperación anterior. Si la entrada (y, por lo tanto, su ETag)
cambió desde la última recuperación, la nueva versión del recurso con el
se mostrará una nueva ETag. De lo contrario, recibirás un error 304 (no modificado)
de respuesta ante incidentes.
El fragmento del código de muestra que aparece a continuación demuestra cómo ejecutar reglas recuperación con el Biblioteca cliente de Java.
private static void run() throws IOException { // Create a test event. Event event = Utils.createTestEvent(client, "Test Event"); System.out.println(String.format("Event created: %s", event.getHtmlLink())); // Pause while the user modifies the event in the Calendar UI. System.out.println("Modify the event's description and hit enter to continue."); System.in.read(); // Fetch the event again if it's been modified. Calendar.Events.Get getRequest = client.events().get("primary", event.getId()); getRequest.setRequestHeaders(new HttpHeaders().setIfNoneMatch(event.getEtag())); try { event = getRequest.execute(); System.out.println("The event was modified, retrieved latest version."); } catch (GoogleJsonResponseException e) { if (e.getStatusCode() == 304) { // A 304 status code, "Not modified", indicates that the etags match, and the event has // not been modified since we last retrieved it. System.out.println("The event was not modified, using local version."); } else { throw e; } } }