pypcapkit 1.3.5.post6__cp313-none-any.whl

Sign up to get free protection for your applications and to get access to all the features.
Files changed (466) hide show
  1. pcapkit/__init__.py +124 -0
  2. pcapkit/__main__.py +138 -0
  3. pcapkit/all.py +136 -0
  4. pcapkit/const/__init__.py +81 -0
  5. pcapkit/const/arp/__init__.py +25 -0
  6. pcapkit/const/arp/hardware.py +181 -0
  7. pcapkit/const/arp/operation.py +131 -0
  8. pcapkit/const/ftp/__init__.py +25 -0
  9. pcapkit/const/ftp/command.py +309 -0
  10. pcapkit/const/ftp/return_code.py +304 -0
  11. pcapkit/const/hip/__init__.py +94 -0
  12. pcapkit/const/hip/certificate.py +77 -0
  13. pcapkit/const/hip/cipher.py +65 -0
  14. pcapkit/const/hip/di.py +59 -0
  15. pcapkit/const/hip/ecdsa_curve.py +59 -0
  16. pcapkit/const/hip/ecdsa_low_curve.py +56 -0
  17. pcapkit/const/hip/eddsa_curve.py +65 -0
  18. pcapkit/const/hip/esp_transform_suite.py +98 -0
  19. pcapkit/const/hip/group.py +86 -0
  20. pcapkit/const/hip/hi_algorithm.py +86 -0
  21. pcapkit/const/hip/hit_suite.py +68 -0
  22. pcapkit/const/hip/nat_traversal.py +62 -0
  23. pcapkit/const/hip/notify_message.py +200 -0
  24. pcapkit/const/hip/packet.py +89 -0
  25. pcapkit/const/hip/parameter.py +377 -0
  26. pcapkit/const/hip/registration.py +68 -0
  27. pcapkit/const/hip/registration_failure.py +84 -0
  28. pcapkit/const/hip/suite.py +71 -0
  29. pcapkit/const/hip/transport.py +59 -0
  30. pcapkit/const/http/__init__.py +39 -0
  31. pcapkit/const/http/error_code.py +95 -0
  32. pcapkit/const/http/frame.py +95 -0
  33. pcapkit/const/http/method.py +184 -0
  34. pcapkit/const/http/setting.py +96 -0
  35. pcapkit/const/http/status_code.py +298 -0
  36. pcapkit/const/ipv4/__init__.py +57 -0
  37. pcapkit/const/ipv4/classification_level.py +64 -0
  38. pcapkit/const/ipv4/option_class.py +55 -0
  39. pcapkit/const/ipv4/option_number.py +137 -0
  40. pcapkit/const/ipv4/protection_authority.py +63 -0
  41. pcapkit/const/ipv4/qs_function.py +51 -0
  42. pcapkit/const/ipv4/router_alert.py +251 -0
  43. pcapkit/const/ipv4/tos_del.py +51 -0
  44. pcapkit/const/ipv4/tos_ecn.py +55 -0
  45. pcapkit/const/ipv4/tos_pre.py +63 -0
  46. pcapkit/const/ipv4/tos_rel.py +51 -0
  47. pcapkit/const/ipv4/tos_thr.py +51 -0
  48. pcapkit/const/ipv4/ts_flag.py +53 -0
  49. pcapkit/const/ipv6/__init__.py +53 -0
  50. pcapkit/const/ipv6/extension_header.py +69 -0
  51. pcapkit/const/ipv6/option.py +137 -0
  52. pcapkit/const/ipv6/option_action.py +55 -0
  53. pcapkit/const/ipv6/qs_function.py +51 -0
  54. pcapkit/const/ipv6/router_alert.py +266 -0
  55. pcapkit/const/ipv6/routing.py +80 -0
  56. pcapkit/const/ipv6/seed_id.py +55 -0
  57. pcapkit/const/ipv6/smf_dpd_mode.py +51 -0
  58. pcapkit/const/ipv6/tagger_id.py +62 -0
  59. pcapkit/const/ipx/__init__.py +27 -0
  60. pcapkit/const/ipx/packet.py +72 -0
  61. pcapkit/const/ipx/socket.py +104 -0
  62. pcapkit/const/l2tp/__init__.py +21 -0
  63. pcapkit/const/l2tp/type.py +51 -0
  64. pcapkit/const/mh/__init__.py +204 -0
  65. pcapkit/const/mh/access_type.py +92 -0
  66. pcapkit/const/mh/ack_status_code.py +71 -0
  67. pcapkit/const/mh/ani_suboption.py +74 -0
  68. pcapkit/const/mh/auth_subtype.py +53 -0
  69. pcapkit/const/mh/binding_ack_flag.py +66 -0
  70. pcapkit/const/mh/binding_error.py +51 -0
  71. pcapkit/const/mh/binding_revocation.py +59 -0
  72. pcapkit/const/mh/binding_update_flag.py +81 -0
  73. pcapkit/const/mh/cga_extension.py +66 -0
  74. pcapkit/const/mh/cga_sec.py +57 -0
  75. pcapkit/const/mh/cga_type.py +68 -0
  76. pcapkit/const/mh/dhcp_support_mode.py +53 -0
  77. pcapkit/const/mh/dns_status_code.py +65 -0
  78. pcapkit/const/mh/dsmip6_tls_packet.py +62 -0
  79. pcapkit/const/mh/dsmipv6_home_address.py +74 -0
  80. pcapkit/const/mh/enumerating_algorithm.py +56 -0
  81. pcapkit/const/mh/fb_ack_status.py +62 -0
  82. pcapkit/const/mh/fb_action.py +71 -0
  83. pcapkit/const/mh/fb_indication_trigger.py +65 -0
  84. pcapkit/const/mh/fb_type.py +59 -0
  85. pcapkit/const/mh/flow_id_status.py +77 -0
  86. pcapkit/const/mh/flow_id_suboption.py +71 -0
  87. pcapkit/const/mh/handoff_type.py +71 -0
  88. pcapkit/const/mh/handover_ack_flag.py +54 -0
  89. pcapkit/const/mh/handover_ack_status.py +92 -0
  90. pcapkit/const/mh/handover_initiate_flag.py +57 -0
  91. pcapkit/const/mh/handover_initiate_status.py +62 -0
  92. pcapkit/const/mh/home_address_reply.py +71 -0
  93. pcapkit/const/mh/lla_code.py +63 -0
  94. pcapkit/const/mh/lma_mag_suboption.py +59 -0
  95. pcapkit/const/mh/mn_group_id.py +59 -0
  96. pcapkit/const/mh/mn_id_subtype.py +77 -0
  97. pcapkit/const/mh/operator_id.py +63 -0
  98. pcapkit/const/mh/option.py +260 -0
  99. pcapkit/const/mh/packet.py +119 -0
  100. pcapkit/const/mh/qos_attribute.py +89 -0
  101. pcapkit/const/mh/revocation_status_code.py +83 -0
  102. pcapkit/const/mh/revocation_trigger.py +86 -0
  103. pcapkit/const/mh/status_code.py +232 -0
  104. pcapkit/const/mh/traffic_selector.py +62 -0
  105. pcapkit/const/mh/upa_status.py +71 -0
  106. pcapkit/const/mh/upn_reason.py +80 -0
  107. pcapkit/const/ospf/__init__.py +27 -0
  108. pcapkit/const/ospf/authentication.py +65 -0
  109. pcapkit/const/ospf/packet.py +71 -0
  110. pcapkit/const/pcapng/__init__.py +51 -0
  111. pcapkit/const/pcapng/block_type.py +152 -0
  112. pcapkit/const/pcapng/filter_type.py +48 -0
  113. pcapkit/const/pcapng/hash_algorithm.py +59 -0
  114. pcapkit/const/pcapng/option_type.py +233 -0
  115. pcapkit/const/pcapng/record_type.py +57 -0
  116. pcapkit/const/pcapng/secrets_type.py +56 -0
  117. pcapkit/const/pcapng/verdict_type.py +53 -0
  118. pcapkit/const/reg/__init__.py +34 -0
  119. pcapkit/const/reg/apptype.py +32728 -0
  120. pcapkit/const/reg/ethertype.py +714 -0
  121. pcapkit/const/reg/linktype.py +890 -0
  122. pcapkit/const/reg/transtype.py +526 -0
  123. pcapkit/const/tcp/__init__.py +35 -0
  124. pcapkit/const/tcp/checksum.py +55 -0
  125. pcapkit/const/tcp/flags.py +73 -0
  126. pcapkit/const/tcp/mp_tcp_option.py +80 -0
  127. pcapkit/const/tcp/option.py +198 -0
  128. pcapkit/const/vlan/__init__.py +23 -0
  129. pcapkit/const/vlan/priority_level.py +71 -0
  130. pcapkit/corekit/__init__.py +59 -0
  131. pcapkit/corekit/fields/__init__.py +45 -0
  132. pcapkit/corekit/fields/collections.py +282 -0
  133. pcapkit/corekit/fields/field.py +269 -0
  134. pcapkit/corekit/fields/ipaddress.py +274 -0
  135. pcapkit/corekit/fields/misc.py +722 -0
  136. pcapkit/corekit/fields/numbers.py +375 -0
  137. pcapkit/corekit/fields/strings.py +245 -0
  138. pcapkit/corekit/infoclass.py +394 -0
  139. pcapkit/corekit/io.py +506 -0
  140. pcapkit/corekit/module.py +39 -0
  141. pcapkit/corekit/multidict.py +626 -0
  142. pcapkit/corekit/protochain.py +263 -0
  143. pcapkit/corekit/version.py +33 -0
  144. pcapkit/dumpkit/__init__.py +15 -0
  145. pcapkit/dumpkit/common.py +199 -0
  146. pcapkit/dumpkit/null.py +77 -0
  147. pcapkit/dumpkit/pcap.py +144 -0
  148. pcapkit/foundation/__init__.py +45 -0
  149. pcapkit/foundation/engines/__init__.py +36 -0
  150. pcapkit/foundation/engines/dpkt.py +230 -0
  151. pcapkit/foundation/engines/engine.py +194 -0
  152. pcapkit/foundation/engines/pcap.py +188 -0
  153. pcapkit/foundation/engines/pcapng.py +310 -0
  154. pcapkit/foundation/engines/pyshark.py +166 -0
  155. pcapkit/foundation/engines/scapy.py +161 -0
  156. pcapkit/foundation/extraction.py +915 -0
  157. pcapkit/foundation/reassembly/__init__.py +49 -0
  158. pcapkit/foundation/reassembly/data/__init__.py +48 -0
  159. pcapkit/foundation/reassembly/data/ip.py +117 -0
  160. pcapkit/foundation/reassembly/data/tcp.py +145 -0
  161. pcapkit/foundation/reassembly/ip.py +192 -0
  162. pcapkit/foundation/reassembly/ipv4.py +50 -0
  163. pcapkit/foundation/reassembly/ipv6.py +50 -0
  164. pcapkit/foundation/reassembly/reassembly.py +389 -0
  165. pcapkit/foundation/reassembly/tcp.py +249 -0
  166. pcapkit/foundation/registry/__init__.py +41 -0
  167. pcapkit/foundation/registry/foundation.py +327 -0
  168. pcapkit/foundation/registry/protocols.py +885 -0
  169. pcapkit/foundation/traceflow/__init__.py +44 -0
  170. pcapkit/foundation/traceflow/data/__init__.py +30 -0
  171. pcapkit/foundation/traceflow/data/tcp.py +105 -0
  172. pcapkit/foundation/traceflow/tcp.py +159 -0
  173. pcapkit/foundation/traceflow/traceflow.py +390 -0
  174. pcapkit/interface/__init__.py +22 -0
  175. pcapkit/interface/core.py +185 -0
  176. pcapkit/interface/misc.py +120 -0
  177. pcapkit/protocols/__init__.py +85 -0
  178. pcapkit/protocols/application/NotImplemented/bgp.py +0 -0
  179. pcapkit/protocols/application/NotImplemented/dhcp.py +0 -0
  180. pcapkit/protocols/application/NotImplemented/dhcpv6.py +0 -0
  181. pcapkit/protocols/application/NotImplemented/dns.py +0 -0
  182. pcapkit/protocols/application/NotImplemented/imap.py +0 -0
  183. pcapkit/protocols/application/NotImplemented/ldap.py +0 -0
  184. pcapkit/protocols/application/NotImplemented/mqtt.py +0 -0
  185. pcapkit/protocols/application/NotImplemented/nntp.py +0 -0
  186. pcapkit/protocols/application/NotImplemented/ntp.py +0 -0
  187. pcapkit/protocols/application/NotImplemented/onc_rpc.py +0 -0
  188. pcapkit/protocols/application/NotImplemented/pop.py +0 -0
  189. pcapkit/protocols/application/NotImplemented/rip.py +0 -0
  190. pcapkit/protocols/application/NotImplemented/rtp.py +0 -0
  191. pcapkit/protocols/application/NotImplemented/sip.py +0 -0
  192. pcapkit/protocols/application/NotImplemented/smtp.py +0 -0
  193. pcapkit/protocols/application/NotImplemented/snmp.py +0 -0
  194. pcapkit/protocols/application/NotImplemented/ssh.py +0 -0
  195. pcapkit/protocols/application/NotImplemented/telnet.py +0 -0
  196. pcapkit/protocols/application/NotImplemented/tls.py +0 -0
  197. pcapkit/protocols/application/NotImplemented/xmpp.py +0 -0
  198. pcapkit/protocols/application/__init__.py +34 -0
  199. pcapkit/protocols/application/application.py +114 -0
  200. pcapkit/protocols/application/ftp.py +206 -0
  201. pcapkit/protocols/application/http.py +176 -0
  202. pcapkit/protocols/application/httpv1.py +320 -0
  203. pcapkit/protocols/application/httpv2.py +1255 -0
  204. pcapkit/protocols/data/__init__.py +192 -0
  205. pcapkit/protocols/data/application/__init__.py +57 -0
  206. pcapkit/protocols/data/application/ftp.py +59 -0
  207. pcapkit/protocols/data/application/httpv1.py +79 -0
  208. pcapkit/protocols/data/application/httpv2.py +293 -0
  209. pcapkit/protocols/data/data.py +25 -0
  210. pcapkit/protocols/data/internet/__init__.py +298 -0
  211. pcapkit/protocols/data/internet/ah.py +31 -0
  212. pcapkit/protocols/data/internet/hip.py +804 -0
  213. pcapkit/protocols/data/internet/hopopt.py +351 -0
  214. pcapkit/protocols/data/internet/ipv4.py +369 -0
  215. pcapkit/protocols/data/internet/ipv6.py +67 -0
  216. pcapkit/protocols/data/internet/ipv6_frag.py +29 -0
  217. pcapkit/protocols/data/internet/ipv6_opts.py +368 -0
  218. pcapkit/protocols/data/internet/ipv6_route.py +86 -0
  219. pcapkit/protocols/data/internet/ipx.py +56 -0
  220. pcapkit/protocols/data/internet/mh.py +509 -0
  221. pcapkit/protocols/data/link/__init__.py +33 -0
  222. pcapkit/protocols/data/link/arp.py +74 -0
  223. pcapkit/protocols/data/link/ethernet.py +28 -0
  224. pcapkit/protocols/data/link/l2tp.py +63 -0
  225. pcapkit/protocols/data/link/ospf.py +58 -0
  226. pcapkit/protocols/data/link/vlan.py +42 -0
  227. pcapkit/protocols/data/misc/__init__.py +109 -0
  228. pcapkit/protocols/data/misc/null.py +18 -0
  229. pcapkit/protocols/data/misc/pcap/__init__.py +18 -0
  230. pcapkit/protocols/data/misc/pcap/frame.py +56 -0
  231. pcapkit/protocols/data/misc/pcap/header.py +53 -0
  232. pcapkit/protocols/data/misc/pcapng.py +925 -0
  233. pcapkit/protocols/data/misc/raw.py +25 -0
  234. pcapkit/protocols/data/protocol.py +32 -0
  235. pcapkit/protocols/data/transport/__init__.py +71 -0
  236. pcapkit/protocols/data/transport/tcp.py +555 -0
  237. pcapkit/protocols/data/transport/udp.py +29 -0
  238. pcapkit/protocols/internet/NotImplemented/ecn.py +0 -0
  239. pcapkit/protocols/internet/NotImplemented/esp.py +97 -0
  240. pcapkit/protocols/internet/NotImplemented/icmp.py +0 -0
  241. pcapkit/protocols/internet/NotImplemented/icmpv6.py +0 -0
  242. pcapkit/protocols/internet/NotImplemented/igmp.py +0 -0
  243. pcapkit/protocols/internet/NotImplemented/shim6.py +0 -0
  244. pcapkit/protocols/internet/__init__.py +43 -0
  245. pcapkit/protocols/internet/ah.py +275 -0
  246. pcapkit/protocols/internet/hip.py +4727 -0
  247. pcapkit/protocols/internet/hopopt.py +1879 -0
  248. pcapkit/protocols/internet/internet.py +249 -0
  249. pcapkit/protocols/internet/ip.py +51 -0
  250. pcapkit/protocols/internet/ipsec.py +50 -0
  251. pcapkit/protocols/internet/ipv4.py +1782 -0
  252. pcapkit/protocols/internet/ipv6.py +412 -0
  253. pcapkit/protocols/internet/ipv6_frag.py +258 -0
  254. pcapkit/protocols/internet/ipv6_opts.py +1890 -0
  255. pcapkit/protocols/internet/ipv6_route.py +708 -0
  256. pcapkit/protocols/internet/ipx.py +230 -0
  257. pcapkit/protocols/internet/mh.py +2764 -0
  258. pcapkit/protocols/link/NotImplemented/dsl.py +0 -0
  259. pcapkit/protocols/link/NotImplemented/eapol.py +1 -0
  260. pcapkit/protocols/link/NotImplemented/fddi.py +0 -0
  261. pcapkit/protocols/link/NotImplemented/isdn.py +0 -0
  262. pcapkit/protocols/link/NotImplemented/ndp.py +0 -0
  263. pcapkit/protocols/link/NotImplemented/ppp.py +0 -0
  264. pcapkit/protocols/link/__init__.py +35 -0
  265. pcapkit/protocols/link/arp.py +421 -0
  266. pcapkit/protocols/link/ethernet.py +248 -0
  267. pcapkit/protocols/link/l2tp.py +267 -0
  268. pcapkit/protocols/link/link.py +140 -0
  269. pcapkit/protocols/link/ospf.py +342 -0
  270. pcapkit/protocols/link/rarp.py +82 -0
  271. pcapkit/protocols/link/vlan.py +225 -0
  272. pcapkit/protocols/misc/__init__.py +37 -0
  273. pcapkit/protocols/misc/null.py +129 -0
  274. pcapkit/protocols/misc/pcap/__init__.py +17 -0
  275. pcapkit/protocols/misc/pcap/frame.py +478 -0
  276. pcapkit/protocols/misc/pcap/header.py +358 -0
  277. pcapkit/protocols/misc/pcapng.py +5520 -0
  278. pcapkit/protocols/misc/raw.py +180 -0
  279. pcapkit/protocols/protocol.py +1216 -0
  280. pcapkit/protocols/schema/__init__.py +140 -0
  281. pcapkit/protocols/schema/application/__init__.py +40 -0
  282. pcapkit/protocols/schema/application/ftp.py +21 -0
  283. pcapkit/protocols/schema/application/httpv1.py +21 -0
  284. pcapkit/protocols/schema/application/httpv2.py +384 -0
  285. pcapkit/protocols/schema/internet/__init__.py +294 -0
  286. pcapkit/protocols/schema/internet/ah.py +40 -0
  287. pcapkit/protocols/schema/internet/hip.py +1184 -0
  288. pcapkit/protocols/schema/internet/hopopt.py +679 -0
  289. pcapkit/protocols/schema/internet/ipv4.py +576 -0
  290. pcapkit/protocols/schema/internet/ipv6.py +63 -0
  291. pcapkit/protocols/schema/internet/ipv6_frag.py +48 -0
  292. pcapkit/protocols/schema/internet/ipv6_opts.py +680 -0
  293. pcapkit/protocols/schema/internet/ipv6_route.py +197 -0
  294. pcapkit/protocols/schema/internet/ipx.py +40 -0
  295. pcapkit/protocols/schema/internet/mh.py +718 -0
  296. pcapkit/protocols/schema/link/__init__.py +19 -0
  297. pcapkit/protocols/schema/link/arp.py +39 -0
  298. pcapkit/protocols/schema/link/ethernet.py +51 -0
  299. pcapkit/protocols/schema/link/l2tp.py +88 -0
  300. pcapkit/protocols/schema/link/ospf.py +90 -0
  301. pcapkit/protocols/schema/link/vlan.py +69 -0
  302. pcapkit/protocols/schema/misc/__init__.py +108 -0
  303. pcapkit/protocols/schema/misc/null.py +18 -0
  304. pcapkit/protocols/schema/misc/pcap/__init__.py +10 -0
  305. pcapkit/protocols/schema/misc/pcap/frame.py +51 -0
  306. pcapkit/protocols/schema/misc/pcap/header.py +63 -0
  307. pcapkit/protocols/schema/misc/pcapng.py +1689 -0
  308. pcapkit/protocols/schema/misc/raw.py +24 -0
  309. pcapkit/protocols/schema/schema.py +809 -0
  310. pcapkit/protocols/schema/transport/__init__.py +69 -0
  311. pcapkit/protocols/schema/transport/tcp.py +928 -0
  312. pcapkit/protocols/schema/transport/udp.py +90 -0
  313. pcapkit/protocols/transport/NotImplemented/dccp.py +0 -0
  314. pcapkit/protocols/transport/NotImplemented/rsvp.py +0 -0
  315. pcapkit/protocols/transport/NotImplemented/sctp.py +0 -0
  316. pcapkit/protocols/transport/__init__.py +27 -0
  317. pcapkit/protocols/transport/tcp.py +3025 -0
  318. pcapkit/protocols/transport/transport.py +158 -0
  319. pcapkit/protocols/transport/udp.py +214 -0
  320. pcapkit/py.typed +0 -0
  321. pcapkit/toolkit/__init__.py +57 -0
  322. pcapkit/toolkit/dpkt.py +306 -0
  323. pcapkit/toolkit/pcap.py +212 -0
  324. pcapkit/toolkit/pcapng.py +251 -0
  325. pcapkit/toolkit/pyshark.py +99 -0
  326. pcapkit/toolkit/scapy.py +297 -0
  327. pcapkit/utilities/__init__.py +20 -0
  328. pcapkit/utilities/compat.py +196 -0
  329. pcapkit/utilities/decorators.py +197 -0
  330. pcapkit/utilities/exceptions.py +365 -0
  331. pcapkit/utilities/logging.py +55 -0
  332. pcapkit/utilities/warnings.py +185 -0
  333. pcapkit/vendor/__init__.py +105 -0
  334. pcapkit/vendor/__main__.py +92 -0
  335. pcapkit/vendor/arp/__init__.py +27 -0
  336. pcapkit/vendor/arp/hardware.py +29 -0
  337. pcapkit/vendor/arp/operation.py +29 -0
  338. pcapkit/vendor/default.py +474 -0
  339. pcapkit/vendor/ftp/__init__.py +27 -0
  340. pcapkit/vendor/ftp/command.py +244 -0
  341. pcapkit/vendor/ftp/return_code.py +256 -0
  342. pcapkit/vendor/hip/__init__.py +94 -0
  343. pcapkit/vendor/hip/certificate.py +29 -0
  344. pcapkit/vendor/hip/cipher.py +29 -0
  345. pcapkit/vendor/hip/di.py +29 -0
  346. pcapkit/vendor/hip/ecdsa_curve.py +29 -0
  347. pcapkit/vendor/hip/ecdsa_low_curve.py +29 -0
  348. pcapkit/vendor/hip/eddsa_curve.py +85 -0
  349. pcapkit/vendor/hip/esp_transform_suite.py +29 -0
  350. pcapkit/vendor/hip/group.py +87 -0
  351. pcapkit/vendor/hip/hi_algorithm.py +29 -0
  352. pcapkit/vendor/hip/hit_suite.py +29 -0
  353. pcapkit/vendor/hip/nat_traversal.py +29 -0
  354. pcapkit/vendor/hip/notify_message.py +29 -0
  355. pcapkit/vendor/hip/packet.py +88 -0
  356. pcapkit/vendor/hip/parameter.py +88 -0
  357. pcapkit/vendor/hip/registration.py +29 -0
  358. pcapkit/vendor/hip/registration_failure.py +29 -0
  359. pcapkit/vendor/hip/suite.py +29 -0
  360. pcapkit/vendor/hip/transport.py +29 -0
  361. pcapkit/vendor/http/__init__.py +39 -0
  362. pcapkit/vendor/http/error_code.py +95 -0
  363. pcapkit/vendor/http/frame.py +91 -0
  364. pcapkit/vendor/http/method.py +167 -0
  365. pcapkit/vendor/http/setting.py +93 -0
  366. pcapkit/vendor/http/status_code.py +185 -0
  367. pcapkit/vendor/ipv4/__init__.py +57 -0
  368. pcapkit/vendor/ipv4/classification_level.py +91 -0
  369. pcapkit/vendor/ipv4/option_class.py +80 -0
  370. pcapkit/vendor/ipv4/option_number.py +105 -0
  371. pcapkit/vendor/ipv4/protection_authority.py +84 -0
  372. pcapkit/vendor/ipv4/qs_function.py +78 -0
  373. pcapkit/vendor/ipv4/router_alert.py +93 -0
  374. pcapkit/vendor/ipv4/tos_del.py +78 -0
  375. pcapkit/vendor/ipv4/tos_ecn.py +95 -0
  376. pcapkit/vendor/ipv4/tos_pre.py +84 -0
  377. pcapkit/vendor/ipv4/tos_rel.py +78 -0
  378. pcapkit/vendor/ipv4/tos_thr.py +77 -0
  379. pcapkit/vendor/ipv4/ts_flag.py +79 -0
  380. pcapkit/vendor/ipv6/__init__.py +53 -0
  381. pcapkit/vendor/ipv6/extension_header.py +171 -0
  382. pcapkit/vendor/ipv6/option.py +104 -0
  383. pcapkit/vendor/ipv6/option_action.py +90 -0
  384. pcapkit/vendor/ipv6/qs_function.py +78 -0
  385. pcapkit/vendor/ipv6/router_alert.py +93 -0
  386. pcapkit/vendor/ipv6/routing.py +87 -0
  387. pcapkit/vendor/ipv6/seed_id.py +81 -0
  388. pcapkit/vendor/ipv6/smf_dpd_mode.py +78 -0
  389. pcapkit/vendor/ipv6/tagger_id.py +81 -0
  390. pcapkit/vendor/ipx/__init__.py +37 -0
  391. pcapkit/vendor/ipx/packet.py +123 -0
  392. pcapkit/vendor/ipx/socket.py +125 -0
  393. pcapkit/vendor/l2tp/__init__.py +21 -0
  394. pcapkit/vendor/l2tp/type.py +78 -0
  395. pcapkit/vendor/mh/__init__.py +204 -0
  396. pcapkit/vendor/mh/access_type.py +87 -0
  397. pcapkit/vendor/mh/ack_status_code.py +88 -0
  398. pcapkit/vendor/mh/ani_suboption.py +88 -0
  399. pcapkit/vendor/mh/auth_subtype.py +83 -0
  400. pcapkit/vendor/mh/binding_ack_flag.py +148 -0
  401. pcapkit/vendor/mh/binding_error.py +78 -0
  402. pcapkit/vendor/mh/binding_revocation.py +87 -0
  403. pcapkit/vendor/mh/binding_update_flag.py +147 -0
  404. pcapkit/vendor/mh/cga_extension.py +91 -0
  405. pcapkit/vendor/mh/cga_sec.py +91 -0
  406. pcapkit/vendor/mh/cga_type.py +74 -0
  407. pcapkit/vendor/mh/dhcp_support_mode.py +77 -0
  408. pcapkit/vendor/mh/dns_status_code.py +87 -0
  409. pcapkit/vendor/mh/dsmip6_tls_packet.py +87 -0
  410. pcapkit/vendor/mh/dsmipv6_home_address.py +87 -0
  411. pcapkit/vendor/mh/enumerating_algorithm.py +82 -0
  412. pcapkit/vendor/mh/fb_ack_status.py +87 -0
  413. pcapkit/vendor/mh/fb_action.py +88 -0
  414. pcapkit/vendor/mh/fb_indication_trigger.py +87 -0
  415. pcapkit/vendor/mh/fb_type.py +88 -0
  416. pcapkit/vendor/mh/flow_id_status.py +87 -0
  417. pcapkit/vendor/mh/flow_id_suboption.py +87 -0
  418. pcapkit/vendor/mh/handoff_type.py +87 -0
  419. pcapkit/vendor/mh/handover_ack_flag.py +143 -0
  420. pcapkit/vendor/mh/handover_ack_status.py +87 -0
  421. pcapkit/vendor/mh/handover_initiate_flag.py +143 -0
  422. pcapkit/vendor/mh/handover_initiate_status.py +87 -0
  423. pcapkit/vendor/mh/home_address_reply.py +87 -0
  424. pcapkit/vendor/mh/lla_code.py +97 -0
  425. pcapkit/vendor/mh/lma_mag_suboption.py +88 -0
  426. pcapkit/vendor/mh/mn_group_id.py +87 -0
  427. pcapkit/vendor/mh/mn_id_subtype.py +87 -0
  428. pcapkit/vendor/mh/operator_id.py +87 -0
  429. pcapkit/vendor/mh/option.py +83 -0
  430. pcapkit/vendor/mh/packet.py +82 -0
  431. pcapkit/vendor/mh/qos_attribute.py +87 -0
  432. pcapkit/vendor/mh/revocation_status_code.py +87 -0
  433. pcapkit/vendor/mh/revocation_trigger.py +87 -0
  434. pcapkit/vendor/mh/status_code.py +91 -0
  435. pcapkit/vendor/mh/traffic_selector.py +87 -0
  436. pcapkit/vendor/mh/upa_status.py +87 -0
  437. pcapkit/vendor/mh/upn_reason.py +87 -0
  438. pcapkit/vendor/ospf/__init__.py +27 -0
  439. pcapkit/vendor/ospf/authentication.py +29 -0
  440. pcapkit/vendor/ospf/packet.py +29 -0
  441. pcapkit/vendor/pcapng/__init__.py +51 -0
  442. pcapkit/vendor/pcapng/block_type.py +94 -0
  443. pcapkit/vendor/pcapng/filter_type.py +77 -0
  444. pcapkit/vendor/pcapng/hash_algorithm.py +82 -0
  445. pcapkit/vendor/pcapng/option_type.py +287 -0
  446. pcapkit/vendor/pcapng/record_type.py +81 -0
  447. pcapkit/vendor/pcapng/secrets_type.py +81 -0
  448. pcapkit/vendor/pcapng/verdict_type.py +79 -0
  449. pcapkit/vendor/reg/__init__.py +34 -0
  450. pcapkit/vendor/reg/apptype.py +338 -0
  451. pcapkit/vendor/reg/ethertype.py +121 -0
  452. pcapkit/vendor/reg/linktype.py +110 -0
  453. pcapkit/vendor/reg/transtype.py +111 -0
  454. pcapkit/vendor/tcp/__init__.py +35 -0
  455. pcapkit/vendor/tcp/checksum.py +80 -0
  456. pcapkit/vendor/tcp/flags.py +149 -0
  457. pcapkit/vendor/tcp/mp_tcp_option.py +90 -0
  458. pcapkit/vendor/tcp/option.py +103 -0
  459. pcapkit/vendor/vlan/__init__.py +23 -0
  460. pcapkit/vendor/vlan/priority_level.py +97 -0
  461. pypcapkit-1.3.5.post6.dist-info/LICENSE +29 -0
  462. pypcapkit-1.3.5.post6.dist-info/METADATA +238 -0
  463. pypcapkit-1.3.5.post6.dist-info/RECORD +466 -0
  464. pypcapkit-1.3.5.post6.dist-info/WHEEL +5 -0
  465. pypcapkit-1.3.5.post6.dist-info/entry_points.txt +3 -0
  466. pypcapkit-1.3.5.post6.dist-info/top_level.txt +1 -0
@@ -0,0 +1,389 @@
1
+ # -*- coding: utf-8 -*-
2
+ """Base Class
3
+ ================
4
+
5
+ .. module:: pcapkit.foundation.reassembly.reassembly
6
+
7
+ :mod:`pcapkit.foundation.reassembly.reassembly` contains
8
+ :class:`~pcapkit.foundation.reassembly.reassembly.Reassembly` only,
9
+ which is an abstract base class for all reassembly classes,
10
+ bases on algorithms described in :rfc:`791` and :rfc:`815`,
11
+ implements datagram reassembly of IP and TCP packets.
12
+
13
+ """
14
+ import abc
15
+ from typing import TYPE_CHECKING, Generic, Type, TypeVar, cast
16
+
17
+ from pcapkit.protocols import __proto__ as protocol_registry
18
+ from pcapkit.protocols.misc.raw import Raw
19
+ from pcapkit.utilities.exceptions import UnsupportedCall
20
+
21
+ if TYPE_CHECKING:
22
+ from typing import Any, Callable, Optional, Type
23
+
24
+ from typing_extensions import Self
25
+
26
+ from pcapkit.corekit.infoclass import Info
27
+ from pcapkit.protocols.protocol import ProtocolBase as Protocol
28
+
29
+ CallbackFn = Callable[[list['_DT']], None]
30
+
31
+ __all__ = ['Reassembly']
32
+
33
+ # packet
34
+ _PT = TypeVar('_PT', bound='Info')
35
+ # datagram
36
+ _DT = TypeVar('_DT', bound='Info')
37
+ # buffer ID
38
+ _IT = TypeVar('_IT', bound='tuple')
39
+ # buffer
40
+ _BT = TypeVar('_BT', bound='Info')
41
+
42
+
43
+ class ReassemblyMeta(abc.ABCMeta):
44
+ """Meta class to add dynamic support to :class:`Reassembly`.
45
+
46
+ This meta class is used to generate necessary attributes for the
47
+ :class:`Reassembly` class. It can be useful to reduce unnecessary
48
+ registry calls and simplify the customisation process.
49
+
50
+ """
51
+ if TYPE_CHECKING:
52
+ #: Protocol name of current reassembly object.
53
+ __protocol_name__: 'str'
54
+ #: Protocol of current reassembly object.
55
+ __protocol_type__: 'Type[Protocol]'
56
+
57
+ @property
58
+ def name(cls) -> 'str':
59
+ """Protocol name of current reassembly object."""
60
+ if hasattr(cls, '__protocol_name__'):
61
+ return cls.__protocol_name__
62
+ return cls.__name__
63
+
64
+ @property
65
+ def protocol(cls) -> 'Type[Protocol]':
66
+ """Protocol of current reassembly object."""
67
+ if hasattr(cls, '__protocol_type__'):
68
+ return cls.__protocol_type__
69
+ return protocol_registry.get(cls.name.upper(), Raw)
70
+
71
+
72
+ class ReassemblyBase(Generic[_PT, _DT, _IT, _BT], metaclass=ReassemblyMeta):
73
+ """Base class for reassembly procedure.
74
+
75
+ Args:
76
+ strict: if return all datagrams (including those not
77
+ implemented) when submit
78
+ store: if store reassembled datagram in memory, i.e.,
79
+ :attr:`self._dtgram <_dtgram>` (if not, datagram
80
+ will be discarded after callback)
81
+
82
+ Note:
83
+ This class is for internal use only. For customisation, please use
84
+ :class:`TraceFlow` instead.
85
+
86
+ """
87
+ if TYPE_CHECKING:
88
+ #: Protocol name of current reassembly object.
89
+ __protocol_name__: 'str'
90
+ #: Protocol of current reassembly object.
91
+ __protocol_type__: 'Type[Protocol]'
92
+
93
+ #: List of callback functions upon reassembled datagram.
94
+ __callback_fn__: 'list[CallbackFn]'
95
+
96
+ _flag_s: 'bool'
97
+ _flag_d: 'bool'
98
+ _flag_n: 'bool'
99
+
100
+ # Internal data storage for cached properties.
101
+ __cached__: 'dict[str, Any]'
102
+
103
+ ##########################################################################
104
+ # Properties.
105
+ ##########################################################################
106
+
107
+ @property
108
+ def name(self) -> 'str':
109
+ """Protocol name of current reassembly object.
110
+
111
+ Note:
112
+ This property is not available as a class
113
+ attribute.
114
+
115
+ """
116
+ if hasattr(self, '__protocol_name__'):
117
+ return self.__protocol_name__
118
+ return type(self).name # type: ignore[return-value]
119
+
120
+ @property
121
+ def protocol(self) -> 'Type[Protocol]':
122
+ """Protocol of current reassembly object.
123
+
124
+ Note:
125
+ This property is not available as a class
126
+ attribute.
127
+
128
+ """
129
+ if hasattr(self, '__protocol_type__'):
130
+ return self.__protocol_type__
131
+ return type(self).protocol # type: ignore[return-value]
132
+
133
+ # total number of reassembled packets
134
+ @property
135
+ def count(self) -> 'int':
136
+ """Total number of reassembled packets."""
137
+ if self._flag_n:
138
+ self.__cached__.clear()
139
+ self._flag_n = False
140
+
141
+ if (cached := self.__cached__.get('count')) is not None:
142
+ return cached
143
+
144
+ ret = len(self.datagram)
145
+ self.__cached__['count'] = ret
146
+ return ret
147
+
148
+ # reassembled datagram
149
+ @property
150
+ def datagram(self) -> 'tuple[_DT, ...]':
151
+ """Reassembled datagram.
152
+
153
+ Raises:
154
+ UnsupportedCall: If :attr:`self._flag_d <_flag_d>` is
155
+ set to :data:`False`.
156
+
157
+ """
158
+ if not self._flag_d:
159
+ raise UnsupportedCall(f'{self.__class__.__name__}(store=False) has no attribute "datagram"')
160
+
161
+ if self._buffer:
162
+ return self.fetch()
163
+ return tuple(self._dtgram)
164
+
165
+ ##########################################################################
166
+ # Methods.
167
+ ##########################################################################
168
+
169
+ # reassembly procedure
170
+ @abc.abstractmethod
171
+ def reassembly(self, info: '_PT') -> 'None':
172
+ """Reassembly procedure.
173
+
174
+ Arguments:
175
+ info: info dict of packets to be reassembled
176
+
177
+ """
178
+ # clear cache
179
+ self._flag_n = False
180
+ self.__cached__['count'] = None
181
+ self.__cached__['fetch'] = None
182
+
183
+ # submit reassembled payload
184
+ @abc.abstractmethod
185
+ def submit(self, buf: '_BT', **kwargs: 'Any') -> 'list[_DT]':
186
+ """Submit reassembled payload.
187
+
188
+ Arguments:
189
+ buf: buffer dict of reassembled packets
190
+ **kwargs: arbitrary keyword arguments
191
+
192
+ """
193
+
194
+ # fetch datagram
195
+ def fetch(self) -> 'tuple[_DT, ...]':
196
+ """Fetch datagram.
197
+
198
+ Returns:
199
+ Tuple of reassembled datagrams.
200
+
201
+ Fetch reassembled datagrams from
202
+ :attr:`self._dtgram <pcapkit.foundation.reassembly.reassembly.Reassembly._dtgram>`
203
+ and returns a *tuple* of such datagrams.
204
+
205
+ If no cache found, the method will call
206
+ :meth:`self.submit <pcapkit.foundation.reassembly.reassembly.Reassembly.submit>`
207
+ to *forcedly* obtain newly reassembled payload. Otherwise, the
208
+ already calculated
209
+ :attr:`self._dtgram <pcapkit.foundation.reassembly.reassembly.Reassembly._dtgram>`
210
+ will be returned.
211
+
212
+ """
213
+ if self._flag_n:
214
+ self.__cached__.clear()
215
+ self._flag_n = False
216
+
217
+ if (cached := self.__cached__.get('fetch')) is not None:
218
+ return cached
219
+
220
+ temp_dtgram = [] # type: list[_DT]
221
+ for (bufid, buffer) in self._buffer.items():
222
+ temp_dtgram.extend(
223
+ self.submit(buffer, bufid=bufid)
224
+ )
225
+ temp_dtgram.extend(self._dtgram)
226
+ ret = tuple(temp_dtgram)
227
+
228
+ self.__cached__['fetch'] = ret
229
+ return ret
230
+
231
+ # return datagram index
232
+ def index(self, pkt_num: 'int') -> 'Optional[int]':
233
+ """Return datagram index.
234
+
235
+ Arguments:
236
+ pkt_num: index of packet
237
+
238
+ Returns:
239
+ Reassembled datagram index which was from No. ``pkt_num`` packet;
240
+ if not found, returns :obj:`None`.
241
+
242
+ """
243
+ for counter, datagram in enumerate(self.datagram):
244
+ if pkt_num in datagram.index: # type: ignore[attr-defined]
245
+ return counter
246
+ return None
247
+
248
+ # run automatically
249
+ def run(self, packets: 'list[_PT]') -> 'None':
250
+ """Run automatically.
251
+
252
+ Arguments:
253
+ packets: list of packet dicts to be reassembled
254
+
255
+ """
256
+ for packet in packets:
257
+ self.reassembly(packet)
258
+
259
+ # register callback function
260
+ @classmethod
261
+ def register(cls, callback: 'CallbackFn', *, index: 'Optional[int]' = None) -> 'None':
262
+ """Register callback function.
263
+
264
+ Arguments:
265
+ callback: callback function, which will be called
266
+ when reassembled datagram is obtained, with the
267
+ list of reassembled datagrams as its only argument
268
+ index: index to be inserted in the callback list,; by
269
+ default, the callback will be appended to the end
270
+ of the list
271
+
272
+ """
273
+ if index is not None:
274
+ cls.__callback_fn__.insert(index, callback)
275
+ else:
276
+ cls.__callback_fn__.append(callback)
277
+
278
+ ##########################################################################
279
+ # Data models.
280
+ ##########################################################################
281
+
282
+ def __new__(cls, *args: 'Any', **kwargs: 'Any') -> 'Self': # pylint: disable=unused-argument
283
+ self = super().__new__(cls)
284
+
285
+ # NOTE: Assign this attribute after ``__new__`` to avoid shared memory
286
+ # reference between instances.
287
+ self.__cached__ = {}
288
+
289
+ return self
290
+
291
+ def __init__(self, *, strict: 'bool' = True, store: 'bool' = True) -> 'None':
292
+ """Initialise packet reassembly.
293
+
294
+ Args:
295
+ strict: if return all datagrams (including those not
296
+ implemented) when submit
297
+ store: if store reassembled datagram in memory, i.e.,
298
+ :attr:`self._dtgram <_dtgram>` (if not, datagram
299
+ will be discarded after callback)
300
+
301
+ """
302
+ #: bool: Strict mode flag. If set to :data:`True`, all
303
+ #: data will be returned, including those not completely
304
+ #: reassembled; otherwise, only completely reassembled
305
+ #: data will be returned.
306
+ self._flag_s = strict
307
+ #: bool: Store mode flag. If set to :data:`True`, all
308
+ #: reassembled datagram will be stored in memory, i.e.,
309
+ #: :attr:`self._dtgram <_dtgram>`; otherwise, datagram
310
+ #: will be discarded after callback.
311
+ self._flag_d = store
312
+ #: bool: New datagram flag. If set to :data:`True`, the
313
+ #: :attr:`self._dtgram <_dtgram>` will be repopulated.
314
+ self._flag_n = False
315
+
316
+ #: dict[_IT, _BT]: Dict buffer field. This field is used to
317
+ #: store reassembled packets in the form of ``{bufid: buffer}``.
318
+ self._buffer = {} # type: dict[_IT, _BT]
319
+ #: list[_DT]: List reassembled datagram. This list is used
320
+ #: to store reassembled datagrams.
321
+ self._dtgram = [] # type: list[_DT]
322
+
323
+ def __call__(self, packet: '_PT') -> 'None':
324
+ """Call packet reassembly.
325
+
326
+ Arguments:
327
+ packet: packet dict to be reassembled
328
+ (detailed format described in corresponding protocol)
329
+
330
+ """
331
+ self._flag_n = True
332
+ self.reassembly(packet)
333
+
334
+ def __init_subclass__(cls) -> 'None':
335
+ """Initialise subclass.
336
+
337
+ This method is to be used for generating necessary attributes
338
+ for the :class:`Reassembly` class. It can be useful to reduce
339
+ unnecessary registry calls and simplify the customisation process.
340
+
341
+ """
342
+ cls.__callback_fn__ = []
343
+
344
+
345
+ class Reassembly(ReassemblyBase[_PT, _DT, _IT, _BT], Generic[_PT, _DT, _IT, _BT]):
346
+ """Base flow tracing class.
347
+
348
+ Example:
349
+
350
+ Use keyword argument ``protocol`` to specify the protocol
351
+ name at class definition:
352
+
353
+ .. code-block:: python
354
+
355
+ class MyProtocol(Reassembly, protocol='my_protocol'):
356
+ ...
357
+
358
+ Arguments:
359
+ strict: if return all datagrams (including those not
360
+ implemented) when submit
361
+ store: if store reassembled datagram in memory, i.e.,
362
+ :attr:`self._dtgram <_dtgram>` (if not, datagram
363
+ will be discarded after callback)
364
+
365
+ """
366
+
367
+ def __init_subclass__(cls, /, protocol: 'Optional[str]' = None, *args: 'Any', **kwargs: 'Any') -> 'None':
368
+ """Initialise subclass.
369
+
370
+ This method is to be used for registering the engine class to
371
+ :class:`~pcapkit.foundation.extraction.Extractor` class.
372
+
373
+ Args:
374
+ name: Protocol name, default to class name.
375
+ *args: Arbitrary positional arguments.
376
+ **kwargs: Arbitrary keyword arguments.
377
+
378
+ See Also:
379
+ For more details, please refer to
380
+ :meth:`pcapkit.foundation.extraction.Extractor.register_reassembly`.
381
+
382
+ """
383
+ if protocol is None:
384
+ protocol = cast('str', cls.name)
385
+
386
+ from pcapkit.foundation.extraction import Extractor
387
+ Extractor.register_reassembly(protocol.lower(), cls)
388
+
389
+ return super().__init_subclass__()
@@ -0,0 +1,249 @@
1
+ # -*- coding: utf-8 -*-
2
+ """TCP Datagram Reassembly
3
+ =============================
4
+
5
+ .. module:: pcapkit.foundation.reassembly.tcp
6
+
7
+ :mod:`pcapkit.foundation.reassembly.tcp` contains
8
+ :class:`~pcapkit.foundation.reassembly.reassembly.Reassembly` only,
9
+ which reconstructs fragmented TCP packets back to origin.
10
+
11
+ """
12
+ import sys
13
+ from typing import TYPE_CHECKING
14
+
15
+ from pcapkit.foundation.reassembly.data.tcp import (Buffer, BufferID, Datagram, DatagramID,
16
+ Fragment, HoleDiscriptor, Packet)
17
+ from pcapkit.foundation.reassembly.reassembly import ReassemblyBase as Reassembly
18
+ from pcapkit.protocols.transport.tcp import TCP as TCP_Protocol
19
+
20
+ if TYPE_CHECKING:
21
+ from typing import Type
22
+
23
+ __all__ = ['TCP']
24
+
25
+
26
+ class TCP(Reassembly[Packet, Datagram, BufferID, Buffer]):
27
+ """Reassembly for TCP payload.
28
+
29
+ Args:
30
+ strict: if return all datagrams (including those not
31
+ implemented) when submit
32
+ store: if store reassembled datagram in memory, i.e.,
33
+ :attr:`self._dtgram <pcapkit.foundation.reassembly.reassembly.Reassembly._dtgram>`
34
+ (if not, datagram will be discarded after callback)
35
+
36
+ Example:
37
+ >>> from pcapkit.foundation.reassembly import TCP
38
+ # Initialise instance:
39
+ >>> tcp_reassembly = TCP()
40
+ # Call reassembly:
41
+ >>> tcp_reassembly(packet_dict)
42
+ # Fetch result:
43
+ >>> result = tcp_reassembly.datagram
44
+
45
+ """
46
+ if TYPE_CHECKING:
47
+ protocol: 'Type[TCP_Protocol]'
48
+
49
+ ##########################################################################
50
+ # Defaults.
51
+ ##########################################################################
52
+
53
+ #: Protocol name of current reassembly object.
54
+ __protocol_name__ = 'TCP'
55
+ #: Protocol of current reassembly object.
56
+ __protocol_type__ = TCP_Protocol
57
+
58
+ ##########################################################################
59
+ # Methods.
60
+ ##########################################################################
61
+
62
+ def reassembly(self, info: 'Packet') -> 'None':
63
+ """Reassembly procedure.
64
+
65
+ Arguments:
66
+ info: :term:`info <reasm.tcp.packet>` dict of packets to be reassembled
67
+
68
+ """
69
+ # clear cache
70
+ self._flag_n = False
71
+ self.__cached__.clear()
72
+
73
+ BUFID = info.bufid # Buffer Identifier
74
+ DSN = info.dsn # Data Sequence Number
75
+ ACK = info.ack # Acknowledgement Number
76
+ FIN = info.fin # Finish Flag (Termination)
77
+ RST = info.rst # Reset Connection Flag (Termination)
78
+ SYN = info.syn # Synchronise Flag (Establishment)
79
+
80
+ # when SYN is set, reset buffer of existing session
81
+ if SYN and BUFID in self._buffer:
82
+ self._dtgram.extend(
83
+ self.submit(self._buffer.pop(BUFID), bufid=BUFID)
84
+ )
85
+
86
+ # initialise buffer with BUFID & ACK
87
+ if BUFID not in self._buffer:
88
+ self._buffer[BUFID] = Buffer(
89
+ hdl=[
90
+ HoleDiscriptor(
91
+ first=info.len,
92
+ last=sys.maxsize,
93
+ ),
94
+ ],
95
+ hdr=info.header if SYN else b'',
96
+ ack={
97
+ ACK: Fragment(
98
+ ind=[
99
+ info.num,
100
+ ],
101
+ isn=info.dsn,
102
+ len=info.len,
103
+ raw=info.payload,
104
+ ),
105
+ },
106
+ )
107
+ else:
108
+ # initialise buffer with ACK
109
+ if ACK not in self._buffer[BUFID].ack:
110
+ self._buffer[BUFID].ack[ACK] = Fragment(
111
+ ind=[
112
+ info.num,
113
+ ],
114
+ isn=info.dsn,
115
+ len=info.len,
116
+ raw=info.payload,
117
+ )
118
+ else:
119
+ # put header into header buffer
120
+ if SYN:
121
+ self._buffer[BUFID].__update__(hdr=info.header)
122
+
123
+ # append packet index
124
+ self._buffer[BUFID].ack[ACK].ind.append(info.num)
125
+
126
+ # record fragment payload
127
+ ISN = self._buffer[BUFID].ack[ACK].isn # Initial Sequence Number
128
+ RAW = self._buffer[BUFID].ack[ACK].raw # Raw Payload Data
129
+ if DSN >= ISN: # if fragment goes after existing payload
130
+ LEN = self._buffer[BUFID].ack[ACK].len
131
+ GAP = DSN - (ISN + LEN) # gap length between payloads
132
+ if GAP >= 0: # if fragment goes after existing payload
133
+ RAW += bytearray(GAP) + info.payload
134
+ else: # if fragment partially overlaps existing payload
135
+ RAW[DSN-ISN:] = info.payload
136
+ else: # if fragment exceeds existing payload
137
+ LEN = info.len
138
+ GAP = ISN - (DSN + LEN) # gap length between payloads
139
+ self._buffer[BUFID].ack[ACK].__update__(
140
+ isn=DSN,
141
+ )
142
+ if GAP >= 0: # if fragment exceeds existing payload
143
+ RAW = info.payload + bytearray(GAP) + RAW
144
+ else: # if fragment partially overlaps existing payload
145
+ RAW = info.payload + RAW[ISN-GAP:]
146
+ #self._buffer[BUFID].ack[ACK].raw = RAW # update payload datagram
147
+ #self._buffer[BUFID].ack[ACK].len = len(RAW) # update payload length
148
+ self._buffer[BUFID].ack[ACK].__update__(
149
+ raw=RAW, # update payload datagram
150
+ len=len(RAW), # update payload length
151
+ )
152
+
153
+ # update hole descriptor list
154
+ HDL = self._buffer[BUFID].hdl # HDL alias
155
+ for (index, hole) in enumerate(HDL): # step one
156
+ if info.first > hole.last: # step two
157
+ continue
158
+ if info.last < hole.first: # step three
159
+ continue
160
+ del HDL[index] # step four
161
+ if info.first > hole.first: # step five
162
+ new_hole = HoleDiscriptor(
163
+ first=hole.first,
164
+ last=info.first - 1,
165
+ )
166
+ HDL.insert(index, new_hole)
167
+ index += 1
168
+ if info.last < hole.last and not FIN and not RST: # step six
169
+ new_hole = HoleDiscriptor(
170
+ first=info.last + 1,
171
+ last=hole.last
172
+ )
173
+ HDL.insert(index, new_hole)
174
+ break # step seven
175
+ #self._buffer[BUFID].hdl = HDL # update HDL
176
+
177
+ # when FIN/RST is set, submit buffer of this session
178
+ if FIN or RST:
179
+ self._dtgram.extend(
180
+ self.submit(self._buffer.pop(BUFID), bufid=BUFID)
181
+ )
182
+
183
+ def submit(self, buf: 'Buffer', *, bufid: 'BufferID') -> 'list[Datagram]': # type: ignore[override] # pylint: disable=arguments-differ
184
+ """Submit reassembled payload.
185
+
186
+ Arguments:
187
+ buf: :term:`buffer <reasm.tcp.buffer>` dict of reassembled packets
188
+ bufid: buffer identifier
189
+
190
+ Returns:
191
+ Reassembled :term:`packets <reasm.tcp.datagram>`.
192
+
193
+ """
194
+ datagram = [] # type: list[Datagram] # reassembled datagram
195
+ HDL = buf.hdl # hole descriptor list
196
+
197
+ # check through every buffer with ACK
198
+ for (ack, buffer) in buf.ack.items():
199
+ # if this buffer is not implemented
200
+ # go through every hole and extract received payload
201
+ if len(HDL) > 2 and self._flag_s:
202
+ data = [] # type: list[bytes]
203
+ start = stop = 0
204
+ for hole in HDL:
205
+ stop = hole.first
206
+ byte = buffer.raw[start:stop]
207
+ start = hole.last
208
+ if byte: # strip empty payload
209
+ data.append(byte)
210
+ byte = buffer.raw[start:]
211
+ if byte: # strip empty payload
212
+ data.append(bytes(byte))
213
+ if data: # strip empty buffer
214
+ packet = Datagram(
215
+ completed=False,
216
+ id=DatagramID(
217
+ src=(bufid[0], bufid[1]),
218
+ dst=(bufid[2], bufid[3]),
219
+ ack=ack,
220
+ ),
221
+ index=tuple(buffer.ind),
222
+ header=buf.hdr,
223
+ payload=tuple(data),
224
+ packet=None,
225
+ )
226
+ datagram.append(packet)
227
+
228
+ # if this buffer is implemented
229
+ # export payload data & convert into bytes
230
+ else:
231
+ payload = buffer.raw
232
+ if payload: # strip empty buffer
233
+ packet = Datagram(
234
+ completed=True,
235
+ id=DatagramID(
236
+ src=(bufid[0], bufid[1]),
237
+ dst=(bufid[2], bufid[3]),
238
+ ack=ack,
239
+ ),
240
+ index=tuple(buffer.ind),
241
+ header=buf.hdr,
242
+ payload=bytes(payload),
243
+ packet=self.protocol.analyze((bufid[1], bufid[3]), bytes(payload)),
244
+ )
245
+ datagram.append(packet)
246
+
247
+ for callback in self.__callback_fn__:
248
+ callback(datagram)
249
+ return datagram
@@ -0,0 +1,41 @@
1
+ # -*- coding: utf-8 -*-
2
+ """Registry Management
3
+ =========================
4
+
5
+ .. module:: pcapkit.foundation.registry
6
+
7
+ This module provides the registry management for :mod:`pcapkit`, as the module
8
+ contains various registry points.
9
+
10
+ """
11
+
12
+ from pcapkit.foundation.registry.foundation import *
13
+ from pcapkit.foundation.registry.protocols import *
14
+
15
+ __all__ = [
16
+ 'register_extractor_engine',
17
+
18
+ 'register_dumper',
19
+ 'register_extractor_dumper', 'register_traceflow_dumper',
20
+
21
+ 'register_protocol',
22
+
23
+ 'register_linktype',
24
+ 'register_pcap', 'register_pcapng',
25
+
26
+ 'register_ethertype',
27
+
28
+ 'register_transtype',
29
+ 'register_ipv4_option', 'register_hip_parameter', 'register_hopopt_option',
30
+ 'register_ipv6_opts_option', 'register_ipv6_route_routing',
31
+ 'register_mh_message', 'register_mh_option', 'register_mh_extension',
32
+
33
+ 'register_apptype',
34
+ 'register_tcp', 'register_udp',
35
+ 'register_tcp_option', 'register_tcp_mp_option',
36
+
37
+ 'register_http_frame',
38
+
39
+ 'register_pcapng_block', 'register_pcapng_option', 'register_pcapng_secrets',
40
+ 'register_pcapng_record',
41
+ ]