package adaptors import ( "encoding/json" "fmt" "goInOut/consumers/WJHP" "log" "strconv" "time" ) // Adaptor_SJWY_WJHP 飞尚视觉位移 转换 魏家滑坡+实验室 type Adaptor_SJWY_WJHP struct { IdMap WJHP.SensorConfig } func (the Adaptor_SJWY_WJHP) Transform(topic, rawMsg string) []byte { return the.GDRDtoUpload(topic, rawMsg) } func (the Adaptor_SJWY_WJHP) GDRDtoUpload(devModule, rawRecords string) (result []byte) { log.Printf("收到模块号[%s]设备mq数据:%s", devModule, rawRecords) d := WJHP.PosData{} err := json.Unmarshal([]byte(rawRecords), &d) if err != nil { return nil } devId := fmt.Sprintf("%s-%s", devModule, d.Pos) sensorInfo := the.matchStationId(devId) if sensorInfo.StationId == 0 { return nil } rp := devToUpload(d) deviceId := strconv.Itoa(sensorInfo.StationId) upData := WJHP.UploadHistoryData{ DeviceId: deviceId, Apikey: sensorInfo.AppKey, Data: map[string]WJHP.HistoryData{ deviceId: rp, }, } result, _ = json.Marshal(upData) return result } func (the Adaptor_SJWY_WJHP) matchStationId(devId string) (sensorInfo WJHP.SensorInfo) { if v, ok := the.IdMap.SjwySensorInfo[devId]; ok { sensorInfo = v } else { log.Printf("未匹配到设备[%s]的stationId", devId) } return sensorInfo } func devToUpload(deviceData WJHP.PosData) (result WJHP.HistoryData) { k := deviceData.Timestamp.Add(time.Hour * -8).Format("2006-01-02T15:04:05.000Z") d := WJHP.HistoryData{ L1_GP_1: map[string]string{ k: fmt.Sprintf("%0.3f,%0.3f,%0.3f", deviceData.XReal, 0.0, deviceData.YReal), }, } return d }