Este documento describe cómo usar notificaciones push que informen a tus cuando un recurso cambia.
Descripción general
La API del Calendario de Google proporciona notificaciones push cambios en los recursos. Puedes usar esta función para mejorar el rendimiento de tu aplicación. Te permite eliminar la red adicional y el procesamiento los costos relacionados con los recursos de sondeo para determinar si cambiaron. Cada vez que un recurso supervisado cambia, la API del Calendario de Google le notifica al y mantener la integridad de su aplicación.
Para usar las notificaciones push, debes hacer dos cosas:
- Cómo configurar tu URL de recepción o "webhook" receptor de devolución de llamada. - Esta es un servidor HTTPS que controla los mensajes de notificación de la API que se que se activa cuando cambia un recurso. 
- Configura un (canal de notificación) para cada extremo de recurso que desees. reloj. - Un canal especifica la información de enrutamiento para la notificación mensajes nuevos. Como parte de la configuración del canal, debes identificar la URL específica donde quieres recibir notificaciones. Cuando cambia el recurso de un canal, la API del Calendario de Google envía un mensaje de notificación como - POSTa esa URL.
Actualmente, la API del Calendario de Google admite notificaciones de cambios en los recursos Acl, CalendarList, Eventos y Configuración.
Crea canales de notificaciones
Para solicitar notificaciones push, debes configurar un canal de notificaciones para cada recurso que quieras supervisar. Después de configurar los canales de notificaciones la API del Calendario de Google informa a tu aplicación cuando un recurso cambios.
Cómo realizar solicitudes de supervisión
Cada recurso de la API de Calendario de Google para mirar tiene un
    watch en un URI con el siguiente formato:
https://www.googleapis.com/API_NAME/API_VERSION/RESOURCE_PATH/watch
Si deseas configurar un canal de notificaciones para los mensajes sobre los cambios en una
    recurso específico, envía una solicitud POST al
    Método watch para el recurso.
Cada canal de notificaciones se asocia con un usuario en particular y
    de un recurso (o conjunto de recursos) en particular. Una solicitud watch
    no tendrá éxito, a menos que el usuario actual
    
    es propietario de este recurso o tiene permiso para acceder a él.
Ejemplo
Comienza a observar los cambios realizados en una colección de eventos de un calendario determinado:
POST https://www.googleapis.com/calendar/v3/calendars/my_calendar@gmail.com/events/watch
Authorization: Bearer auth_token_for_current_user
Content-Type: application/json
{
  "id": "01234567-89ab-cdef-0123456789ab", // Your channel ID.
  "type": "web_hook",
  "address": "https://mydomain.com/notifications", // Your receiving URL.
  ...
  "token": "target=myApp-myCalendarChannelDest", // (Optional) Your channel token.
  "expiration": 1426325213000 // (Optional) Your requested channel expiration time.
}Propiedades obligatorias
Con cada solicitud watch, debes completar estos campos:
- 
          Una cadena de propiedad idque identifica esto de forma única nuevo canal de notificaciones dentro de tu proyecto. Recomendamos usar un identificador único a nivel universal (UUID) o cualquier opción similar o una cadena única. Longitud máxima: 64 caracteres.El valor de ID que establezcas se replicará en la Encabezado HTTP X-Goog-Channel-Idde cada notificación que recibas para este canal.
- 
          Una cadena de propiedad typeconfigurada en el valorweb_hook
- 
          Una cadena de propiedad addressconfigurada en la URL que escucha y responde las notificaciones de este canal. Este es la URL de devolución de llamada del webhook que debe usar HTTPS.Ten en cuenta que la API del Calendario de Google puede enviar notificaciones a esta dirección HTTPS solo si hay instalado un certificado SSL válido en tu servidor web. Entre los certificados no válidos, se incluyen los siguientes: - Certificados autofirmados
- Certificados firmados por una fuente no confiable
- Certificados revocados
- Certificados con un asunto que no coincide con el objetivo nombre de host.
 
Propiedades opcionales
También puedes especificar estos campos opcionales con tu
      Solicitud de watch:
- 
          Una propiedad tokenque especifica una cadena arbitraria valor para usar como token del canal. Puedes usar el canal de notificaciones los tokens para varios fines. Por ejemplo, puedes usar el token para verificar que cada mensaje entrante sea para un canal al que tu para garantizar que la notificación no se envíe de identidad, o para enrutar el mensaje al destino correcto en la postulación en función del objetivo de este canal. Longitud máxima: 256 caracteres.El token se incluye en el Encabezado HTTP X-Goog-Channel-Tokenen cada notificación mensaje que tu aplicación recibe para este canal.Si usas tokens del canal de notificaciones, te recomendamos lo siguiente: - Usa un formato de codificación extensible, como una consulta de URL parámetros. Ejemplo: - forwardTo=hr&createdBy=mobile
