Topflytech protocol

Protocol used by GPS tracking devices manufactured by Topflytech headquartered in China.
flespi parses the Topflytech protocol messages into a JSON object with the fields listed below in the Parameters tab.

Step-by-step guide on how-to obtain telematics data from Topflytech devices via API.

To connect your tracker using the Topflytech protocol, you need to have a topflytech channel created first.

Point your tracker to the channel's domain name:port via SMS or configuration tool provided by the vendor.

Then create a device instance for your tracker and use a 15-character IMEI (usually specified on the tracker casing) in the ident field.

Use the Logs & Messages tab on the device screen to check if the messages are coming.

accident.event
boolean
Accident event detected
Message Type 0x07
ain
number
volts
Voltage on the analog input
Message Type 0x02,
Message Type 0x04,
Message Type 0x13,
Message Type 0x14
alarm.event
boolean
Alarm event triggered
Alarm Code 3,
Alarm Type 3,
Message Type 0x10,
Message Type 0x12
alarm.time
number
seconds
Accumulated time of the specific alarm
Message Type 0x13,
Message Type 0x14
antitheft.event
boolean
Antitheft event triggered
Alarm Type 10
average.fuel.consumption
number
liters/100km
Average fuel consumption
Message Type 0x02,
Message Type 0x04
battery.level
number
percentage
Internal battery level
Message Type 0x02,
Message Type 0x04,
Message Type 0x13,
Message Type 0x14
battery.low.status
boolean
Battery low status
Alarm Code 6,
Alarm Code 7,
Alarm Type 2,
Alarm Type 24
battery.voltage
number
volts
Internal battery voltage
Message Type 0x02,
Message Type 0x13,
Message Type 0x14
ble.beacons
array
Array with all detected BLE beacons data objects. Each object contain list of associated parameters sent by appropriate beacon. Standard parameter names used: *id* - beacon identification string. Usually it is beacon's UUID or MAC-address *local_name* - Beacons's Local Name *rssi* - BLE signal level. Units = dBm *battery.voltage* - Beacon's battery voltage. Units = volts *battery.level* - Beacon's battery level. Units = percentage *temperature* - Beacon's temperature. Units = celsius
Message Type 0x10,
Message Type 0x12
box.status
boolean
Box status (true - box is opened, false - box is closed)
Alarm Code 23,
Alarm Code 4
can.dtc
array
Diagnostic trouble code array read from CAN
Message Type 0x09
can.dtc.state
number
DTC state: 1 - confirmed error, 2 - con confirmed error (error probably is, may disappear or happen again)
Message Type 0x09
can.engine.coolant.temperature
number
celsius
Engine coolant temperature read from CAN
Message Type 0x02,
Message Type 0x04,
Message Type 0x13,
Message Type 0x14
can.engine.load.level
number
percentage
Calculated engine load level read from CAN
Message Type 0x02,
Message Type 0x04,
Message Type 0x13,
Message Type 0x14
can.engine.rpm
number
rpm
Engine RPM read from CAN
Message Type 0x02,
Message Type 0x04,
Message Type 0x05,
Message Type 0x06,
Message Type 0x07
can.fuel.consumed
number
liters
Fuel volume totally consumed by vehicle read from CAN
Message Type 0x13,
Message Type 0x14
can.fuel.level
number
percentage
Fuel level in tank read from CAN
Message Type 0x02,
Message Type 0x04,
Message Type 0x13,
Message Type 0x14
can.fuel.volume
number
liters
CAN fuel volume
Message Type 0x02,
Message Type 0x04
can.intake.air.temperature
number
celsius
Intake air temperature
Message Type 0x02,
Message Type 0x04
can.intake.map
number
kPa
Intake manifold absolute pressure
Message Type 0x02,
Message Type 0x04
can.maf.air.flow.rate
number
g/sec
MAF air flow rate read from CAN
Message Type 0x02,
Message Type 0x04
can.throttle.pedal.level
number
percentage
Throttle pedal push level read from CAN
Message Type 0x02,
Message Type 0x04
can.vehicle.speed
number
km/h
Vehicle speed read from CAN
Message Type 0x13,
Message Type 0x14
case.status
boolean
Case opened status
Alarm Code 2,
Alarm Code 22
channel.id
number
ID of channel that received a message
crash.status
boolean
Crash event status: true - collision detected, false - collision stopped
Alarm Code 10,
Alarm Code 27
device.id
number
ID of device that received a message
device.name
string
Name of device that received a message
device.temperature
number
celsius
Temperature of device
Message Type 0x02,
Message Type 0x13,
Message Type 0x14
device.temperature.high.status
boolean
Device temperature high status: true - device temperature is higher than predefined threshold, false - device temperature is in normal range
Alarm Code 25,
Alarm Code 8
device.temperature.low.status
boolean
Device temperature low status: true - device temperature is lower than predefined threshold, false - device temperature is in normal range
Alarm Code 30,
Alarm Code 31
device.type.id
number
ID of device type of device that received a message
din
number
Digital inputs bitmask
Message Type 0x02,
Message Type 0x04,
Message Type 0x13,
Message Type 0x14
displacement.status
boolean
Device displacement status: true - device removed, false - device mounted (triggered by back light sensor)
Alarm Code 1,
Alarm Code 21
dout
number
Digital outputs bitmask
Message Type 0x13
driver.id
string
Driver identification card id
Message Type 0x10,
Message Type 0x12
engine.blocked.status
boolean
Engine blocked status (fuel cutoff relay), true - engine is blocked, false - engine isn't blocked
Message Type 0x02,
Message Type 0x13,
Message Type 0x14
engine.ignition.status
boolean
Engine ignition or ACC status
Alarm Code 16,
Alarm Code 17,
Bit14 of Digital I/O status,
Bit2 of Status,
Message Type 0x02,
Message Type 0x04,
Message Type 0x10,
Message Type 0x12,
Message Type 0x13,
Message Type 0x14,
Message Type 0x21,
Message Type 0x23
engine.rpm
number
rpm
Engine RPM read
Message Type 0x13,
Message Type 0x14
event.code
string
Protocol-specific event code string
Message Type 0x09
event.enum
number
Protocol-specific event code
Message Type 0x04,
Message Type 0x13,
Message Type 0x14,
Message Type 0x24,
Message Type 0x25
external.powersource.status
boolean
External power source connection status
Alarm Type 1,
Message Type 0x02,
Message Type 0x04,
Message Type 0x13,
Message Type 0x14
external.powersource.voltage
number
volts
External power voltage
Message Type 0x02,
Message Type 0x04,
Message Type 0x13,
Message Type 0x14
fall.status
boolean
Device fall status: true - device is falling, false - falling stopped
Alarm Code 24,
Alarm Code 5
fuel.consumed
number
liters
Fuel volume totally consumed by vehicle
Message Type 0x02,
Message Type 0x04
geofence.status
boolean
Geofence entered status
Alarm Code 14,
Alarm Code 15,
Alarm Type 5,
Alarm Type 6
gnss.status
boolean
GNSS receiver on/off status
Message Type 0x02,
Message Type 0x04,
Message Type 0x06,
Message Type 0x07,
Message Type 0x10,
Message Type 0x12,
Message Type 0x13,
Message Type 0x14,
Message Type 0x17,
Message Type 0x24,
Message Type 0x25
gsm.cellid
number
Mobile network (GSM, 3G, 4G, LTE, 5G, ...) base station ID
Message Type 0x02,
Message Type 0x04,
Message Type 0x06,
Message Type 0x07,
Message Type 0x10,
Message Type 0x12,
Message Type 0x13,
Message Type 0x14,
Message Type 0x17,
Message Type 0x24,
Message Type 0x25
gsm.jamming.event
boolean
Mobile network (GSM, 3G, 4G, LTE, 5G, ...) signal jamming detected
Alarm Type 21,
Alarm Type 22
gsm.lac
number
Mobile network (GSM, 3G, 4G, LTE, 5G, ...) location area code
Message Type 0x02,
Message Type 0x04,
Message Type 0x06,
Message Type 0x07,
Message Type 0x10,
Message Type 0x12,
Message Type 0x13,
Message Type 0x14,
Message Type 0x17,
Message Type 0x24,
Message Type 0x25
gsm.mcc
number
Mobile network (GSM, 3G, 4G, LTE, 5G, ...) country code
Message Type 0x02,
Message Type 0x04,
Message Type 0x06,
Message Type 0x07,
Message Type 0x10,
Message Type 0x12,
Message Type 0x13,
Message Type 0x14,
Message Type 0x17,
Message Type 0x24,
Message Type 0x25
gsm.mnc
number
Mobile network (GSM, 3G, 4G, LTE, 5G, ...) code
Message Type 0x02,
Message Type 0x04,
Message Type 0x06,
Message Type 0x07,
Message Type 0x10,
Message Type 0x12,
Message Type 0x13,
Message Type 0x14,
Message Type 0x17,
Message Type 0x24,
Message Type 0x25
gsm.network.name
string
Mobile network (GSM, 3G, 4G, LTE, 5G, ...) operator name
Message Type 0x05,
Message Type 0x11
gsm.pcid
number
Physical layer Cell ID in the Mobile network (LTE and NR)
Message Type 0x02,
Message Type 0x04,
Message Type 0x06,
Message Type 0x07,
Message Type 0x10,
Message Type 0x12,
Message Type 0x13,
Message Type 0x14,
Message Type 0x17,
Message Type 0x24,
Message Type 0x25
gsm.signal.level
number
percentage
Mobile network (GSM, 3G, 4G, LTE, 5G, ...) signal strength level
Message Type 0x02,
Message Type 0x04,
Message Type 0x13,
Message Type 0x14
gsm.sim.iccid
string
Integrated Circuit Card Id of SIM card of the Mobile network (GSM, 3G, 4G, LTE, 5G, ...)
Message Type 0x05,
Message Type 0x11
gsm.sim.imsi
string
IMSI of SIM card of the Mobile network (GSM, 3G, 4G, LTE, 5G, ...)
Message Type 0x05,
Message Type 0x11
harsh.acceleration.event
boolean
Harsh acceleration detected
Message Type 0x05,
Message Type 0x06
harsh.braking.event
boolean
Harsh braking detected
Message Type 0x05,
Message Type 0x06
harsh.cornering.event
boolean
Harsh cornering detected
Message Type 0x06
ident
string
Device unique identifier like serial number, IMEI, etc
idle.status
boolean
Vehicle is in idling state
Alarm Code 18,
Alarm Code 19,
Alarm Type 19,
Alarm Type 20
light.sensor.voltage
number
volts
Front light sensor voltage
Message Type 0x02
lock.data
string
Lock data in HEX format
Message Type 0x17
lock.state
number
Numeric value of a lock status
Message Type 0x17
message.buffered.status
boolean
Black box message
Message Type 0x02,
Message Type 0x04,
Message Type 0x06,
Message Type 0x07,
Message Type 0x10,
Message Type 0x12,
Message Type 0x13,
Message Type 0x14,
Message Type 0x17,
Message Type 0x24,
Message Type 0x25
message.type
string
Message type
Message Type 0x02,
Message Type 0x04,
Message Type 0x06,
Message Type 0x07,
Message Type 0x10,
Message Type 0x12,
Message Type 0x13,
Message Type 0x14,
Message Type 0x17
movement.distance
number
meters
Distance since last Location or Alarm data on Ignition On state
Message Type 0x13
movement.event
boolean
Movement detected
Alarm Type 8
movement.status
boolean
Current movement state
Message Type 0x02
onewire.payload.hex
string
OneWire HEX payload received from device
Message Type 0x23
onewire.sensor.serial
string
External 1-Wire sensor serial number in HEX representation
Message Type 0x23
overspeeding.event
boolean
Overspeeding detected
Alarm Type 4,
Message Type 0x05
payload.text
string
Text Payload received from device
Message Type 0x81
peer
string
IP:port from which device connecting to the channel
position.altitude
number
meters
Altitude value for position
Message Type 0x02,
Message Type 0x04,
Message Type 0x05,
Message Type 0x06,
Message Type 0x07,
Message Type 0x10,
Message Type 0x12,
Message Type 0x13,
Message Type 0x14,
Message Type 0x17,
Message Type 0x24,
Message Type 0x25
position.direction
number
degrees
Heading angle at position detection moment
Message Type 0x02,
Message Type 0x04,
Message Type 0x05,
Message Type 0x06,
Message Type 0x07,
Message Type 0x10,
Message Type 0x12,
Message Type 0x13,
Message Type 0x14,
Message Type 0x17,
Message Type 0x24,
Message Type 0x25
position.hdop
number
Horizontal dilution of precision
Message Type 0x13,
Message Type 0x14,
Message Type 0x24,
Message Type 0x25
position.latitude
number
degrees
Latitude coordinate value
Message Type 0x02,
Message Type 0x04,
Message Type 0x05,
Message Type 0x06,
Message Type 0x07,
Message Type 0x10,
Message Type 0x12,
Message Type 0x13,
Message Type 0x14,
Message Type 0x17,
Message Type 0x24,
Message Type 0x25
position.longitude
number
degrees
Longitude coordinate value
Message Type 0x02,
Message Type 0x04,
Message Type 0x05,
Message Type 0x06,
Message Type 0x07,
Message Type 0x10,
Message Type 0x12,
Message Type 0x13,
Message Type 0x14,
Message Type 0x17,
Message Type 0x24,
Message Type 0x25
position.satellites
number
Quantity of satellites used to calculate coordinates for given position information
Message Type 0x02,
Message Type 0x04,
Message Type 0x06,
Message Type 0x07,
Message Type 0x10,
Message Type 0x12,
Message Type 0x13,
Message Type 0x14,
Message Type 0x17,
Message Type 0x24,
Message Type 0x25
position.speed
number
km/h
Instant speed at position detection moment
Message Type 0x02,
Message Type 0x04,
Message Type 0x05,
Message Type 0x06,
Message Type 0x07,
Message Type 0x10,
Message Type 0x12,
Message Type 0x13,
Message Type 0x14,
Message Type 0x17,
Message Type 0x24,
Message Type 0x25
position.valid
boolean
Is position information accurate and valid for given timestamp
Message Type 0x02,
Message Type 0x04,
Message Type 0x05,
Message Type 0x06,
Message Type 0x07,
Message Type 0x10,
Message Type 0x12,
Message Type 0x13,
Message Type 0x14,
Message Type 0x17,
Message Type 0x24,
Message Type 0x25
power.on.status
boolean
Power-on device status
Alarm Code 20,
Alarm Code 29
protocol.id
number
ID of protocol
report.reason
number
Transmission reason code
rs485.device.id
number
ID of device connected to RS-485
Message Type 0x21
rs485.payload.hex
string
RS485 HEX payload received from device
Message Type 0x21
server.timestamp
number
seconds
Timestamp when server received a message
solar.panel.charging.status
boolean
Solar panel charging device
Message Type 0x02
solar.panel.voltage
number
volts
Solar panel voltage
Message Type 0x02
tilt.status
boolean
Device tilt status (true - device is tilted, false - device is in normal position)
Alarm Code 11,
Alarm Code 28
timestamp
number
seconds
Message timestamp
Message Type 0x02,
Message Type 0x04,
Message Type 0x05,
Message Type 0x06,
Message Type 0x07,
Message Type 0x09,
Message Type 0x10,
Message Type 0x11,
Message Type 0x12,
Message Type 0x13,
Message Type 0x14,
Message Type 0x15,
Message Type 0x17,
Message Type 0x21,
Message Type 0x22,
Message Type 0x23,
Message Type 0x24,
Message Type 0x25
time.valid.status
boolean
Time is accurate
Message Type 0x02,
Message Type 0x04,
Message Type 0x05,
Message Type 0x06,
Message Type 0x07,
Message Type 0x09,
Message Type 0x10,
Message Type 0x11,
Message Type 0x12,
Message Type 0x13,
Message Type 0x14,
Message Type 0x15,
Message Type 0x17,
Message Type 0x21,
Message Type 0x22,
Message Type 0x23,
Message Type 0x24,
Message Type 0x25
towing.alarm.status
boolean
Towing alarm state
Alarm Type 7
usb.connection.status
boolean
Status of USB connection (true - USB cable is connected, false - USB cable is disconnected)
Alarm Code 12,
Alarm Code 13
vehicle.mileage
number
km
Total calculated mileage
Message Type 0x02,
Message Type 0x04,
Message Type 0x13,
Message Type 0x14
vehicle.vin
string
VIN of vehicle
Message Type 0x09,
Message Type 0x22
vibration.status
boolean
Vibration status of the device. true - device is vibrated, false - device is in still state
Alarm Code 26,
Alarm Code 9
wifi.mac.address
string
WiFi MAC address
Message Type 0x15,
Message Type 0x24,
Message Type 0x25
wifi.signal.strength
number
WiFi signal strength, RSSI
Message Type 0x15,
Message Type 0x24,
Message Type 0x25
x.acceleration
number
g
Accelerometer value X
Message Type 0x02,
Message Type 0x06,
Message Type 0x07
y.acceleration
number
g
Accelerometer value Y
Message Type 0x02,
Message Type 0x06,
Message Type 0x07
z.acceleration
number
g
Accelerometer value Z
Message Type 0x02,
Message Type 0x06,
Message Type 0x07
Properties
Custom command
custom
Send custom command to device
payload: Command data ending with #
Get device IP2 setting
{"payload":"IP2,2#"}
Setup communication mode to UDP
{"payload":"DMODE,2#"}
Set APN with username and password
{"payload":"APN,APN_name,APN_username,APN_password#"}