Это пример интеграции сети вещей с Azure IoT Hub. Эта интеграция функционирует создание устройств в реестре устройств IoT Hub Azure, а также отправка событий из сообщений восходящей линии связи.
Эта интеграция требует имени ключа политики общего доступа с разрешением чтения и записи реестра и устройства. В этом примере мы используем политику iothubowner , которая имеет эти разрешения, включенные по умолчанию.
'use strict' ;
const ttnazureiot = require ( 'ttn-azure-iothub' ) ;
// Replace with your region, app ID and access key
const region = '<insert region>' ;
const appId = '<insert app ID>' ;
const accessKey = '<insert access key>' ;
// Replace with your Azure IoT Hub name, key name and key
const hubName = '<insert hub name>' ;
const keyName = 'iothubowner' ;
const key = '<insert key>' ;
const bridge = new ttnazureiot . Bridge ( region , appId , accessKey , hubName , keyName , key ) ;
bridge . on ( 'ttn-connect' , ( ) => {
console . log ( 'TTN connected' ) ;
} ) ;
bridge . on ( 'error' , err => {
console . warn ( 'Error' , err ) ;
} ) ;
bridge . on ( 'message' , data => {
console . log ( 'Message' , data ) ;
} ) ; При создании и инициализации Bridge вы можете указать параметры:
const options = { } ;
const bridge = new ttnazureiot . Bridge ( region , appID , accessKey , hubName , keyName , key , options ) ;createMessage Функция для создания сообщения. По умолчанию сообщение представляет собой комбинацию результата fields функций полезной нагрузки, уникального идентификатора устройства и времени сервера:
options . createMessage = function ( deviceId , message ) {
const metadata = {
deviceId : deviceId ,
time : message . metadata . time ,
raw : message . payload_raw
} ;
return Object . assign ( { } , message . payload_fields , metadata ) ;
} ПРИМЕЧАНИЕ. Если результат ваших функций полезной нагрузки содержит deviceId Fields или time , эти поля будут перезаписаны метаданными. Используйте пользовательскую функцию createMessage , чтобы использовать пользовательские имена поля.