-
Notifications
You must be signed in to change notification settings - Fork 50
/
Copy pathPRETty.py
executable file
·154 lines (137 loc) · 7.11 KB
/
PRETty.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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
#!/usr/bin/python
# -*- coding: utf-8 -*-
import os
import argparse
from time import sleep
from termcolor import colored, cprint
main_color = 'green'
sub_color = 'blue'
line_color = 'red'
text_color = 'white'
alt_text = ' automation tool'
def main_text():
cprint(" \"PRinter Exploitation Toolkit\" LAN"+alt_text+" ", text_color)
def main_art():
cprint(" ▄▄▄▄▄▄▄▄▄▄▄ ▄▄▄▄▄▄▄▄▄▄▄ ▄▄▄▄▄▄▄▄▄▄▄ ▄▄▄▄▄▄▄▄▄▄▄ ▄▄▄▄▄▄▄▄▄▄▄ ▄ ▄ ", main_color)
cprint("▐░░░░░░░░░░░▌▐░░░░░░░░░░░▌▐░░░░░░░░░░░▌▐░░░░░░░░░░░▌▐░░░░░░░░░░░▌▐░▌ ▐░▌ ", main_color)
cprint("▐░█▀▀▀▀▀▀▀█░▌▐░█▀▀▀▀▀▀▀█░▌▐░█▀▀▀▀▀▀▀▀▀ ▀▀▀▀█░█▀▀▀▀ ▀▀▀▀█░█▀▀▀▀ ▐░▌ ▐░▌ ", main_color)
cprint("▐░▌ ▐░▌▐░▌ ▐░▌▐░▌ ▐░▌ ▐░▌ ▐░▌ ▐░▌ ", main_color)
cprint("▐░█▄▄▄▄▄▄▄█░▌▐░█▄▄▄▄▄▄▄█░▌▐░█▄▄▄▄▄▄▄▄▄ ▐░▌ ▐░▌ ▐░█▄▄▄▄▄▄▄█░▌ ", main_color)
cprint("▐░░░░░░░░░░░▌▐░░░░░░░░░░░▌▐░░░░░░░░░░░▌ ▐░▌ ▐░▌ ▐░░░░░░░░░░░▌ ", main_color)
cprint("▐░█▀▀▀▀▀▀▀▀▀ ▐░█▀▀▀▀█░█▀▀ ▐░█▀▀▀▀▀▀▀▀▀ ▐░▌ ▐░▌ ▀▀▀▀█░█▀▀▀▀ ", main_color)
cprint("▐░▌ ▐░▌ ▐░▌ ▐░▌ ▐░▌ ▐░▌ ▐░▌ ", main_color)
cprint("▐░▌ ▐░▌ ▐░▌ ▐░█▄▄▄▄▄▄▄▄▄ ▐░▌ ▐░▌ ▐░▌ ", main_color)
cprint("▐░▌ ▐░▌ ▐░▌▐░░░░░░░░░░░▌ ▐░▌ ▐░▌ ▐░▌ ", main_color)
cprint(" ▀ ▀ ▀ ▀▀▀▀▀▀▀▀▀▀▀ ▀ ▀ ▀ ", main_color)
cprint(" BusesCanFly 76 33 2e 30 ", sub_color)
cprint("-------------------------------------------------------------------------------", line_color)
main_text()
cprint("-------------------------------------------------------------------------------", line_color)
def interactive_steps():
cprint("Step 1: Generate IP list", 'yellow')
cprint("Step 2: Select IP list", 'yellow')
cprint("Step 3: Select PRET command input file", 'yellow')
cprint("Step 4: Select shell type", 'yellow')
cprint("Step 5: Observe all laws and ethical/moral codes :D", 'yellow')
cprint("Step 6: >:)\n", 'yellow')
parser = argparse.ArgumentParser()
parser.add_argument('--cli', dest='cli', action='store_true',
help='Enable CLI mode (No user input)')
parser.add_argument('-r', '--ip_range', type=str, default='--localnet',
help='IP range to scan')
parser.add_argument('-c', '--commands_list', type=str, default='pret_pagecount.txt',
help='Name of command list file to use')
parser.add_argument('-s', '--shell_type', type=str, default='ps',
help='Printer shell type for PRET')
args = parser.parse_args()
sleep_time=1.5
def PrinterLogSort():
os.system('tshark -r ./IP/scan.pcap > ./IP/pcap.txt 2>/dev/null')
os.system('cat ./IP/pcap.txt | grep -iE "Hewlett|Brother|Kyocera|Laserjet" > ./IP/raw_list 2>/dev/null')
os.system('awk \'{print $8}\' ./IP/raw_list > ./IP/Printer_list')
sleep(0.5)
cprint('Successfully processed raw data', 'green')
os.system('rm -rf ./IP/scan.pcap && rm -rf ./IP/pcap.txt && rm -rf ./IP/raw_list 2>/dev/null')
sleep(sleep_time)
cprint('Cleaned raw data', 'green')
sleep(sleep_time)
cprint('\nLocated '+ str(sum(1 for line in open ('./IP/Printer_list'))) +' printers, storing as ./IP/Printer_list\n', 'yellow')
def PRETty_Interactive():
gen_new= str(raw_input("Generate new IP list? [y/N] "))
if gen_new == 'y':
set_ip_range = raw_input("Set IP range for scanning? [y/N] ")
if set_ip_range == 'y':
ip_range = str(raw_input("IP range: [ex. 192.168.0.0/16] "))
else:
ip_range = '--localnet'
cprint("ARP scanning LAN for devices...", 'green')
sleep(1.5)
os.system('sudo arp-scan -g '+ip_range+' -W ./IP/scan.pcap')
cprint('Successfully collected IP\'s', 'green')
PrinterLogSort()
list_answer = str(raw_input("Use default IP list? [Y/n] "))
if list_answer == 'n':
cprint('An example IP list can be found at ./IP/example', 'green')
cprint('Available IP lists: ', 'green')
os.system('ls ./IP/')
print('\n')
list = './IP/' + str(raw_input("Which list? ./IP/"))
cprint('\nLoaded '+ str(sum(1 for line in open (list))) +' IP\'s\n', 'yellow')
else:
cprint('Using "./IP/Printer_list" as IP range', 'green')
list = './IP/Printer_list'
cprint('\nLoaded '+ str(sum(1 for line in open ('./IP/Printer_list'))) +' IP\'s\n', 'yellow')
commands_list = str(raw_input("Use default ./commands/pret_pagecount.txt command file? [Y/n] "))
if commands_list == 'n':
cprint('Example command lists: (./commands)', 'green')
os.system('ls ./commands/')
print('\n')
commands_list = './commands/' + str(raw_input("Which command list? "+'./commands/'))
cprint('Commands: ', 'green')
os.system('cat '+commands_list)
print('\n')
else:
cprint('Using "./commands/pret_pagecount.txt" as PRET commands', 'green')
commands_list = './commands/pret_pagecount.txt'
cprint('Commands: ', 'yellow')
os.system('cat ./commands/pret_pagecount.txt')
print('\n')
shell_type = raw_input("Shell Type: [ps, pjl, pcl] ")
debug = raw_input('Enable PRET debug mode? [y/N] ')
if debug == 'y':
debug_enabled = '-d'
else:
debug_enabled = ''
print('')
with open(list) as inf:
lines = [line.strip() for line in inf]
i=0
while i < len(lines):
os.system('../pret.py '+debug_enabled+' -i '+commands_list+' -q '+lines[i]+' '+ shell_type)
i+=1
def PRETty_cli():
os.system('sudo arp-scan -g '+args.ip_range+' -W ./IP/scan.pcap')
PrinterLogSort()
sleep(1)
list = './IP/Printer_list'
with open(list) as inf:
lines = [line.strip() for line in inf]
i=0
while i < len(lines):
os.system('../pret.py -i ./commands/'+args.commands_list+' -q '+lines[i]+' '+ args.shell_type)
i+=1
if args.cli:
main_color = 'red'
sub_color = 'green'
line_color = 'white'
text_color = 'yellow'
alt_text =' AUTOPWN '
main_art()
sleep_time=0.5
PRETty_cli()
else:
alt_text = ' automation tool'
main_art()
interactive_steps()
sleep_time=1.5
PRETty_Interactive()