integration azure
1.0.0
这是与Azure IoT中心的事物网络集成的示例。此集成具有在Azure Iot Hub设备注册表中创建设备以及从上行链路消息发送事件的设备。
此集成需要一个共享访问策略关键名称,并具有注册表读取和写入以及设备连接权限。在此示例中,我们使用默认情况下具有这些权限的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 ,唯一设备ID和服务器时间的结果的组合:
options . createMessage = function ( deviceId , message ) {
const metadata = {
deviceId : deviceId ,
time : message . metadata . time ,
raw : message . payload_raw
} ;
return Object . assign ( { } , message . payload_fields , metadata ) ;
}注意:如果您的有效负载功能的结果包含fields deviceId或time ,则这些字段将被元数据覆盖。使用自定义createMessage函数使用自定义字段名称。