- No incluyas datos sensibles, como tokens de OAuth. 
 
- 
            Una cadena de propiedad expirationestablecida en un Marca de tiempo Unix (en milisegundos) de la fecha y hora en que deseas que la API del Calendario de Google dejar de enviar mensajes para este canal de notificaciones.Si un canal tiene un período de vencimiento, se incluye como valor del encabezado HTTP X-Goog-Channel-Expiration(en formato legible formato) en todos los mensajes de notificación que recibe la aplicación para este canal.
Para obtener más detalles sobre la solicitud, consulta el método watch.
    para los recursos Acl, CalendarList, Eventos y Configuración en la Referencia de la API.
Mirar respuesta
Si la solicitud watch crea una notificación correctamente
      muestra un código de estado HTTP 200 OK.
El cuerpo del mensaje de la respuesta de observación proporciona información sobre el canal de notificaciones que acabas de crear, como se muestra en el siguiente ejemplo.
{
  "kind": "api#channel",
  "id": "01234567-89ab-cdef-0123456789ab"", // ID you specified for this channel.
  "resourceId": "o3hgv1538sdjfh", // ID of the watched resource.
  "resourceUri": "https://www.googleapis.com/calendar/v3/calendars/my_calendar@gmail.com/events", // Version-specific ID of the watched resource.
  "token": "target=myApp-myCalendarChannelDest", // Present only if one was provided.
  "expiration": 1426325213000, // Actual expiration time as Unix timestamp (in ms), if applicable.
}
Además de las propiedades que enviaste como parte de tu solicitud, la
      la información que se muestra también incluye resourceId y
      resourceUri para identificar el recurso que se está mirando en este
      canal de notificaciones.
Puedes pasar la información devuelta a otro canal de notificaciones operaciones, como cuando quieres dejar de recibir notificaciones.
Para obtener más detalles sobre la respuesta, consulta el watch.
      para los recursos Acl, CalendarList, Events y Settings en la Referencia de la API.
Sincronizar mensaje
Después de crear un canal de notificaciones para ver un recurso, el
      La API del Calendario de Google envía un mensaje sync para indicar que
      están empezando las notificaciones. El HTTP X-Goog-Resource-State
      el valor del encabezado para estos mensajes es sync. Debido a la red
      problemas de tiempo, es posible recibir el mensaje sync
      incluso antes de recibir la respuesta del método watch.
Puedes omitir la notificación sync, pero puedes
      que también la usan.  Por ejemplo, si decides que no quieres mantener
      el canal, puedes usar X-Goog-Channel-ID y
      valores de X-Goog-Resource-ID en una llamada a
      dejar de recibir notificaciones. También puedes usar
      sync para realizar una inicialización y prepararse
      eventos posteriores.
El formato de los mensajes de sync que envía la API del Calendario de Google
      tu URL de recepción se muestra debajo.
POST https://mydomain.com/notifications // Your receiving URL. X-Goog-Channel-ID: channel-ID-value X-Goog-Channel-Token: channel-token-value X-Goog-Channel-Expiration: expiration-date-and-time // In human-readable format. Present only if the channel expires. X-Goog-Resource-ID: identifier-for-the-watched-resource X-Goog-Resource-URI: version-specific-URI-of-the-watched-resource X-Goog-Resource-State: sync X-Goog-Message-Number: 1
Los mensajes de sincronización siempre tienen un HTTP X-Goog-Message-Number
      valor de encabezado de 1. Cada notificación posterior para este canal tiene
      un número de mensaje mayor que el anterior, aunque el mensaje
      los números no aparecerán en orden secuencial.
Renovar canales de notificaciones
Un canal de notificaciones puede tener una fecha de vencimiento, con un valor
    determinados a partir de tu solicitud o de cualquier límite interno de la API del Calendario de Google
    o valores predeterminados (se usa el valor más restrictivo).  El vencimiento del canal
    hora, si tiene una, se incluye como una marca de tiempo Unix
    (en milisegundos) en la información que muestra el método watch.  Además, el
    se incluyen la fecha y hora de vencimiento  (en un formato legible) en cada
    mensaje de notificación que recibe tu aplicación para este canal en el
    Encabezado HTTP X-Goog-Channel-Expiration.
Actualmente, no existe una manera automática de renovar un canal de notificaciones. Cuándo
    un canal está por vencer, debes reemplazarlo por uno nuevo llamando
    el método watch Como siempre, debes usar un valor único para
    la propiedad id del canal nuevo Ten en cuenta que probablemente
    como una "superposición" período en el que los dos canales de notificación del
    mismo recurso estén activos.
Recepción de notificaciones
Cada vez que cambia un recurso observado, tu aplicación recibe
  de notificación en la que se describe el cambio. La API del Calendario de Google envía estas
  como solicitudes POST HTTPS a la URL que especificaste como el
  Hay address propiedad para esta notificación
  canal.
