Cómo admitir la detección de dispositivos

Se establece una ruta de entrega local cuando Google hace coincidir un dispositivo controlable de manera local con uno que se muestre en la respuesta SYNC de tu entrega en la nube.

Para permitir que Google descubra tu dispositivo en la red local y establezca la ruta de entrega local, debes agregar información de descubrimiento en la Consola de Actions. También debes actualizar la respuesta SYNC de tu entrega en la nube para informar a Google sobre el dispositivo controlable de forma local.

Cómo configurar la información de configuración de análisis

Para especificar la información de descubrimiento, sigue estos pasos:

  1. Abre tu proyecto de casa inteligente en la Consola de Actions.
  2. En el panel de navegación izquierdo, haz clic en Acciones.
  3. En Configura el SDK de la casa local (opcional) > Agregar configuración de análisis de dispositivos, haz clic en Nueva configuración de análisis.
  4. Selecciona un tipo de protocolo que coincida con el análisis del menú desplegable y, luego, ingresa valores para que Google analice.

En las siguientes tablas, se muestran los atributos que puedes agregar, según los protocolos que desees que Google use para analizar tu dispositivo:

mDNS
Atributo Descripción Example Value
Nombre del servicio Obligatorio. El nombre del servicio publicado por el dispositivo en el formato service.domain _http._tcp.local
Nombre

Obligatorio. Filtra por una instancia de servicio única en el formato instance.service.domain.

La plataforma trata este valor como una expresión regular y muestra cualquier dispositivo que coincida.
my-device-[0-9]{4}\._http\._tcp\.local
UPnP
Atributo Descripción Example Value
Tipo de servicio Obligatorio. Es un identificador completamente calificado del servicio UPnP con el formato domain:service:type:version. schemas-upnp-org:service:SwitchPower:1
OUI

Opcional. Identificador único de la organización.

Es el valor de 24 bits que identifica el fabricante del dispositivo. Por lo general, los primeros tres octetos de la dirección MAC del dispositivo.
1A:2B:3C
UDP
Atributo Descripción Example Value
Dirección de transmisión Obligatorio. Dirección IP de destino para la transmisión UDP. 255.255.255.255
Puerto de transmisión Obligatorio. Puerto de destino para la transmisión UDP. 5555
Puerto de escucha Obligatorio. Puerto de escucha para la respuesta de detección de UDP. 5556
Paquete Discovery

Obligatorio. Carga útil para enviar en la transmisión UDP.

Tiene el formato de una string de bytes con codificación hexadecimal.
48454C4C4F

Actualiza la respuesta de SYNC en la entrega en la nube

El intent SYNC informa a Asistente qué dispositivos controla el usuario y sus capacidades.

Para admitir la entrega local, la plataforma de Local Home verifica la respuesta SYNC de la entrega de Acciones de la casa inteligente y trata de hacer coincidir los ID de dispositivo del campo otherDeviceIds con el ID de verificación que muestra el controlador IDENTIFY. Las entradas de dispositivos sin un campo otherDeviceIds se excluyen de la entrega local.

En el campo otherDeviceIds de la respuesta SYNC, debes configurar los ID de dispositivos de casa inteligente que se pueden controlar de forma local. El campo aparece en el nivel device de la respuesta. Google puede establecer una ruta de entrega local en cualquier dispositivo con el ID determinado.

Usa el campo customData a fin de especificar los datos adicionales que Google necesite conectar a un dispositivo independiente o para segmentar dispositivos finales mediante un concentrador (por ejemplo, el número de puerto y otra información específica del protocolo).

Ejemplo

En el siguiente fragmento, se muestra cómo puedes crear tu controlador SYNC.

Independiente/Centro
{
  "requestId": "ff36a3cc-ec34-11e6-b1a0-64510650abcf",
  "payload": {
    "agentUserId": "1836.15267389",
    "devices": [{
      "id": "123",
      "type": "action.devices.types.OUTLET",
      "traits": [
        "action.devices.traits.OnOff"
      ],
      "name": {
        "name": "Night light"
      },
      "willReportState": false,
      "otherDeviceIds": [{
        "deviceId": "local-device-id"
      }],
      "customData": {
        "port": 5555,
        "authToken": "..."
      }
    }]
  }
}