decoder propre

master
Eloan ANDRÉ 2 years ago
parent fa62cd4ec8
commit 97c2dd0dbc

Binary file not shown.

@ -9,18 +9,78 @@ import scapy.contrib.modbus as mb
def decode(pkt): def decode(pkt):
if "ModbusADU" in pkt: if "ModbusADU" in pkt:
miniL=[] global miniL
modpkt = pkt["ModbusADU"] modpkt = pkt["ModbusADU"]
print(modpkt.payload.name) print(modpkt.payload.name)
for i in modpkt.payload.fields: for i in modpkt.payload.fields:
miniL.append(modpkt.payload.getfieldval(i)) typeCall = ""
print(i,modpkt.payload.getfieldval(i)) print(i,modpkt.payload.getfieldval(i),type(modpkt.payload.get_field(i)))
if(i=="coilStatus"):
bi=str(bin(modpkt.payload.getfieldval(i)[0])) if "Multiple" in modpkt.payload.name:
typeCall += "m"
else:
typeCall += "s"
if "Coil" in modpkt.payload.name:
typeCall += "C"
else:
typeCall += "R"
miniL[0] = typeCall
if "Read" in modpkt.payload.name:
typeCall += "r"
if "Response" in modpkt.payload.name:
byteCount = modpkt.payload.getfieldval("byteCount")
print(byteCount,"cc")
cs = []
if "C" in typeCall:
Value = modpkt.payload.getfieldval("coilStatus")
for j in range(byteCount):
bi=str(bin(Value[j]))
bi=bi[2:] bi=bi[2:]
bi=bi.rjust(8,'0') bi=bi.rjust(8,'0')[::-1]
print([*bi]) cs.extend(k for k in [*bi])
bigL.append(miniL) else:
cs = modpkt.payload.getfieldval("registerVal")
for j in range(len(cs)):
bigL.append([miniL[0],cs[j],miniL[2]+j])
miniL = [0,0,0]
print(bigL) print(bigL)
else:
startAddr = modpkt.payload.getfieldval("startAddr")
miniL[2] = startAddr
else:
typeCall += "w"
if "Response" in modpkt.payload.name:
pass
else:
if "m" in typeCall:
addr = modpkt.payload.getfieldval("startAddr")
#byteCount = modpkt.payload.getfieldval("quantityOutput")
outputValue = modpkt.payload.getfieldval("outputsValue")
cs = []
if "C" in typeCall:
for j in range(len(outputValue)):
bi=str(bin(outputValue[j]))
bi = bi[2:]
bi = bi.rjust(8,'0')[::-1]
cs.extend(k for k in [*bi])
for j in range(len(cs)):
bigL.append([miniL[0],cs[j],addr+j]) # changer 5 pour mettre l'adresse
print(bigL)
else:
if "C" in typeCall:
addr = modpkt.payload.getfieldval("outputAddr")
outputValue = modpkt.payload.getfieldval("outputValue")
else:
addr = modpkt.payload.getfieldval("registerAddr")
outputValue = modpkt.payload.getfieldval("registerValue")
bigL.append([miniL[0],outputValue,addr])
bigL.append(miniL)
#print(bigL)
bigL = [] bigL = []
miniL = [0,0,0]
scapy.sniff(iface="lo", prn=decode) scapy.sniff(iface="lo", prn=decode)

Loading…
Cancel
Save