Interpreta el formato del mensaje de notificación
Todos los mensajes de notificación incluyen un conjunto de encabezados HTTP que tienen
    X-Goog-.
    Algunos tipos de notificaciones también pueden incluir un
    cuerpo del mensaje.
Encabezados
Mensajes de notificación publicados por la API del Calendario de Google para el destinatario Las URL incluyen los siguientes encabezados HTTP:
| Encabezado | Descripción | 
|---|---|
| Siempre presente | |
|  | UUID o alguna otra cadena única que hayas proporcionado para identificarlo canal de notificaciones. | 
|  | Número entero que identifica el mensaje de esta notificación
          canal. El valor es siempre 1para los mensajes desync. Mensaje
          aumentan para cada mensaje posterior en el canal, pero son
          y no secuencial. | 
|  | Valor opaco que identifica el recurso observado. Este ID es estable entre las versiones de API. | 
|  | El nuevo estado del recurso que activó la notificación.
          Valores posibles: sync,existsonot_exists | 
|  | Un identificador específico de la versión de la API para el recurso observado. | 
| A veces está presente | |
|  | Fecha y hora de vencimiento del canal de notificación, expresadas en en un formato legible por humanos. Solo está presente si está definido. | 
|  | El token del canal de notificaciones que estableció tu aplicación. que puedes usar para verificar la fuente de notificación. Solo está presente si definido. | 
Los mensajes de notificación que publica la API de Calendario de Google en tu URL de recepción no incluyen el cuerpo del mensaje. Estos mensajes no contienen información específica sobre los recursos actualizados. Deberás realizar otra llamada a la API para ver todos los detalles de los cambios.
Ejemplos
Cambia el mensaje de notificación para una colección de eventos modificada:
POST https://mydomain.com/notifications // Your receiving URL. Content-Type: application/json; utf-8 Content-Length: 0 X-Goog-Channel-ID: 4ba78bf0-6a47-11e2-bcfd-0800200c9a66 X-Goog-Channel-Token: 398348u3tu83ut8uu38 X-Goog-Channel-Expiration: Tue, 19 Nov 2013 01:13:52 GMT X-Goog-Resource-ID: ret08u3rv24htgh289g X-Goog-Resource-URI: https://www.googleapis.com/calendar/v3/calendars/my_calendar@gmail.com/events X-Goog-Resource-State: exists X-Goog-Message-Number: 10
Responder notificaciones
Para indicar que la operación se realizó correctamente, puedes mostrar cualquiera de los siguientes códigos de estado:
    200, 201, 202, 204 o
      102 
Si tu servicio usa la biblioteca cliente de la API de Google
      y muestra 500, 502, 503 o 504, la API del Calendario de Google
      reintentos con retirada exponencial.
      Todos los demás códigos de estado de retorno se consideran como errores de mensaje.
Información sobre los eventos de notificación de la API del Calendario de Google
En esta sección, se proporcionan detalles sobre los mensajes de notificación que puedes recibir cuando uses notificaciones push con la API del Calendario de Google.
| Se entrega cuando | ||
|---|---|---|
| sync | LCA, listas de calendario, eventos y configuración. | Se creó correctamente un canal nuevo. Puedes comenzar a recibir notificaciones sobre este tema. | 
| exists | LCA, listas de calendario, eventos y configuración. | Se produjo un cambio en un recurso. Entre los posibles cambios, se incluyen la creación de un recurso nuevo o la modificación o eliminación de un recurso existente. | 
Detener notificaciones
La propiedad expiration controla cuándo se detienen automáticamente las notificaciones. Puedes
  decide dejar de recibir notificaciones de un canal en particular antes de que
  expira llamando al método stop en
  
  el siguiente URI:
https://www.googleapis.com/calendar/v3/channels/stop
Este método requiere que proporciones, al menos, el nombre de tu canal
  id y las propiedades resourceId, como se muestra en
  ejemplo a continuación. Ten en cuenta que si la API del Calendario de Google tiene varios tipos
  recursos que tienen métodos watch, solo hay uno
  stop.
Solo los usuarios que tienen el permiso adecuado pueden detener un canal. En particular:
- Si el canal se creó con una cuenta de usuario común, solo se admitirá usuario del mismo cliente (tal como lo identifican los IDs de cliente de OAuth 2.0 del tokens de autenticación) que crearon el canal pueden detenerlo.
- Si el canal se creó con una cuenta de servicio, cualquier usuario de la misma cliente puede detener el canal.
En la siguiente muestra de código, se indica cómo dejar de recibir notificaciones:
POST https://www.googleapis.com/calendar/v3/channels/stop
  
Authorization: Bearer CURRENT_USER_AUTH_TOKEN
Content-Type: application/json
{
  "id": "4ba78bf0-6a47-11e2-bcfd-0800200c9a66",
  "resourceId": "ret08u3rv24htgh289g"
}