aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--contrib/ptunnel-dissector.lua48
-rw-r--r--src/options.c2
-rw-r--r--src/pconfig.h1
3 files changed, 50 insertions, 1 deletions
diff --git a/contrib/ptunnel-dissector.lua b/contrib/ptunnel-dissector.lua
new file mode 100644
index 0000000..d5a63a2
--- /dev/null
+++ b/contrib/ptunnel-dissector.lua
@@ -0,0 +1,48 @@
+ptunnel_protocol = Proto("PTunnel-NG", "PTunnel-NG Protocol")
+
+icmp_type = ProtoField.uint8("icmp.type", "type", base.HEX)
+icmp_code = ProtoField.uint8("icmp.code", "code", base.HEX)
+icmp_chksm = ProtoField.uint16("icmp.chksm", "chksm", base.HEX)
+
+magic = ProtoField.uint32("ptunnel.magic", "magic", base.HEX)
+
+ptunnel_protocol.fields = { icmp_type, icmp_code, icmp_chksm, magic }
+
+function ptunnel_protocol.dissector(buffer, pinfo, tree)
+ length = buffer:len()
+ if length == 0 then return end
+
+ pinfo.cols.protocol = ptunnel_protocol.name
+
+ local subtree = tree:add(ptunnel_protocol, buffer(), "PTunnel Protocol Data")
+ local icmpHeaderSubtree = subtree:add(ptunnel_protocol, buffer(), "ICMP Header")
+
+ icmpHeaderSubtree:add_le(icmp_type, buffer(0,1))
+ icmpHeaderSubtree:add_le(icmp_code, buffer(1,1))
+ icmpHeaderSubtree:add_le(icmp_chksm, buffer(2,2))
+
+ icmpHeaderSubtree:add_le(magic, buffer(4,4))
+end
+
+local icmp = DissectorTable.get("ip.proto")
+icmp:add(1, ptunnel_protocol)
+
+local function heuristic_checker(buffer, pinfo, tree)
+ length = buffer:len()
+ --if length < 28 + 8 then return false end
+
+ local magic = buffer(8,4):uint32()
+ if magic == 0xdeadc0de
+ then
+ ptunnel_protocol.dissector(buffer, pinfo, tree)
+ return true
+ else
+ return false
+ end
+end
+
+ptunnel_protocol:register_heuristic("ip", heuristic_checker)
+
+--for k,v in pairs(DissectorTable.list()) do
+-- print(k,v)
+--end
diff --git a/src/options.c b/src/options.c
index 84227ae..4d36a73 100644
--- a/src/options.c
+++ b/src/options.c
@@ -74,7 +74,7 @@ struct option_usage {
static const struct option_usage usage[] = {
/** --magic */
- {"magic", 0, OPT_HEX32, {.unum = 0xdeadc0de},
+ {"magic", 0, OPT_HEX32, {.unum = kMagic_default},
"Set ptunnel magic hexadecimal number. (32-bit unsigned)\n"
"It is an identifier for all ICMP/UDP packets\n"
"and can be used to bypass Cisco IPS fingerprint scan.\n"
diff --git a/src/pconfig.h b/src/pconfig.h
index 140cad5..8c9fcba 100644
--- a/src/pconfig.h
+++ b/src/pconfig.h
@@ -47,6 +47,7 @@
#define PCONFIG_H 1
enum {
+ kMagic_default = 0xdeadc0de,
/** Set this constant to the number of
* concurrent connections you wish to handle by default.
*/