added payload formatter

This commit is contained in:
Hendrik Schutter 2024-03-24 21:12:47 +01:00
parent ec29ab24f0
commit 31a957461e

238
payload_formatter.js Normal file
View File

@ -0,0 +1,238 @@
/*
JS payload formatter for decoding VEGAPULS Air TTN payload
change the following line to run the script with 'node payload_formatter.js' for debugging
*/
const debug = false
if (debug) {
function main() {
const decoded_payload = [0x08, 0x42, 0x28, 0xF5, 0xC3, 0x01, 0x02, 0x00, 0x2A, 0x03, 0x04];
var decoded = Decoder(decoded_payload, 0x01);
console.log(decoded);
}
if (require.main === module) {
main();
}
}
function Decoder(frm_payload, f_port) {
if (debug) {
console.log(frm_payload);
}
function bytesToFloat(bytesToDecode) {
// JavaScript bitwise operators yield a 32 bits integer, not a float.
// Assume LSB (least significant byte first).
var bits = bytesToDecode[0] << 24 | bytesToDecode[1] << 16 | bytesToDecode[2] << 8 | bytesToDecode[3];
var sign = (bits >>> 31 === 0) ? 1.0 : -1.0;
var e = bits >>> 23 & 0xff;
var m = (e === 0) ? (bits & 0x7fffff) << 1 : (bits & 0x7fffff) | 0x800000;
var f = sign * m * Math.pow(2, e - 150);
return f;
}
function bytesToInt16(bytesToDecode) {
var tmpInt16 = (bytesToDecode[0] << 24 >> 16) | bytesToDecode[1];
return tmpInt16;
}
function bytesToUInt32(bytesToDecode) {
var tmpUInt32 = bytesToDecode[0] * 256 * 256 * 256 + bytesToDecode[1] * 256 * 256 + bytesToDecode[2] * 256 + bytesToDecode[3];
return tmpUInt32;
}
if (frm_payload.length < 1) {
if (debug) {
console.log("Invalid payload length");
}
return null;
}
var decoded = {};
decoded.raw_frm_payload = frm_payload;
decoded.PacketIdentifier = frm_payload[0];
switch (decoded.PacketIdentifier) {
case 8: // OKAY
decoded.Distance = bytesToFloat(frm_payload.slice(1, 5));
decoded.Unit = frm_payload[5];
decoded.RemainingPower = frm_payload[6];
decoded.Temperature = bytesToInt16(frm_payload.slice(7, 9));
decoded.UnitTemperature = frm_payload[9];
decoded.Inclination_degree = frm_payload[10];
break;
case 9: // OKAY AND GPS
decoded.Distance = bytesToFloat(frm_payload.slice(1, 5));
decoded.Unit = frm_payload[5];
decoded.RemainingPower = frm_payload[6];
decoded.GNSSLatitude = bytesToFloat(frm_payload.slice(7, 11));
decoded.GNSSLongitude = bytesToFloat(frm_payload.slice(11, 15));
decoded.Temperature = bytesToInt16(frm_payload.slice(15, 17));
decoded.UnitTemperature = frm_payload[17];
decoded.Inclination_degree = frm_payload[18];
break;
case 10: // ERROR
decoded.NamurState = frm_payload[1];
decoded.Distance = bytesToFloat(frm_payload.slice(2, 6));
decoded.Unit = frm_payload[6];
decoded.RemainingPower = frm_payload[7];
decoded.DetailState = bytesToUInt32(frm_payload.slice(8, 12));
decoded.Temperature = bytesToInt16(frm_payload.slice(12, 14));
decoded.UnitTemperature = frm_payload[14];
decoded.Inclination_degree = frm_payload[15];
break;
case 11: // ERROR AND GPS
decoded.NamurState = frm_payload[1];
decoded.Distance = bytesToFloat(frm_payload.slice(2, 6));
decoded.Unit = frm_payload[6];
decoded.RemainingPower = frm_payload[7];
decoded.GNSSLatitude = bytesToFloat(frm_payload.slice(8, 12));
decoded.GNSSLongitude = bytesToFloat(frm_payload.slice(12, 16));
decoded.DetailState = bytesToUInt32(frm_payload.slice(16, 20));
decoded.Temperature = bytesToInt16(frm_payload.slice(20, 22));
decoded.UnitTemperature = frm_payload[22];
decoded.Inclination_degree = frm_payload[23];
break;
case 12: // MEASUREMENT OKAY
decoded.Distance = bytesToFloat(frm_payload.slice(1, 5));
decoded.Unit = frm_payload[5];
decoded.MvProcent = bytesToInt16(frm_payload.slice(6, 8));
decoded.MvLinProcent = bytesToInt16(frm_payload.slice(8, 10));
decoded.MvScaled = bytesToFloat(frm_payload.slice(10, 14));
decoded.MvScaledUnit = frm_payload[14];
decoded.RemainingPower = frm_payload[15];
decoded.Temperature = bytesToInt16(frm_payload.slice(16, 18));
decoded.UnitTemperature = frm_payload[18];
decoded.Inclination_degree = frm_payload[19];
break;
case 13: // MEASUREMENT OKAY AND GPS
decoded.Distance = bytesToFloat(frm_payload.slice(1, 5));
decoded.Unit = frm_payload[5];
decoded.MvProcent = bytesToInt16(frm_payload.slice(6, 8));
decoded.MvLinProcent = bytesToInt16(frm_payload.slice(8, 10));
decoded.MvScaled = bytesToFloat(frm_payload.slice(10, 14));
decoded.MvScaledUnit = frm_payload[14];
decoded.RemainingPower = frm_payload[15];
decoded.GNSSLatitude = bytesToFloat(frm_payload.slice(16, 20));
decoded.GNSSLongitude = bytesToFloat(frm_payload.slice(20, 24));
decoded.Temperature = bytesToInt16(frm_payload.slice(24, 26));
decoded.UnitTemperature = frm_payload[26];
decoded.Inclination_degree = frm_payload[27];
break;
case 14: // MEASUREMENT ERROR
decoded.NamurState = frm_payload[1];
decoded.Distance = bytesToFloat(frm_payload.slice(2, 6));
decoded.Unit = frm_payload[6];
decoded.MvProcent = bytesToInt16(frm_payload.slice(7, 9));
decoded.MvLinProcent = bytesToInt16(frm_payload.slice(9, 11));
decoded.MvScaled = bytesToFloat(frm_payload.slice(11, 15));
decoded.MvScaledUnit = frm_payload[15];
decoded.RemainingPower = frm_payload[16];
decoded.DetailState = bytesToUInt32(frm_payload.slice(17, 21));
decoded.Temperature = bytesToInt16(frm_payload.slice(21, 23));
decoded.UnitTemperature = frm_payload[23];
decoded.Inclination_degree = frm_payload[24];
break;
case 15: // MEASUREMENT ERROR AND GPS
decoded.NamurState = frm_payload[1];
decoded.Distance = bytesToFloat(frm_payload.slice(2, 6));
decoded.Unit = frm_payload[6];
decoded.MvProcent = bytesToInt16(frm_payload.slice(7, 9));
decoded.MvLinProcent = bytesToInt16(frm_payload.slice(9, 11));
decoded.MvScaled = bytesToFloat(frm_payload.slice(11, 15));
decoded.MvScaledUnit = frm_payload[15];
decoded.RemainingPower = frm_payload[16];
decoded.GNSSLatitude = bytesToFloat(frm_payload.slice(17, 21));
decoded.GNSSLongitude = bytesToFloat(frm_payload.slice(21, 25));
decoded.DetailState = bytesToUInt32(frm_payload.slice(25, 29));
decoded.Temperature = bytesToInt16(frm_payload.slice(29, 31));
decoded.UnitTemperature = frm_payload[31];
decoded.Inclination_degree = frm_payload[32];
break;
case 16: // INFORMATION PACKAGES 1
decoded.Information = frm_payload[1];
decoded.DtmID = bytesToUInt32(frm_payload.slice(2, 6));
decoded.ManufacturerID = bytesToUInt32(frm_payload.slice(6, 10));
decoded.DeviceType = bytesToUInt32(frm_payload.slice(10, 14));
decoded.SoverSystem = frm_payload[14];
decoded.SoverFunction = frm_payload[15];
decoded.SoverError = frm_payload[16];
decoded.SoverCustomer = frm_payload[17];
decoded.MeasureAndSendIntervall = bytesToUInt32(frm_payload.slice(18, 22)) | bytesToInt16(frm_payload.slice(22, 24)) | frm_payload[24];
decoded.ChangeCounter = bytesToInt16(frm_payload.slice(25, 27));
decoded.MvScaledMin = bytesToFloat(frm_payload.slice(27, 31));
decoded.MvScaledMax = bytesToFloat(frm_payload.slice(31, 35));
break;
case 17:
decoded.DeviceName = bytesToUInt32(frm_payload.slice(1, 5)) | bytesToUInt32(frm_payload.slice(5, 9)) | bytesToUInt32(frm_payload.slice(9, 13)) |
bytesToUInt32(frm_payload.slice(13, 17)) | bytesToInt16(frm_payload.slice(17, 19)) | frm_payload[19];
decoded.DeviceTag = bytesToUInt32(frm_payload.slice(20, 24)) | bytesToUInt32(frm_payload.slice(24, 29)) | bytesToUInt32(frm_payload.slice(29, 33)) |
bytesToUInt32(frm_payload.slice(33, 37)) | bytesToInt16(frm_payload.slice(37, 39)) | frm_payload[39];
break;
case 18: // US SF10 OKAY
decoded.Distance = bytesToFloat(frm_payload.slice(1, 5));
decoded.Unit = frm_payload[5];
decoded.RemainingPower = frm_payload[6];
decoded.Temperature = bytesToInt16(frm_payload.slice(7, 9));
decoded.UnitTemperature = frm_payload[9];
decoded.Inclination_degree = frm_payload[10];
break;
case 19: // US SF10 ERROR 1
decoded.NamurState = frm_payload[1];
decoded.Distance = bytesToFloat(frm_payload.slice(2, 6));
decoded.Unit = frm_payload[6];
decoded.RemainingPower = frm_payload[7];
decoded.Inclination_degree = frm_payload[8];
break;
case 20: // US SF10 ERROR 2
decoded.NamurState = frm_payload[1];
decoded.DetailState = bytesToUInt32(frm_payload.slice(8, 12));
decoded.Temperature = bytesToInt16(frm_payload.slice(12, 14));
decoded.UnitTemperature = frm_payload[14];
break;
case 21: // US SF10 GPS 
decoded.NamurState = frm_payload[1];
decoded.GNSSLatitude = bytesToFloat(frm_payload.slice(2, 6));
decoded.GNSSLongitude = bytesToFloat(frm_payload.slice(6, 10));
break;
case 22: // US SF10 MEASUREMENT
decoded.NamurState = frm_payload[1];
decoded.MvProcent = bytesToInt16(frm_payload.slice(2, 4));
decoded.MvLinProcent = bytesToInt16(frm_payload.slice(4, 6));
decoded.MvScaled = bytesToFloat(frm_payload.slice(6, 10));
decoded.MvScaledUnit = frm_payload[10];
break;
case 23: // US SF10 INFO1
decoded.NamurState = frm_payload[1];
decoded.Information = frm_payload[2];
decoded.DtmID = bytesToUInt32(frm_payload.slice(3, 6));
decoded.ManufacturerID = bytesToUInt32(frm_payload.slice(6, 10));
break;
case 24: // US SF10 INFO2
decoded.NamurState = frm_payload[1];
decoded.DeviceType = bytesToUInt32(frm_payload.slice(2, 6));
decoded.SoverSystem = frm_payload[6];
decoded.SoverFunction = frm_payload[7];
decoded.SoverError = frm_payload[8];
decoded.SoverCustomer = frm_payload[9];
break;
case 25: // US SF10 INFO3
decoded.NamurState = frm_payload[1];
decoded.MeasureAndSendIntervall = bytesToUInt32(frm_payload.slice(2, 6)) | bytesToInt16(frm_payload.slice(6, 8)) | frm_payload[8];
decoded.ChangeCounter = bytesToInt16(frm_payload.slice(9, 11));
break;
case 26: // US SF10 INFO4
decoded.NamurState = frm_payload[1];
decoded.MvScaledMin = bytesToFloat(frm_payload.slice(2, 6));
decoded.MvScaledMax = bytesToFloat(frm_payload.slice(6, 10));
break;
default:
if (debug) {
console.log("Invalid PacketIdentifier type: " + String(decoded.PacketIdentifier));
}
decoded = null;
break;
}
return decoded;
}