-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathargv_parser.py
202 lines (173 loc) · 9.27 KB
/
argv_parser.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
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
# Checkpot - Honeypot Checker
# Copyright (C) 2018 Vlad Florea
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, version 3 of the License.
#
# DISCLAIMER: All prerequisites (containers, additional programs, etc.)
# and libraries that might be needed to run this program are property
# of their original authors and carry their own separate licenses that
# you should read to inform yourself about their terms.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# As this software is PROVIDED WITH ABSOLUTELY NO WARRANTY OF ANY KIND,
# YOU USE THIS SOFTWARE AT YOUR OWN RISK!
#
# By using this tool YOU TAKE FULL LEGAL RESPONSIBILITY FOR ANY
# POSSIBLE OUTCOME.
#
# We strongly recommend that you read all the information in the README.md
# file (found in the root folder of this project) and even the
# documentation (which you can find locally in the /docs/ folder or
# at http://checkpot.readthedocs.io/) to make sure you fully
# understand how this tool works and consult all laws that apply
# to your use case.
#
# We strongly suggest that you keep this notice intact for all files.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <https://www.gnu.org/licenses/>.
# The local copy of the license should be located in the root folder of the app
# in the file gpl-3.0.txt.
#
# You can contact the author and team at any time via the Checkpot official
# GitHub page: https://github.com/honeynet/checkpot or via the Honeynet
# official Slack channel: https://gsoc-slack.honeynet.org/ or
# https://honeynetpublic.slack.com/
#
# You can contact us at any time and with any question, we are here to help!
#
# If you consider any information in this copyright notice might be incorrect,
# outdated, arises any questions, raises any problems, etc. please contact us
# and we will make it our top priority to fix it. We have the deepest respect
# for the work of all authors and for all of our users.
import getopt
import ipaddress
def print_usage():
"""Prints correct command line usage of the app"""
print("Usage: checkpot -t <target IP> <options>")
print("Options: ")
print("\t-O / --os-scan -> fingerprint OS (requires sudo)")
print("\t-l / --level= <level> -> maximum scanning level (1/2/3)")
print("\t-p / --ports <port range> -> scan a specific range of ports (e.g. 20-100)."
" For all ports use -p -")
print("\t-f / --fast -> Uses -Pn and -T5 for faster scans on local connections")
print("\t-b / --brief -> Disables NOT APPLICABLE tests for shorter output")
print("\t-s / --show <c/w> -> Show copyright/warranty information")
def parse(argv):
"""
Parses command line arguments and returns dict of requested options
:param argv:
:return: options dict
"""
parsed = {
"target": None,
"scan_os": False,
"scan_level": 5,
"port_range": None,
"fast": False,
"brief": False
}
short_options = 't:l:Op:fbs:'
long_options = ['target=', 'level=', 'os-scan', 'ports', 'fast', 'brief', 'show=']
try:
options, values = getopt.getopt(argv[1:], short_options, long_options)
except getopt.GetoptError as opt_error:
print(opt_error)
print_usage()
return None
for option, value in options:
if option in ('-t', '--target'):
parsed["target"] = value
elif option in ('-l', '--level'):
parsed["scan_level"] = int(value)
elif option in ('-O', '--osscan'):
parsed["scan_os"] = True
elif option in ('-p', '--ports'):
parsed["port_range"] = value
elif option in ('-f', '--fast'):
parsed["fast"] = True
elif option in ('-b', '--brief'):
parsed["brief"] = True
elif option in ('-s', '--show'):
if value == 'c':
print(
"Checkpot - Honeypot Checker\n"
"Copyright (C) 2018 Vlad Florea\n\n"
"This program is free software: you can redistribute it and/or modify\n"
"it under the terms of the GNU General Public License as published by\n"
"the Free Software Foundation, version 3 of the License.\n\n"
"DISCLAIMER: All prerequisites (containers, additional programs, etc.)\n"
"and libraries that might be needed to run this program are property\n"
"of their original authors and carry their own separate licenses that\n"
"you should read to inform yourself about their terms.\n\n"
"This program is distributed in the hope that it will be useful,\n"
"but WITHOUT ANY WARRANTY; without even the implied warranty of\n"
"MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n"
"GNU General Public License for more details.\n\n"
"As this software is PROVIDED WITH ABSOLUTELY NO WARRANTY OF ANY KIND,\n"
"YOU USE THIS SOFTWARE AT YOUR OWN RISK!\n\n"
"By using this tool YOU TAKE FULL LEGAL RESPONSIBILITY FOR ANY\n"
"POSSIBLE OUTCOME.\n\n"
"We strongly recommend that you read all the information in the README.md\n"
"file (found in the root folder of this project) and even the\n"
"documentation (which you can find locally in the /docs/ folder or\n"
"at http://checkpot.readthedocs.io/) to make sure you fully\n"
"understand how this tool works and consult all laws that apply\n"
"to your use case.\n\n"
"We strongly suggest that you keep this notice intact for all files.\n"
"You should have received a copy of the GNU General Public License\n"
"along with this program. If not, see <https://www.gnu.org/licenses/>.\n"
"The local copy of the license should be located in the root folder of the app\n"
"in the file gpl-3.0.txt.\n\n"
"You can contact the author and team at any time via the Checkpot official\n"
"GitHub page: https://github.com/honeynet/checkpot or via the Honeynet\n"
"official Slack channel: https://gsoc-slack.honeynet.org/ or\n"
" https://honeynetpublic.slack.com/\n\n"
"You can contact us at any time and with any question, we are here to help!\n\n"
"If you consider any information in this copyright notice might be incorrect,\n"
"outdated, arises any questions, raises any problems, etc. please contact us\n"
"and we will make it our top priority to fix it. We have the deepest respect\n"
"for the work of all authors and for all of our users.\n"
)
elif value == 'w':
print(
"THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY\n"
"APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT\n"
'HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY\n'
"OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO,\n"
"THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR\n"
"PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM\n"
"IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF\n"
"ALL NECESSARY SERVICING, REPAIR OR CORRECTION.\n"
"\n"
"IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING\n"
"WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS\n"
"THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY\n"
"GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE\n"
"USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF\n"
"DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD\n"
"PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS),\n"
"EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF\n"
"SUCH DAMAGES.\n"
)
exit(0)
# validate target IP
# TODO convert this to use exceptions if it gets too big
if parsed["target"] is None:
print("No target specified. Use -t")
print_usage()
return None
try:
ipaddress.ip_address(parsed["target"])
except ValueError:
# not a valid ip address
print("Target not a valid IP address")
print_usage()
return None
return parsed