pypcapkit 1.3.5.post6__cp312-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,188 @@
1
+ # -*- coding: utf-8 -*-
2
+ """PCAP Support
3
+ ==================
4
+
5
+ .. module:: pcapkit.foundation.engines.pcap
6
+
7
+ This module contains the implementation for PCAP file extraction
8
+ support, as is used by :class:`pcapkit.foundation.extraction.Extractor`.
9
+
10
+ """
11
+ from typing import TYPE_CHECKING
12
+
13
+ from pcapkit.foundation.engines.engine import EngineBase as Engine
14
+ from pcapkit.protocols.misc.pcap.frame import Frame
15
+ from pcapkit.protocols.misc.pcap.header import Header
16
+
17
+ __all__ = ['PCAP']
18
+
19
+ if TYPE_CHECKING:
20
+ from pcapkit.const.reg.linktype import LinkType as Enum_LinkType
21
+ from pcapkit.corekit.version import VersionInfo
22
+
23
+
24
+ class PCAP(Engine[Frame]):
25
+ """PCAP file extraction support.
26
+
27
+ Args:
28
+ extractor: :class:`~pcapkit.foundation.extraction.Extractor` instance.
29
+
30
+ """
31
+
32
+ if TYPE_CHECKING:
33
+ #: Global header.
34
+ _gbhdr: 'Header'
35
+ #: Version info.
36
+ _vinfo: 'VersionInfo'
37
+ #: Data link layer protocol.
38
+ _dlink: 'Enum_LinkType'
39
+ #: Nanosecond flag.
40
+ _nnsec: 'bool'
41
+
42
+ MAGIC_NUMBER = (
43
+ b'\xa1\xb2\x3c\x4d',
44
+ b'\xa1\xb2\xc3\xd4',
45
+ b'\x4d\x3c\xb2\xa1',
46
+ b'\xd4\xc3\xb2\xa1',
47
+ )
48
+
49
+ ##########################################################################
50
+ # Defaults.
51
+ ##########################################################################
52
+
53
+ #: Engine name.
54
+ __engine_name__ = 'PCAP'
55
+
56
+ #: Engine module name.
57
+ __engine_module__ = 'pcapkit.protocols.misc.pcap'
58
+
59
+ ##########################################################################
60
+ # Properties.
61
+ ##########################################################################
62
+
63
+ @property
64
+ def header(self) -> 'Header':
65
+ """Global header."""
66
+ return self._gbhdr
67
+
68
+ @property
69
+ def version(self) -> 'VersionInfo':
70
+ """Version of input PCAP file."""
71
+ return self._vinfo
72
+
73
+ @property
74
+ def dlink(self) -> 'Enum_LinkType':
75
+ """Data link layer protocol."""
76
+ return self._dlink
77
+
78
+ @property
79
+ def nanosecond(self) -> 'bool':
80
+ """Nanosecond flag."""
81
+ return self._nnsec
82
+
83
+ ##########################################################################
84
+ # Methods.
85
+ ##########################################################################
86
+
87
+ def run(self) -> 'None':
88
+ """Start extraction.
89
+
90
+ This method is the entry point for PCAP file extraction. It will start
91
+ the extraction process by parsing the PCAP global header and then halt
92
+ the extraction process until the
93
+ :meth:`self.extractor.record_frames <pcapkit.foundation.extraction.Extractor.record_frames>`
94
+ method is called.
95
+
96
+ The method will parse the PCAP global header and save the parsed result
97
+ as :attr:`self.header <header>`. Information such as PCAP version, data
98
+ link layer protocol type, nanosecond flag and byteorder will also be
99
+ save the current :class:`PCAP` engine instance.
100
+
101
+ For output, the method will dump the parsed PCAP global header under
102
+ the name of ``Global Header``.
103
+
104
+ """
105
+ # pylint: disable=attribute-defined-outside-init,protected-access
106
+ ext = self._extractor
107
+
108
+ self._gbhdr = Header(ext._ifile)
109
+ self._vinfo = self._gbhdr.version
110
+ self._dlink = self._gbhdr.protocol
111
+ self._nnsec = self._gbhdr.nanosecond
112
+
113
+ if ext._flag_q:
114
+ return
115
+
116
+ if ext._flag_f:
117
+ ofile = ext._ofile(f'{ext._ofnm}/Global Header.{ext._fext}')
118
+ ofile(self._gbhdr.info.to_dict(), name='Global Header')
119
+ else:
120
+ ext._ofile(self._gbhdr.info.to_dict(), name='Global Header')
121
+ ofile = ext._ofile
122
+ ext._offmt = ofile.kind
123
+
124
+ def read_frame(self) -> 'Frame':
125
+ """Read frames.
126
+
127
+ This method performs following operations:
128
+
129
+ - extract frames and each layer of packets;
130
+ - make :class:`~pcapkit.corekit.infoclass.Info` object out of frame properties;
131
+ - write to output file with corresponding dumper;
132
+ - reassemble IP and/or TCP datagram;
133
+ - trace TCP flows if any;
134
+ - record frame :class:`~pcapkit.corekit.infoclass.Info` object to frame storage.
135
+
136
+ Returns:
137
+ Parsed frame instance.
138
+
139
+ """
140
+ from pcapkit.toolkit.pcap import (ipv4_reassembly, ipv6_reassembly, tcp_reassembly,
141
+ tcp_traceflow)
142
+ ext = self._extractor
143
+
144
+ # read frame header
145
+ frame = Frame(ext._ifile, num=ext._frnum+1, header=self._gbhdr.info,
146
+ layer=ext._exlyr, protocol=ext._exptl, nanosecond=self._nnsec)
147
+ ext._frnum += 1
148
+
149
+ # verbose output
150
+ ext._vfunc(ext, frame)
151
+
152
+ # write plist
153
+ frnum = f'Frame {ext._frnum}'
154
+ if not ext._flag_q:
155
+ if ext._flag_f:
156
+ ofile = ext._ofile(f'{ext._ofnm}/{frnum}.{ext._fext}')
157
+ ofile(frame.info.to_dict(), name=frnum)
158
+ else:
159
+ ext._ofile(frame.info.to_dict(), name=frnum)
160
+
161
+ # record fragments
162
+ if ext._flag_r:
163
+ if ext._ipv4:
164
+ data_ipv4 = ipv4_reassembly(frame)
165
+ if data_ipv4 is not None:
166
+ ext._reasm.ipv4(data_ipv4)
167
+ if ext._ipv6:
168
+ data_ipv6 = ipv6_reassembly(frame)
169
+ if data_ipv6 is not None:
170
+ ext._reasm.ipv6(data_ipv6)
171
+ if ext._tcp:
172
+ data_tcp = tcp_reassembly(frame)
173
+ if data_tcp is not None:
174
+ ext._reasm.tcp(data_tcp)
175
+
176
+ # trace flows
177
+ if ext._flag_t:
178
+ if ext._tcp:
179
+ data_tf_tcp = tcp_traceflow(frame, data_link=self._dlink)
180
+ if data_tf_tcp is not None:
181
+ ext._trace.tcp(data_tf_tcp)
182
+
183
+ # record frames
184
+ if ext._flag_d:
185
+ ext._frame.append(frame)
186
+
187
+ # return frame record
188
+ return frame
@@ -0,0 +1,310 @@
1
+ # -*- coding: utf-8 -*-
2
+ """PCAP-NG Support
3
+ =====================
4
+
5
+ .. module:: pcapkit.foundation.engines.pcapng
6
+
7
+ This module contains the implementation for PCAP-NG file extraction
8
+ support, as is used by :class:`pcapkit.foundation.extraction.Extractor`.
9
+
10
+ """
11
+ from logging import warn
12
+ from typing import TYPE_CHECKING, cast
13
+
14
+ from pcapkit.const.pcapng.block_type import BlockType as Enum_BlockType
15
+ from pcapkit.corekit.infoclass import Info, info_final
16
+ from pcapkit.foundation.engines.engine import EngineBase as Engine
17
+ from pcapkit.protocols.misc.pcapng import PCAPNG as P_PCAPNG
18
+ from pcapkit.utilities.exceptions import FormatError, stacklevel
19
+ from pcapkit.utilities.warnings import DeprecatedFormatWarning
20
+
21
+ __all__ = ['PCAPNG']
22
+
23
+ if TYPE_CHECKING:
24
+ from pcapkit.foundation.extraction import Extractor
25
+ from pcapkit.protocols.data.misc.pcapng import PCAPNG as Data_PCAPNG
26
+ from pcapkit.protocols.data.misc.pcapng import CustomBlock as Data_CustomBlock
27
+ from pcapkit.protocols.data.misc.pcapng import \
28
+ DecryptionSecretsBlock as Data_DecryptionSecretsBlock
29
+ from pcapkit.protocols.data.misc.pcapng import EnhancedPacketBlock as Data_EnhancedPacketBlock
30
+ from pcapkit.protocols.data.misc.pcapng import \
31
+ InterfaceDescriptionBlock as Data_InterfaceDescriptionBlock
32
+ from pcapkit.protocols.data.misc.pcapng import \
33
+ InterfaceStatisticsBlock as Data_InterfaceStatisticsBlock
34
+ from pcapkit.protocols.data.misc.pcapng import NameResolutionBlock as Data_NameResolutionBlock
35
+ from pcapkit.protocols.data.misc.pcapng import PacketBlock as Data_PacketBlock
36
+ from pcapkit.protocols.data.misc.pcapng import SectionHeaderBlock as Data_SectionHeaderBlock
37
+ from pcapkit.protocols.data.misc.pcapng import \
38
+ SystemdJournalExportBlock as Data_SystemdJournalExportBlock
39
+ from pcapkit.protocols.data.misc.pcapng import UnknownBlock as Data_UnknownBlock
40
+
41
+
42
+ @info_final
43
+ class Context(Info):
44
+ """Context manager for PCAP-NG file format."""
45
+
46
+ #: Section header.
47
+ section: 'Data_SectionHeaderBlock'
48
+
49
+ def __post_init__(self) -> None:
50
+ """Post initialisation hook."""
51
+ self.__update__(
52
+ interfaces=[],
53
+ #packets=[],
54
+ names=[],
55
+ journals=[],
56
+ secrets=[],
57
+ custom=[],
58
+ statistics=[],
59
+ unknown=[],
60
+ )
61
+
62
+ if TYPE_CHECKING:
63
+ #: Interface descriptions.
64
+ interfaces: 'list[Data_InterfaceDescriptionBlock]'
65
+ #: Packets.
66
+ #packets: 'list[Data_PacketBlock | Data_SimplePacketBlock | Data_EnhancedPacketBlock]'
67
+ #: Name resolution records.
68
+ names: 'list[Data_NameResolutionBlock]'
69
+ #: :manpage:`systemd(1)` journal export records.
70
+ journals: 'list[Data_SystemdJournalExportBlock]'
71
+ #: Decryption secrets.
72
+ secrets: 'list[Data_DecryptionSecretsBlock]'
73
+ #: Custom blocks.
74
+ custom: 'list[Data_CustomBlock]'
75
+ #: Interface statistics.
76
+ statistics: 'list[Data_InterfaceStatisticsBlock]'
77
+ #: Unknown blocks.
78
+ unknown: 'list[Data_UnknownBlock]'
79
+
80
+ def __init__(self, section: 'Data_SectionHeaderBlock') -> 'None': ...
81
+
82
+
83
+ class PCAPNG(Engine[P_PCAPNG]):
84
+ """PCAP-NG file extraction support.
85
+
86
+ Args:
87
+ extractor: :class:`~pcapkit.foundation.extraction.Extractor` instance.
88
+
89
+ """
90
+ if TYPE_CHECKING:
91
+ #: Current context.
92
+ _ctx: 'Context'
93
+ #: File context storage.
94
+ _ctx_list: 'list[Context]'
95
+
96
+ MAGIC_NUMBER = (
97
+ b'\x0a\x0d\x0d\x0a',
98
+ )
99
+
100
+ ##########################################################################
101
+ # Defaults.
102
+ ##########################################################################
103
+
104
+ #: Engine name.
105
+ __engine_name__ = 'PCAP-NG'
106
+
107
+ #: Engine module name.
108
+ __engine_module__ = 'pcapkit.protocols.misc.pcapng'
109
+
110
+ ##########################################################################
111
+ # Data models.
112
+ ##########################################################################
113
+
114
+ def __init__(self, extractor: 'Extractor') -> 'None':
115
+ self._ctx = None # type: ignore[assignment]
116
+ self._ctx_list = []
117
+
118
+ super().__init__(extractor)
119
+
120
+ ##########################################################################
121
+ # Methods.
122
+ ##########################################################################
123
+
124
+ def run(self) -> 'None':
125
+ """Start extraction.
126
+
127
+ This method is the entry point for PCAP-NG file extraction. It will
128
+ directly extract the first block, which should be a section header
129
+ block, and then save the related information into the internal
130
+ context storage.
131
+
132
+ """
133
+ ext = self._extractor
134
+
135
+ shb = P_PCAPNG(ext._ifile, num=0, sct=1, ctx=None)
136
+ if shb.info.type != Enum_BlockType.Section_Header_Block:
137
+ raise FormatError(f'PCAP-NG: [SHB] invalid block type: {shb.info.type!r}')
138
+
139
+ self._ctx = Context(cast('Data_SectionHeaderBlock', shb.info))
140
+ self._ctx_list.append(self._ctx)
141
+ shb._ctx = self._ctx
142
+
143
+ self._write_file(shb.info, name=f'Section Header {len(self._ctx_list)}')
144
+
145
+ def read_frame(self) -> 'P_PCAPNG':
146
+ """Read frames.
147
+
148
+ This method performs following tasks:
149
+
150
+ - read the next block from input file;
151
+ - check if the block is a packet block;
152
+ - if not, save the block into the internal context storage and repeat;
153
+ - if yes, save the related information into the internal context storage;
154
+ - write the parsed block into output file.
155
+ - reassemble IP and/or TCP fragments;
156
+ - trace TCP flows if any;
157
+ - record frame information if any.
158
+
159
+ Returns:
160
+ Parsed PCAP-NG block.
161
+
162
+ """
163
+ from pcapkit.toolkit.pcapng import (ipv4_reassembly, ipv6_reassembly, tcp_reassembly,
164
+ tcp_traceflow)
165
+ ext = self._extractor
166
+
167
+ while True:
168
+ # read next block
169
+ block = P_PCAPNG(ext._ifile, num=ext._frnum+1, sct=len(self._ctx_list),
170
+ ctx=self._ctx, layer=ext._exlyr, protocol=ext._exptl,
171
+ __packet__={
172
+ 'snaplen': self._get_snaplen(),
173
+ })
174
+
175
+ # check block type
176
+ if block.info.type == Enum_BlockType.Section_Header_Block:
177
+ self._ctx = Context(cast('Data_SectionHeaderBlock', block.info))
178
+ self._ctx_list.append(self._ctx)
179
+ block._ctx = self._ctx
180
+
181
+ self._write_file(block.info, name=f'Section Header {len(self._ctx_list)}')
182
+
183
+ elif block.info.type == Enum_BlockType.Interface_Description_Block:
184
+ self._ctx.interfaces.append(cast('Data_InterfaceDescriptionBlock', block.info))
185
+ self._write_file(block.info, name=f'Interface Description {len(self._ctx.interfaces)}')
186
+
187
+ elif block.info.type == Enum_BlockType.Name_Resolution_Block:
188
+ self._ctx.names.append(cast('Data_NameResolutionBlock', block.info))
189
+ self._write_file(block.info, name=f'Name Resolution {len(self._ctx.names)}')
190
+
191
+ elif block.info.type == Enum_BlockType.systemd_Journal_Export_Block:
192
+ self._ctx.journals.append(cast('Data_SystemdJournalExportBlock', block.info))
193
+ self._write_file(block.info, name=f'systemd Journal Export {len(self._ctx.journals)}')
194
+
195
+ elif block.info.type == Enum_BlockType.Decryption_Secrets_Block:
196
+ self._ctx.secrets.append(cast('Data_DecryptionSecretsBlock', block.info))
197
+ self._write_file(block.info, name=f'Decryption Secrets {len(self._ctx.secrets)}')
198
+
199
+ elif block.info.type == Enum_BlockType.Interface_Statistics_Block:
200
+ isb_info = cast('Data_InterfaceStatisticsBlock', block.info)
201
+ if isb_info.interface_id >= len(self._ctx.interfaces):
202
+ raise FormatError(f'PCAP-NG: [ISB] invalid interface ID: {isb_info.interface_id}')
203
+ self._ctx.statistics.append(isb_info)
204
+
205
+ self._write_file(isb_info, name=f'Interface Statistics {len(self._ctx.statistics)}')
206
+
207
+ elif block.info.type in (Enum_BlockType.Custom_Block_that_rewriters_can_copy_into_new_files,
208
+ Enum_BlockType.Custom_Block_that_rewriters_should_not_copy_into_new_files):
209
+ self._ctx.custom.append(cast('Data_CustomBlock', block.info))
210
+ self._write_file(block.info, name=f'Custom {len(self._ctx.custom)}')
211
+
212
+ elif block.info.type == Enum_BlockType.Enhanced_Packet_Block:
213
+ epb_info = cast('Data_EnhancedPacketBlock', block.info)
214
+ if epb_info.interface_id >= len(self._ctx.interfaces):
215
+ raise FormatError(f'PCAP-NG: [EPB] invalid interface ID: {epb_info.interface_id}')
216
+ break
217
+
218
+ elif block.info.type == Enum_BlockType.Simple_Packet_Block:
219
+ if len(self._ctx.interfaces) != 1:
220
+ raise FormatError(f'PCAP-NG: [SPB] invalid section with {len(self._ctx.interfaces)} interfaces')
221
+ break
222
+
223
+ elif block.info.type == Enum_BlockType.Packet_Block:
224
+ pack_info = cast('Data_PacketBlock', block.info)
225
+ if pack_info.interface_id >= len(self._ctx.interfaces):
226
+ raise FormatError(f'PCAP-NG: [Packet] invalid interface ID: {pack_info.interface_id}')
227
+
228
+ warn('PCAP-NG: [Packet] deprecated block type', DeprecatedFormatWarning,
229
+ stacklevel=stacklevel())
230
+ break
231
+
232
+ else:
233
+ self._ctx.unknown.append(cast('Data_UnknownBlock', block.info))
234
+ self._write_file(block.info, name=f'Unknown {len(self._ctx.unknown)}')
235
+
236
+ # increment frame number
237
+ ext._frnum += 1
238
+
239
+ # verbose output
240
+ ext._vfunc(ext, block)
241
+
242
+ # write plist
243
+ self._write_file(block.info, name=f'Frame {ext._frnum}')
244
+
245
+ # record fragments
246
+ if ext._flag_r:
247
+ if ext._ipv4:
248
+ data_ipv4 = ipv4_reassembly(block)
249
+ if data_ipv4 is not None:
250
+ ext._reasm.ipv4(data_ipv4)
251
+ if ext._ipv6:
252
+ data_ipv6 = ipv6_reassembly(block)
253
+ if data_ipv6 is not None:
254
+ ext._reasm.ipv6(data_ipv6)
255
+ if ext._tcp:
256
+ data_tcp = tcp_reassembly(block)
257
+ if data_tcp is not None:
258
+ ext._reasm.tcp(data_tcp)
259
+
260
+ # trace flows
261
+ if ext._flag_t:
262
+ if ext._tcp:
263
+ data_tf_tcp = tcp_traceflow(block, nanosecond=block.nanosecond)
264
+ if data_tf_tcp is not None:
265
+ ext._trace.tcp(data_tf_tcp)
266
+
267
+ # record blocks
268
+ if ext._flag_d:
269
+ ext._frame.append(block)
270
+
271
+ # return block record
272
+ return block
273
+
274
+ ##########################################################################
275
+ # Utilities.
276
+ ##########################################################################
277
+
278
+ def _write_file(self, block: 'Data_PCAPNG', *, name: 'str') -> 'None':
279
+ """Write the parsed block into output file.
280
+
281
+ Args:
282
+ block: The parsed block.
283
+ name: The name of the block.
284
+
285
+ """
286
+ ext = self._extractor
287
+ if ext._flag_q:
288
+ return
289
+
290
+ if ext._flag_f:
291
+ ofile = ext._ofile(f'{ext._ofnm}/{name}.{ext._fext}')
292
+ ofile(block.to_dict(), name=name)
293
+ else:
294
+ ext._ofile(block.to_dict(), name=name)
295
+ ofile = ext._ofile
296
+ ext._offmt = ofile.kind
297
+
298
+ def _get_snaplen(self) -> 'int':
299
+ """Get snapshot length from the current context.
300
+
301
+ This method is used for providing the snapshot length to the ``__packet__``
302
+ argument when parsing a Simple Packet Block (SPB).
303
+
304
+ Notes:
305
+ If there is no interface, return ``0xFFFF_FFFF_FFFF_FFFF``.
306
+
307
+ """
308
+ if self._ctx.interfaces:
309
+ return self._ctx.interfaces[0].snaplen
310
+ return 0xFFFF_FFFF_FFFF_FFFF
@@ -0,0 +1,166 @@
1
+ # -*- coding: utf-8 -*-
2
+ """PyShark Support
3
+ =====================
4
+
5
+ .. module:: pcapkit.foundation.engines.pyshark
6
+
7
+ This module contains the implementation for `PyShark`_ engine
8
+ support, as is used by :class:`pcapkit.foundation.extraction.Extractor`.
9
+
10
+ .. _PyShark: https://kiminewt.github.io/pyshark
11
+
12
+ """
13
+ from typing import TYPE_CHECKING, cast
14
+
15
+ from pcapkit.foundation.engines.engine import EngineBase as Engine
16
+ from pcapkit.foundation.reassembly import ReassemblyManager
17
+ from pcapkit.utilities.exceptions import stacklevel
18
+ from pcapkit.utilities.warnings import AttributeWarning, warn
19
+
20
+ __all__ = ['PyShark']
21
+
22
+ if TYPE_CHECKING:
23
+ from pyshark.capture.file_capture import FileCapture
24
+ from pyshark.packet.packet import Packet as PySharkPacket
25
+
26
+ from pcapkit.foundation.extraction import Extractor
27
+
28
+
29
+ class PyShark(Engine['PySharkPacket']):
30
+ """PyShark engine support.
31
+
32
+ Args:
33
+ extractor: :class:`~pcapkit.foundation.extraction.Extractor` instance.
34
+
35
+ """
36
+ if TYPE_CHECKING:
37
+ import pyshark
38
+
39
+ #: Engine extraction package.
40
+ _expkg: 'pyshark'
41
+ #: Engine extraction temporary storage.
42
+ _extmp: 'FileCapture'
43
+
44
+ ##########################################################################
45
+ # Defaults.
46
+ ##########################################################################
47
+
48
+ #: Engine name.
49
+ __engine_name__ = 'PyShark'
50
+
51
+ #: Engine module name.
52
+ __engine_module__ = 'pyshark'
53
+
54
+ ##########################################################################
55
+ # Data models.
56
+ ##########################################################################
57
+
58
+ def __init__(self, extractor: 'Extractor') -> 'None':
59
+ import pyshark # isort:skip
60
+
61
+ self._expkg = pyshark
62
+ self._extmp = cast('FileCapture', None)
63
+
64
+ super().__init__(extractor)
65
+
66
+ ##########################################################################
67
+ # Methods.
68
+ ##########################################################################
69
+
70
+ def run(self) -> 'None':
71
+ """Call :class:`pyshark.FileCapture` to extract PCAP files.
72
+
73
+ This method assigns :attr:`self._expkg <PyShark._expkg>`
74
+ as :mod:`pyshark` and :attr:`self._extmp <PyShark._extmp>`
75
+ as an iterator from :class:`pyshark.FileCapture`.
76
+
77
+ Warns:
78
+ AttributeWarning: Warns under following circumstances:
79
+
80
+ * if :attr:`self.extractor._exlyr <pcapkit.foundation.extraction.Extractor._exlyr>`
81
+ and/or :attr:`self.extractor._exptl <pcapkit.foundation.extraction.Extractor._exptl>`
82
+ is provided as the PyShark engine currently does not
83
+ support such operations.
84
+ * if reassembly is enabled, as the PyShark engine currently
85
+ does not support such operation.
86
+
87
+ """
88
+ ext = self._extractor
89
+
90
+ if ext._exlyr != 'none' or ext._exptl != 'null':
91
+ warn("'Extractor(engine='pyshark')' does not support protocol and layer threshold; "
92
+ f"'layer={ext._exlyr}' and 'protocol={ext._exptl}' ignored",
93
+ AttributeWarning, stacklevel=stacklevel())
94
+
95
+ if ext._flag_r and (ext._ipv4 or ext._ipv6 or ext._tcp):
96
+ ext._flag_r = False
97
+ ext._reasm = ReassemblyManager(ipv4=None, ipv6=None, tcp=None)
98
+ warn("'Extractor(engine='pyshark')' object dose not support reassembly; "
99
+ f"so 'ipv4={ext._ipv4}', 'ipv6={ext._ipv6}' and 'tcp={ext._tcp}' will be ignored",
100
+ AttributeWarning, stacklevel=stacklevel())
101
+
102
+ # setup verbose handler
103
+ if ext._flag_v:
104
+ ext._vfunc = lambda e, f: print(
105
+ f'Frame {e._frnum:>3d}: {f.frame_info.protocols}' # pylint: disable=protected-access
106
+ ) # pylint: disable=logging-fstring-interpolation
107
+
108
+ # extract & analyse file
109
+ self._extmp = self._expkg.FileCapture(ext._ifnm, keep_packets=False)
110
+
111
+ def read_frame(self) -> 'PySharkPacket':
112
+ """Read frames with PyShark engine.
113
+
114
+ Returns:
115
+ Parsed frame instance.
116
+
117
+ See Also:
118
+ Please refer to :meth:`PCAP.read_frame <pcapkit.foundation.engines.pcap.PCAP.read_frame>`
119
+ for more operational information.
120
+
121
+ """
122
+ from pcapkit.toolkit.pyshark import packet2dict, tcp_traceflow
123
+ ext = self._extractor
124
+
125
+ # fetch PyShark packet
126
+ packet = cast('PySharkPacket', self._extmp.next())
127
+
128
+ # verbose output
129
+ ext._frnum = int(packet.number)
130
+ ext._vfunc(ext, packet)
131
+
132
+ # write plist
133
+ frnum = f'Frame {ext._frnum}'
134
+ if not ext._flag_q:
135
+ info = packet2dict(packet)
136
+ if ext._flag_f:
137
+ ofile = ext._ofile(f'{ext._ofnm}/{frnum}.{ext._fext}')
138
+ ofile(info, name=frnum)
139
+ else:
140
+ ext._ofile(info, name=frnum)
141
+ ofile = ext._ofile
142
+ ext._offmt = ofile.kind
143
+
144
+ # trace flows
145
+ if ext._flag_t:
146
+ if ext._tcp:
147
+ data_tf_tcp = tcp_traceflow(packet)
148
+ if data_tf_tcp is not None:
149
+ ext._trace.tcp(data_tf_tcp)
150
+
151
+ # record frames
152
+ if ext._flag_d:
153
+ # setattr(packet, 'packet2dict', packet2dict)
154
+ ext._frame.append(packet)
155
+
156
+ # return frame record
157
+ return packet
158
+
159
+ def close(self) -> 'None':
160
+ """Close engine.
161
+
162
+ This method is to be used for closing the engine instance. It is to
163
+ close the engine instance after the extraction process is finished.
164
+
165
+ """
166
+ self._extmp.close()