-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathblack_venom_cli.py
60 lines (49 loc) Β· 2.59 KB
/
black_venom_cli.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
import argparse
import time
from BlackVenom.BlackVenom import BlackVenom
def main():
parser = argparse.ArgumentParser(description="BlackVenom π€: Ethical Hacking ARP and DNS Spoofing Tool")
# Main arguments for ARP Spoofing
parser.add_argument('--target_ip', type=str, required=True, help="The IP address of the target machine.")
parser.add_argument('--gateway_ip', type=str, required=True, help="The IP address of the gateway.")
parser.add_argument('--interface', type=str, default='eth0', help="Network interface to use (default is 'eth0').")
# Arguments for Packet Logging
parser.add_argument('--logger_queue_num', type=int, default=1, help="Queue number for packet logging (default is 1).")
parser.add_argument('--enable_logging', action='store_true', help="Enable packet logging to a pcap file.")
parser.add_argument('--log_file', type=str, default="captured_packets.pcap", help="Path to pcap file for logging packets (used only if logging is enabled).")
# Arguments for DNS Spoofing
parser.add_argument('--spoof_dns', action='store_true', help="Enable DNS spoofing.")
parser.add_argument('--dns_queue_num', type=int, default=2, help="Queue number for DNS spoofing (default is 2).")
parser.add_argument('--dns_records', type=str, nargs='+', help="DNS records in the format 'domain=ip' to redirect DNS requests.")
args = parser.parse_args()
# Validate DNS records if spoofing is enabled
dns_records = {}
if args.spoof_dns:
if not args.dns_records:
parser.error("--dns_records is required when --spoof_dns is enabled.")
for record in args.dns_records:
try:
domain, ip = record.split('=')
dns_records[domain.encode()] = ip # Convert domain to bytes
except ValueError:
parser.error("DNS record must be in the format 'domain=ip'.")
# Instantiate BlackVenom with all configurations
black_venom = BlackVenom(
interface=args.interface,
logger_queue_num=args.logger_queue_num,
dns_queue_num=args.dns_queue_num,
enable_logging=args.enable_logging,
log_file=args.log_file,
dns_records=dns_records
)
# Start ARP Spoofing (and DNS Spoofing if enabled)
black_venom.start_spoofing(args.target_ip, args.gateway_ip)
try:
print("π Spoofing started. Press Ctrl+C to stop.")
while True:
time.sleep(1)
except KeyboardInterrupt:
print("π Stopping spoofing and logging...")
black_venom.stop_spoofing()
if __name__ == "__main__":
main()