pypcapkit 1.3.5.post6__pp310-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,251 @@
1
+ # -*- coding: utf-8 -*-
2
+ """PCAP-NG-NG Tools
3
+ ===================
4
+
5
+ .. module:: pcapkit.toolkit.pcapng
6
+
7
+ :mod:`pcapkit.toolkit.pcapng` contains all you need
8
+ for :mod:`pcapkit` handy usage of PCAP-NG-NG file format.
9
+ All functions returns with a flag to indicate if
10
+ usable for its caller.
11
+
12
+ """
13
+ from typing import TYPE_CHECKING, cast
14
+
15
+ from pcapkit.const.ipv6.extension_header import ExtensionHeader as Enum_ExtensionHeader
16
+ from pcapkit.foundation.reassembly.data.ip import Packet as IP_Packet
17
+ from pcapkit.foundation.reassembly.data.tcp import Packet as TCP_Packet
18
+ from pcapkit.foundation.traceflow.data.tcp import Packet as TF_TCP_Packet
19
+ from pcapkit.protocols.data.misc.pcap.frame import Frame as Data_Frame
20
+ from pcapkit.protocols.data.misc.pcap.frame import FrameInfo as Data_FrameInfo
21
+
22
+ if TYPE_CHECKING:
23
+ from ipaddress import IPv4Address, IPv6Address
24
+
25
+ from pcapkit.protocols.internet.ipv4 import IPv4
26
+ from pcapkit.protocols.internet.ipv6 import IPv6
27
+ from pcapkit.protocols.internet.ipv6_frag import IPv6_Frag
28
+ from pcapkit.protocols.misc.pcapng import PCAPNG, Packet
29
+ from pcapkit.protocols.transport.tcp import TCP
30
+
31
+ __all__ = ['ipv4_reassembly', 'ipv6_reassembly', 'tcp_reassembly',
32
+ 'tcp_traceflow', 'block2frame']
33
+
34
+
35
+ def ipv4_reassembly(frame: 'PCAPNG') -> 'IP_Packet[IPv4Address] | None':
36
+ """Make data for IPv4 reassembly.
37
+
38
+ Args:
39
+ frame: PCAP-NG frame.
40
+
41
+ Returns:
42
+ Data for IPv4 reassembly.
43
+
44
+ * If the ``frame`` can be used for IPv4 reassembly. A frame can be reassembled
45
+ if it contains IPv4 layer (:class:`~pcapkit.protocols.internet.ipv4.IPv4`) and
46
+ the **DF** (:attr:`IPv4.flags.df <pcapkit.protocols.data.internet.ipv4.Flags.df>`)
47
+ flag is :data:`False`.
48
+ * If the ``frame`` can be reassembled, then the :obj:`dict` mapping of data for IPv4
49
+ reassembly (c.f. :term:`reasm.ipv4.packet`) will be returned; otherwise, returns :data:`None`.
50
+
51
+ See Also:
52
+ :class:`pcapkit.foundation.reassembly.ipv4.IPv4`
53
+
54
+ """
55
+ if 'IPv4' in frame:
56
+ ipv4 = cast('IPv4', frame['IPv4'])
57
+ ipv4_info = ipv4.info
58
+ if ipv4_info.flags.df: # dismiss not fragmented frame
59
+ return None
60
+
61
+ frame_info = cast('Packet', frame.info)
62
+ data = IP_Packet(
63
+ bufid=(
64
+ ipv4_info.src, # source IP address
65
+ ipv4_info.dst, # destination IP address
66
+ ipv4_info.id, # identification
67
+ ipv4_info.protocol, # payload protocol type
68
+ ),
69
+ num=frame_info.number, # original packet range number
70
+ fo=ipv4_info.offset, # fragment offset
71
+ ihl=ipv4_info.hdr_len, # internet header length
72
+ mf=ipv4_info.flags.mf, # more fragment flag
73
+ tl=ipv4_info.len, # total length, header includes
74
+ header=ipv4.packet.header, # raw bytes type header
75
+ payload=bytearray(ipv4.packet.payload), # raw bytearray type payload
76
+ )
77
+ return data
78
+ return None
79
+
80
+
81
+ def ipv6_reassembly(frame: 'PCAPNG') -> 'IP_Packet[IPv6Address] | None':
82
+ """Make data for IPv6 reassembly.
83
+
84
+ Args:
85
+ frame: PCAP-NG frame.
86
+
87
+ Returns:
88
+ A tuple of data for IPv6 reassembly.
89
+
90
+ * If the ``frame`` can be used for IPv6 reassembly. A frame can be reassembled
91
+ if it contains IPv6 layer (:class:`~pcapkit.protocols.internet.ipv6.IPv6`) and
92
+ IPv6 Fragment header (:rfc:`2460#section-4.5`, i.e.,
93
+ :class:`~pcapkit.protocols.internet.ipv6_frag.IPv6_Frag`).
94
+ * If the ``frame`` can be reassembled, then the :obj:`dict` mapping of data for IPv6
95
+ reassembly (:term:`reasm.ipv6.packet`) will be returned; otherwise, returns :data:`None`.
96
+
97
+ See Also:
98
+ :class:`pcapkit.foundation.reassembly.ipv6.IPv6`
99
+
100
+ """
101
+ if 'IPv6' in frame:
102
+ ipv6 = cast('IPv6', frame['IPv6'])
103
+ ipv6_info = ipv6.info
104
+ if (ipv6_frag := ipv6.extension_headers.get( # type: ignore[call-overload]
105
+ Enum_ExtensionHeader.IPv6_Frag
106
+ )) is None: # dismiss not fragmented frame
107
+ return None
108
+ ipv6_frag_info = cast('IPv6_Frag', ipv6_frag).info
109
+
110
+ frame_info = cast('Packet', frame.info)
111
+ data = IP_Packet(
112
+ bufid=(
113
+ ipv6_info.src, # source IP address
114
+ ipv6_info.dst, # destination IP address
115
+ ipv6_info.label, # label
116
+ ipv6_frag_info.next, # next header field in IPv6 Fragment Header
117
+ ),
118
+ num=frame_info.number, # original packet range number
119
+ fo=ipv6_frag_info.offset, # fragment offset
120
+ ihl=ipv6_info.hdr_len, # header length, only headers before IPv6-Frag
121
+ mf=ipv6_frag_info.mf, # more fragment flag
122
+ tl=ipv6_info.hdr_len + ipv6_info.raw_len, # total length, header includes
123
+ header=ipv6_info.fragment.header, # raw bytearray type header before IPv6-Frag
124
+ payload=bytearray(ipv6_info.fragment.payload), # raw bytearray type payload after IPv6-Frag
125
+ )
126
+ return data
127
+ return None
128
+
129
+
130
+ def tcp_reassembly(frame: 'PCAPNG') -> 'TCP_Packet | None':
131
+ """Make data for TCP reassembly.
132
+
133
+ Args:
134
+ frame: PCAP-NG frame.
135
+
136
+ Returns:
137
+ A tuple of data for TCP reassembly.
138
+
139
+ * If the ``frame`` can be used for TCP reassembly. A frame can be reassembled
140
+ if it contains TCP layer (:class:`~pcapkit.protocols.transport.tcp.TCP`).
141
+ * If the ``frame`` can be reassembled, then the :obj:`dict` mapping of data for TCP
142
+ reassembly (:term:`reasm.tcp.packet`) will be returned; otherwise, returns :data:`None`.
143
+
144
+ See Also:
145
+ :class:`pcapkit.foundation.reassembly.tcp.TCP`
146
+
147
+ """
148
+ if 'TCP' in frame:
149
+ ip = cast('IPv4 | IPv6', frame['IP'])
150
+ ip_info = ip.info
151
+ tcp = cast('TCP', frame['TCP'])
152
+ tcp_info = tcp.info
153
+
154
+ raw_len = len(tcp.packet.payload)
155
+ frame_info = cast('Packet', frame.info)
156
+
157
+ data = TCP_Packet(
158
+ bufid=(
159
+ ip_info.src, # source IP address
160
+ tcp_info.srcport.port, # source port
161
+ ip_info.dst, # destination IP address
162
+ tcp_info.dstport.port, # destination port
163
+ ),
164
+ num=frame_info.number, # original packet range number
165
+ ack=tcp_info.ack, # acknowledgement
166
+ dsn=tcp_info.seq, # data sequence number
167
+ syn=tcp_info.flags.syn, # synchronise flag
168
+ fin=tcp_info.flags.fin, # finish flag
169
+ rst=tcp_info.flags.rst, # reset connection flag
170
+ header=tcp.packet.header, # raw bytes type header
171
+ payload=bytearray(tcp.packet.payload), # raw bytearray type payload
172
+ first=tcp_info.seq, # this sequence number
173
+ last=tcp_info.seq + raw_len, # next (wanted) sequence number
174
+ len=raw_len, # payload length, header excludes
175
+ )
176
+ return data
177
+ return None
178
+
179
+
180
+ def tcp_traceflow(frame: 'PCAPNG', *, nanosecond: 'bool' = False) -> 'TF_TCP_Packet | None':
181
+ """Trace packet flow for TCP.
182
+
183
+ Args:
184
+ frame: PCAP-NG frame.
185
+ nanosecond: Whether to use nanosecond precision.
186
+
187
+ Returns:
188
+ Data for TCP reassembly.
189
+
190
+ * If the ``packet`` can be used for TCP flow tracing. A frame can be reassembled
191
+ if it contains TCP layer (:class:`~pcapkit.protocols.transport.tcp.TCP`).
192
+ * If the ``frame`` can be reassembled, then the :obj:`dict` mapping of data for TCP
193
+ flow tracing (:term:`trace.tcp.packet`) will be returned; otherwise, returns :data:`None`.
194
+
195
+ See Also:
196
+ :class:`pcapkit.foundation.traceflow.tcp.TCP`
197
+
198
+ """
199
+ if 'TCP' in frame:
200
+ ip = cast('IPv4 | IPv6', frame['IP'])
201
+ ip_info = ip.info
202
+ tcp = cast('TCP', frame['TCP'])
203
+ tcp_info = tcp.info
204
+
205
+ frame_info = cast('Packet', frame.info)
206
+ data = TF_TCP_Packet( # type: ignore[type-var]
207
+ protocol=frame.linktype, # data link type from global header
208
+ index=frame_info.number, # frame number
209
+ frame=block2frame(frame_info, nanosecond=nanosecond),
210
+ # extracted frame info
211
+ syn=tcp_info.flags.syn, # TCP synchronise (SYN) flag
212
+ fin=tcp_info.flags.fin, # TCP finish (FIN) flag
213
+ src=ip_info.src, # source IP
214
+ dst=ip_info.dst, # destination IP
215
+ srcport=tcp_info.srcport.port, # TCP source port
216
+ dstport=tcp_info.dstport.port, # TCP destination port
217
+ timestamp=float(frame_info.timestamp_epoch), # frame timestamp
218
+ )
219
+ return data
220
+ return None
221
+
222
+
223
+ def block2frame(block: 'Packet', *, nanosecond: 'bool' = False) -> 'Data_Frame':
224
+ """Convert PCAP-NG block to PCAP frame.
225
+
226
+ Args:
227
+ block: PCAP-NG block.
228
+ nanosecond: Whether to use nanosecond precision.
229
+
230
+ Returns:
231
+ PCAP frame.
232
+
233
+ """
234
+ ts_sec = int(block.timestamp_epoch)
235
+ ts_usec = int(block.timestamp_epoch - ts_sec) * (1_000_000_000 if nanosecond else 1_000_000)
236
+
237
+ frame = Data_Frame(
238
+ frame_info=Data_FrameInfo(
239
+ ts_sec=ts_sec,
240
+ ts_usec=ts_usec,
241
+ incl_len=block.captured_len,
242
+ orig_len=block.original_len,
243
+ ),
244
+ time=block.timestamp,
245
+ number=block.number,
246
+ time_epoch=block.timestamp_epoch,
247
+ len=block.original_len,
248
+ cap_len=block.captured_len,
249
+ )
250
+ frame.__update__(packet=block.packet)
251
+ return frame
@@ -0,0 +1,99 @@
1
+ # -*- coding: utf-8 -*-
2
+ """PyShark Tools
3
+ ===================
4
+
5
+ :mod:`pcapkit.toolkit.pyshark` contains all you need for
6
+ :mod:`pcapkit` handy usage with `PyShark`_ engine. All
7
+ reforming functions returns with a flag to indicate if
8
+ usable for its caller.
9
+
10
+ .. _PyShark: https://kiminewt.github.io/pyshark
11
+
12
+ .. note::
13
+
14
+ Due to the lack of functionality of `PyShark`_, some
15
+ functions of :mod:`pcapkit` may not be available with
16
+ the `PyShark`_ engine.
17
+
18
+ """
19
+ import ipaddress
20
+ from typing import TYPE_CHECKING, cast
21
+
22
+ from pcapkit.const.reg.linktype import LinkType as Enum_LinkType
23
+ from pcapkit.foundation.traceflow.data.tcp import Packet as TF_TCP_Packet
24
+
25
+ if TYPE_CHECKING:
26
+ from typing import Any
27
+
28
+ from pyshark.packet.packet import Packet
29
+
30
+ __all__ = ['packet2dict', 'tcp_traceflow']
31
+
32
+
33
+ def packet2dict(packet: 'Packet') -> 'dict[str, Any]':
34
+ """Convert PyShark packet into :obj:`dict`.
35
+
36
+ Args:
37
+ packet: Scapy packet.
38
+
39
+ Returns:
40
+ A :obj:`dict` mapping of packet data.
41
+
42
+ """
43
+ dict_ = {} # type: dict[str, Any]
44
+ frame = packet.frame_info
45
+ for field in frame.field_names:
46
+ dict_[field] = getattr(frame, field)
47
+
48
+ tempdict = dict_
49
+ for layer in packet.layers:
50
+ tempdict[layer.layer_name.upper()] = {}
51
+ tempdict = tempdict[layer.layer_name.upper()]
52
+ for field in layer.field_names:
53
+ tempdict[field] = getattr(layer, field)
54
+
55
+ return dict_
56
+
57
+
58
+ def tcp_traceflow(packet: 'Packet') -> 'TF_TCP_Packet | None':
59
+ """Trace packet flow for TCP.
60
+
61
+ Args:
62
+ packet: Scapy packet.
63
+
64
+ Returns:
65
+ Tuple[bool, Dict[str, Any]]: A tuple of data for TCP reassembly.
66
+
67
+ * If the ``packet`` can be used for TCP flow tracing. A packet can be reassembled
68
+ if it contains TCP layer.
69
+ * If the ``packet`` can be reassembled, then the :obj:`dict` mapping of data for TCP
70
+ flow tracing (:term:`trace.tcp.packet`) will be returned; otherwise, returns :data:`None`.
71
+
72
+ See Also:
73
+ :class:`pcapkit.foundation.traceflow.tcp.TCP`
74
+
75
+ """
76
+ if 'IP' in packet:
77
+ ip = cast('Packet', packet.ip)
78
+ elif 'IPv6' in packet:
79
+ ip = cast('Packet', packet.ipv6)
80
+ else:
81
+ return None
82
+
83
+ if 'TCP' in packet:
84
+ tcp = cast('Packet', packet.tcp)
85
+
86
+ data = TF_TCP_Packet( # type: ignore[type-var]
87
+ protocol=Enum_LinkType.get(packet.layers[0].layer_name.upper()), # data link type from global header
88
+ index=int(packet.number), # frame number
89
+ frame=packet2dict(packet), # extracted packet
90
+ syn=bool(int(tcp.flags_syn)), # TCP synchronise (SYN) flag
91
+ fin=bool(int(tcp.flags_fin)), # TCP finish (FIN) flag
92
+ src=ipaddress.ip_address(ip.src), # source IP
93
+ dst=ipaddress.ip_address(ip.dst), # destination IP
94
+ srcport=int(tcp.srcport), # TCP source port
95
+ dstport=int(tcp.dstport), # TCP destination port
96
+ timestamp=packet.frame_info.time_epoch, # timestamp
97
+ )
98
+ return data
99
+ return None
@@ -0,0 +1,297 @@
1
+ # -*- coding: utf-8 -*-
2
+ """Scapy Tools
3
+ =================
4
+
5
+ .. module:: pcapkit.toolkit.scapy
6
+
7
+ :mod:`pcapkit.toolkit.scapy` contains all you need for
8
+ :mod:`pcapkit` handy usage with `Scapy`_ engine. All reforming
9
+ functions returns with a flag to indicate if usable for
10
+ its caller.
11
+
12
+ .. _Scapy: https://scapy.net
13
+
14
+ .. warning::
15
+
16
+ This module requires installed `Scapy`_ engine.
17
+
18
+ """
19
+ import ipaddress
20
+ import time
21
+ from typing import TYPE_CHECKING, cast
22
+
23
+ from pcapkit.const.reg.linktype import LinkType as Enum_LinkType
24
+ from pcapkit.const.reg.transtype import TransType as Enum_TransType
25
+ from pcapkit.foundation.reassembly.data.ip import Packet as IP_Packet
26
+ from pcapkit.foundation.reassembly.data.tcp import Packet as TCP_Packet
27
+ from pcapkit.foundation.traceflow.data.tcp import Packet as TF_TCP_Packet
28
+ from pcapkit.utilities.compat import ModuleNotFoundError # pylint: disable=redefined-builtin
29
+ from pcapkit.utilities.exceptions import ModuleNotFound, stacklevel
30
+ from pcapkit.utilities.warnings import ScapyWarning, warn
31
+
32
+ try:
33
+ import scapy
34
+ except ModuleNotFoundError:
35
+ scapy = None
36
+ warn("dependency package 'Scapy' not found",
37
+ ScapyWarning, stacklevel=stacklevel())
38
+
39
+ if TYPE_CHECKING:
40
+ from ipaddress import IPv4Address, IPv6Address
41
+ from typing import Any
42
+
43
+ from scapy.layers.inet import IP, TCP
44
+ from scapy.layers.inet6 import IPv6
45
+ from scapy.packet import Packet
46
+
47
+ __all__ = [
48
+ 'packet2chain', 'packet2dict',
49
+ 'ipv4_reassembly', 'ipv6_reassembly', 'tcp_reassembly', 'tcp_traceflow'
50
+ ]
51
+
52
+
53
+ def packet2chain(packet: 'Packet') -> 'str':
54
+ """Fetch Scapy packet protocol chain.
55
+
56
+ Args:
57
+ packet: Scapy packet.
58
+
59
+ Returns:
60
+ Colon (``:``) seperated list of protocol chain.
61
+
62
+ Raises:
63
+ ModuleNotFound: If `Scapy`_ is not installed.
64
+
65
+ """
66
+ if scapy is None:
67
+ raise ModuleNotFound("No module named 'scapy'", name='scapy')
68
+ from scapy.packet import NoPayload
69
+
70
+ chain = [packet.name]
71
+ payload = packet.payload
72
+ while not isinstance(payload, NoPayload):
73
+ chain.append(payload.name)
74
+ payload = payload.payload
75
+ return ':'.join(chain)
76
+
77
+
78
+ def packet2dict(packet: 'Packet') -> 'dict[str, Any]':
79
+ """Convert Scapy packet into :obj:`dict`.
80
+
81
+ Args:
82
+ packet: Scapy packet.
83
+
84
+ Returns:
85
+ A :obj:`dict` mapping of packet data.
86
+
87
+ Raises:
88
+ ModuleNotFound: If `Scapy`_ is not installed.
89
+
90
+ """
91
+ if scapy is None:
92
+ raise ModuleNotFound("No module named 'scapy'", name='scapy')
93
+ from scapy.packet import NoPayload
94
+
95
+ def wrapper(packet: 'Packet') -> 'dict[str, Any]':
96
+ dict_ = packet.fields
97
+ payload = packet.payload
98
+ if not isinstance(payload, NoPayload):
99
+ dict_[payload.name] = wrapper(payload)
100
+ return dict_
101
+
102
+ return {
103
+ 'packet': bytes(packet),
104
+ packet.name: wrapper(packet),
105
+ }
106
+
107
+
108
+ def ipv4_reassembly(packet: 'Packet', *, count: 'int' = -1) -> 'IP_Packet[IPv4Address] | None':
109
+ """Make data for IPv4 reassembly.
110
+
111
+ Args:
112
+ packet: Scapy packet.
113
+ count: Packet index. If not provided, default to ``-1``.
114
+
115
+ Returns:
116
+ Data for IPv4 reassembly.
117
+
118
+ * If the ``packet`` can be used for IPv4 reassembly. A packet can be reassembled
119
+ if it contains IPv4 layer (:class:`scapy.layers.inet.IP`) and the **DF**
120
+ (:attr:`scapy.layers.inet.IP.flags.DF`) flag is :data:`False`.
121
+ * If the ``packet`` can be reassembled, then the :obj:`dict` mapping of data for IPv4
122
+ reassembly (:term:`reasm.ipv4.packet`) will be returned; otherwise, returns :data:`None`.
123
+
124
+ See Also:
125
+ :class:`pcapkit.foundation.reassembly.ipv4.IPv4`
126
+
127
+ """
128
+ if 'IP' in packet:
129
+ ipv4 = cast('IP', packet['IP'])
130
+ if ipv4.flags.DF: # dismiss not fragmented packet
131
+ return None
132
+
133
+ data = IP_Packet(
134
+ bufid=(
135
+ cast('IPv4Address',
136
+ ipaddress.ip_address(ipv4.src)), # source IP address
137
+ cast('IPv4Address',
138
+ ipaddress.ip_address(ipv4.dst)), # destination IP address
139
+ ipv4.id, # identification
140
+ Enum_TransType.get(ipv4.proto), # payload protocol type
141
+ ),
142
+ num=count, # original packet range number
143
+ fo=ipv4.frag, # fragment offset
144
+ ihl=ipv4.ihl, # internet header length
145
+ mf=bool(ipv4.flags.MF), # more fragment flag
146
+ tl=ipv4.len, # total length, header includes
147
+ header=ipv4.raw_packet_cache, # raw bytes type header
148
+ payload=bytearray(bytes(ipv4.payload)), # raw bytearray type payload
149
+ )
150
+ return data
151
+ return None
152
+
153
+
154
+ def ipv6_reassembly(packet: 'Packet', *, count: 'int' = -1) -> 'IP_Packet[IPv6Address] | None':
155
+ """Make data for IPv6 reassembly.
156
+
157
+ Args:
158
+ packet: Scapy packet.
159
+ count: Packet index. If not provided, default to ``-1``.
160
+
161
+ Returns:
162
+ Data for IPv6 reassembly.
163
+
164
+ * If the ``packet`` can be used for IPv6 reassembly. A packet can be reassembled
165
+ if it contains IPv6 layer (:class:`scapy.layers.inet6.IPv6`) and IPv6 Fragment
166
+ header (:rfc:`2460#section-4.5`, i.e., :class:`scapy.layers.inet6.IPv6ExtHdrFragment`).
167
+ * If the ``packet`` can be reassembled, then the :obj:`dict` mapping of data for IPv6
168
+ reassembly (:term:`reasm.ipv6.packet`) will be returned; otherwise, returns :data:`None`.
169
+
170
+ Raises:
171
+ ModuleNotFound: If `Scapy`_ is not installed.
172
+
173
+ See Also:
174
+ :class:`pcapkit.foundation.reassembly.ipv6.IPv6`
175
+
176
+ """
177
+ if scapy is None:
178
+ raise ModuleNotFound("No module named 'scapy'", name='scapy')
179
+ from scapy.layers.inet6 import IPv6ExtHdrFragment
180
+
181
+ if 'IPv6' in packet:
182
+ ipv6 = cast('IPv6', packet['IPv6'])
183
+ if IPv6ExtHdrFragment not in ipv6: # pylint: disable=E1101
184
+ return None # dismiss not fragmented packet
185
+ ipv6_frag = cast('IPv6ExtHdrFragment', ipv6['IPv6ExtHdrFragment'])
186
+
187
+ data = IP_Packet(
188
+ bufid=(
189
+ cast('IPv6Address',
190
+ ipaddress.ip_address(ipv6.src)), # source IP address
191
+ cast('IPv6Address',
192
+ ipaddress.ip_address(ipv6.dst)), # destination IP address
193
+ ipv6.fl, # label
194
+ Enum_TransType.get(ipv6_frag.nh), # next header field in IPv6 Fragment Header
195
+ ),
196
+ num=count, # original packet range number
197
+ fo=ipv6_frag.offset, # fragment offset
198
+ ihl=len(ipv6) - len(ipv6_frag), # header length, only headers before IPv6-Frag
199
+ mf=bool(ipv6_frag.m), # more fragment flag
200
+ tl=len(ipv6), # total length, header includes
201
+ header=bytes(ipv6)[:-len(ipv6_frag)], # raw bytes type header before IPv6-Frag
202
+ payload=bytearray(bytes(ipv6_frag.payload)), # raw bytearray type payload after IPv6-Frag
203
+ )
204
+ return data
205
+ return None
206
+
207
+
208
+ def tcp_reassembly(packet: 'Packet', *, count: 'int' = -1) -> 'TCP_Packet | None':
209
+ """Store data for TCP reassembly.
210
+
211
+ Args:
212
+ packet: Scapy packet.
213
+ count: Packet index. If not provided, default to ``-1``.
214
+
215
+ Returns:
216
+ Data for TCP reassembly.
217
+
218
+ * If the ``packet`` can be used for TCP reassembly. A packet can be reassembled
219
+ if it contains TCP layer (:class:`scapy.layers.inet.TCP`).
220
+ * If the ``packet`` can be reassembled, then the :obj:`dict` mapping of data for TCP
221
+ reassembly (:term:`reasm.tcp.packet`) will be returned; otherwise, returns :data:`None`.
222
+
223
+ See Also:
224
+ :class:`pcapkit.foundation.reassembly.tcp.TCP`
225
+
226
+ """
227
+ if 'IP' in packet:
228
+ ip = cast('IP', packet['IP'])
229
+ elif 'IPv6' in packet:
230
+ ip = cast('IPv6', packet['IPv6'])
231
+ else:
232
+ return None
233
+
234
+ if 'TCP' in packet:
235
+ tcp = cast('TCP', packet['TCP'])
236
+
237
+ raw_len = len(tcp.payload) # payload length, header excludes
238
+ data = TCP_Packet(
239
+ bufid=(
240
+ ipaddress.ip_address(ip.src), # source IP address
241
+ tcp.sport, # source port
242
+ ipaddress.ip_address(ip.dst), # destination IP address
243
+ tcp.dport, # destination port
244
+ ),
245
+ num=count, # original packet range number
246
+ ack=tcp.ack, # acknowledgement
247
+ dsn=tcp.seq, # data sequence number
248
+ syn=bool(tcp.flags.S), # synchronise flag
249
+ fin=bool(tcp.flags.F), # finish flag
250
+ rst=bool(tcp.flags.R), # reset connection flag
251
+ header=tcp.raw_packet_cache, # raw bytes type header
252
+ payload=bytearray(bytes(tcp.payload)), # raw bytearray type payload
253
+ first=tcp.seq, # this sequence number
254
+ last=tcp.seq + raw_len, # next (wanted) sequence number
255
+ len=raw_len, # payload length, header excludes
256
+ )
257
+ return data
258
+ return None
259
+
260
+
261
+ def tcp_traceflow(packet: 'Packet', *, count: 'int' = -1) -> 'TF_TCP_Packet | None':
262
+ """Trace packet flow for TCP.
263
+
264
+ Args:
265
+ packet: Scapy packet.
266
+ count: Packet index. If not provided, default to ``-1``.
267
+
268
+ Returns:
269
+ Data for TCP reassembly.
270
+
271
+ * If the ``packet`` can be used for TCP flow tracing. A packet can be reassembled
272
+ if it contains TCP layer (:class:`scapy.layers.inet.TCP`).
273
+ * If the ``packet`` can be reassembled, then the :obj:`dict` mapping of data for TCP
274
+ flow tracing (:term:`trace.tcp.packet`) will be returned; otherwise, returns :data:`None`.
275
+
276
+ See Also:
277
+ :class:`pcapkit.foundation.traceflow.tcp.TCP`
278
+
279
+ """
280
+ if 'TCP' in packet:
281
+ ip = cast('IP', packet['IP']) if 'IP' in packet else cast('IPv6', packet['IPv6'])
282
+ tcp = cast('TCP', packet['TCP'])
283
+
284
+ data = TF_TCP_Packet( # type: ignore[type-var]
285
+ protocol=Enum_LinkType.get(packet.name.upper()), # data link type from global header
286
+ index=count, # frame number
287
+ frame=packet2dict(packet), # extracted packet
288
+ syn=bool(tcp.flags.S), # TCP synchronise (SYN) flag
289
+ fin=bool(tcp.flags.F), # TCP finish (FIN) flag
290
+ src=ipaddress.ip_address(ip.src), # source IP
291
+ dst=ipaddress.ip_address(ip.dst), # destination IP
292
+ srcport=tcp.sport, # TCP source port
293
+ dstport=tcp.dport, # TCP destination port
294
+ timestamp=time.time(), # timestamp
295
+ )
296
+ return data
297
+ return None
@@ -0,0 +1,20 @@
1
+ # -*- coding: utf-8 -*-
2
+ # pylint: disable=unused-wildcard-import
3
+ """Module Utilities
4
+ ======================
5
+
6
+ .. module:: pcapkit.utilities
7
+
8
+ :mod:`pcapkit.utilities` contains several useful functions
9
+ and classes which are fundations of :mod:`pcapkit`, including
10
+ decorater function :func:`~pcapkit.utilities.decorators.seekset`
11
+ and :func:`~pcapkit.utilities.decorators.beholder`, etc., and
12
+ several user-refined exceptions and warnings.
13
+
14
+ """
15
+ from pcapkit.utilities.decorators import beholder, prepare, seekset
16
+ from pcapkit.utilities.exceptions import stacklevel
17
+ from pcapkit.utilities.logging import logger
18
+ from pcapkit.utilities.warnings import warn
19
+
20
+ __all__ = ['logger', 'warn', 'stacklevel']