Refactor handle_packet to detect APs using only beacon frames and improve unicast client counting logic.
This commit is contained in:
parent
7be1b48831
commit
a81321436a
1 changed files with 3 additions and 4 deletions
|
@ -77,9 +77,9 @@ def handle_packet(pkt):
|
|||
a1 = dot11.addr1.lower() if dot11.addr1 else None
|
||||
a2 = dot11.addr2.lower() if dot11.addr2 else None
|
||||
|
||||
# === Detect APs via beacons/probe responses ===
|
||||
if dot11.type == 0 and dot11.subtype in (5, 8): # Probe Response or Beacon
|
||||
if a2:
|
||||
# === Detect APs via beacon frames only ===
|
||||
if dot11.type == 0 and dot11.subtype == 8: # Beacon
|
||||
if a2 and is_unicast(a2):
|
||||
aps.add(a2)
|
||||
ssid = parse_ssid(pkt)
|
||||
if ssid:
|
||||
|
@ -92,7 +92,6 @@ def handle_packet(pkt):
|
|||
|
||||
for mac in (sa, da):
|
||||
if is_unicast(mac) and mac != target_ap_bssid:
|
||||
print(f"[D] Counting client: {mac} (frame type: {dot11.type}, subtype: {dot11.subtype})")
|
||||
clients[mac] += 1
|
||||
|
||||
# Track clients talking to the same AP we're connected to
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue