SKYTOWER
- Layout for this exercise:
data:image/s3,"s3://crabby-images/95b9d/95b9d554f27e9843f44339e89a7279b352d2bcaf" alt=""
1 - INTRODUCTION
- The goal of this exercise is to develop a hacking process for the vulnerable machine SkyTower.
- SkyTower can be downloaded from here:
https://www.vulnhub.com/entry/skytower-1,96/
- Once downloaded SkyTower and extracted with VirtualBox:
data:image/s3,"s3://crabby-images/6a685/6a685ed6c70dacce30ce2a5dc1c2a9442d4ae28b" alt=""
2 - ENUMERATION
- Discovering SkyTower's IP:
data:image/s3,"s3://crabby-images/99ab6/99ab6ddf63d5af57aa18ba9e315ac68d9ddf06e5" alt=""
- Scanning with Nmap it seems that there are 3 available ports:
data:image/s3,"s3://crabby-images/adad2/adad292b9f69e02f507c9c888d14e4064ac34cbc" alt=""
- Let's notice port 22 for SSH is filtered, probably due to the presence of the HTTP-PROXY at port 3128.
3 - SQL INJECTION ATTACK
- Connecting to the web server we find a login form:
data:image/s3,"s3://crabby-images/4c945/4c945a255a4696bb4f926dd0a3a75c30c8efefd4" alt=""
- Entering ' we discover that a MySQL is running and it is possibly vulnerable to SQL Injection attack:
data:image/s3,"s3://crabby-images/c9858/c98584f683a09fb55ea069b773117d3cf6407301" alt=""
data:image/s3,"s3://crabby-images/894a7/894a7d7c7bc3c150e420dc011d3f62089d58b6a4" alt=""
- Entering an usual SQL Injection the answer is Login Failed, meaning that we are probably in the right track:
data:image/s3,"s3://crabby-images/06720/06720494140c97dd2655161fc507eb597bd487f3" alt=""
data:image/s3,"s3://crabby-images/81faf/81faf19b7fbfcd68b3e0cef782664f4557e66b4b" alt=""
- Maybe OR is filtered? Let's remember that the boolean operator OR can be also written with ||
data:image/s3,"s3://crabby-images/caadb/caadb81ee4f39e74bd9d6302be1ef6c55c231167" alt=""
- The SQL injection is eventually successful:
data:image/s3,"s3://crabby-images/b26fe/b26fe9115430b19bf30151aa12c3bc587e043862" alt=""
- So, as a result of the SQLi attack we have some valid credentials for user john:
john:hereisjohn
- Let's try to take advantage of it.
4 - GETTING A REMOTE SHELL
4.1 - Proxytunnel
- To bypass the HTTP-PROXY running at port 3128 we can use a proxytunnel with these three options:
data:image/s3,"s3://crabby-images/9b2ea/9b2ea3adebf9181478948c0f83e0878f31580892" alt=""
data:image/s3,"s3://crabby-images/a75c7/a75c7c2961567f3ceee86e4ff86703cf327d775c" alt=""
data:image/s3,"s3://crabby-images/426dc/426dcdc4fa5eb7dd02d6513041a5aef8b8e7d7f1" alt=""
data:image/s3,"s3://crabby-images/804b8/804b8af40c4c6d091e8ccea86306b5dbb85dfa9e" alt=""
- Checking that the proxytunnel is enabled:
data:image/s3,"s3://crabby-images/c9397/c9397c04e00d266c7d2d2f84e3527dc2b5f0df99" alt=""
- Now, trying a remote shell with SSH, it works but the connection is closed:
data:image/s3,"s3://crabby-images/0dfcc/0dfcc95c2e44208834067b5ac1a3119c89dbe347" alt=""
4.2 - Running commands with SSH
- However SSH allows also to run commands remotely , like for instance cat /etc/passwd:
data:image/s3,"s3://crabby-images/bcaad/bcaada8d00af3e892815a61d84023f59710804d8" alt=""
- By the way, let's notice the presence of these 3 users:
data:image/s3,"s3://crabby-images/5343e/5343e7e3102342cd803a0675752c9750165deea7" alt=""
- Now, two different ways to achieve a remote shell would be the following:
a) Running the command /bin/sh and forcing a pseudo-terminal allocation with the -t option:
data:image/s3,"s3://crabby-images/0aa26/0aa267922994ffd02d7c61a762ce0779f10387ce" alt=""
data:image/s3,"s3://crabby-images/04c2c/04c2c3b80bf7f49254ab75c2b7c12f0d168bbe93" alt=""
b) Using Netcat:
data:image/s3,"s3://crabby-images/5382b/5382b1300a8d039ac4736e82064eb32fbfa3bd73" alt=""
data:image/s3,"s3://crabby-images/10fee/10fee09970daf4a7de53bcc24e50d97929d5b063" alt=""
data:image/s3,"s3://crabby-images/5f7af/5f7af640788b8618b5578cb105184b1c5e3f9be3" alt=""
- Anyway, unfortunately user john has no sudo privileges:
data:image/s3,"s3://crabby-images/35b74/35b746a632db2915cf797e48d7b5ca50b949265d" alt=""
4.3 - Exploring the database
- Looking for the login.php file:
data:image/s3,"s3://crabby-images/c2998/c299891ff525e9cec7ed00d856f814275f0c4245" alt=""
- Reading login.php we find interesting information:
data:image/s3,"s3://crabby-images/9dda2/9dda2cb92a56128d1dcd33906fb7e74b354393b6" alt=""
- Using credentials root:root to connect to the database SkyTech:
data:image/s3,"s3://crabby-images/b2c04/b2c04cc7140fba0fe2540af194b8b0f53bbefe50" alt=""
- Passwords for the 3 users john, sara and william are achieved in an easy way, just exploring the database:
data:image/s3,"s3://crabby-images/32a2b/32a2b7405ed7a66934ec3d9ce5639de396aea43f" alt=""
- By the way, digging into login.php we can find the SQL injection filter:
data:image/s3,"s3://crabby-images/b5d2a/b5d2a0892ea87f25b6f7be37b5fea0ba02ac1edc" alt=""
5 - PRIVILEGE ESCALATION
- We are not allowed to use sara and william user accounts:
data:image/s3,"s3://crabby-images/4251f/4251f2cd08c2c4c5118b24a0fce8c97d77f81324" alt=""
- However, SSH-ing for sara is successful:
data:image/s3,"s3://crabby-images/25fab/25fabf5f15e48455108950dd3c2157d03f8fd187" alt=""
- Not for william:
data:image/s3,"s3://crabby-images/eb693/eb693e99469a158b1aaedfe556514c98ce1ec5b2" alt=""
- Great news are that sara has got some sudoer privileges:
data:image/s3,"s3://crabby-images/b0e20/b0e20f4354c91ed49f18cc9cde2348c6d71f482e" alt=""
- Let's see how to take advantage of it.
- First of all, sara is not allowed to read directly from root's home folder:
data:image/s3,"s3://crabby-images/a10a8/a10a822c9a3e38a2ca3df8b0e0f8824a37478802" alt=""
- However, it happens that folders accounts and root are in the same root directory /:
data:image/s3,"s3://crabby-images/e3dd4/e3dd410815fd716bda5afda645cd42cb4f00fa11" alt=""
- According to sara's sudoer privileges we can use ls and cat in an indirect way (Path Traversal) through /accounts to access /root:
data:image/s3,"s3://crabby-images/fa434/fa434f559cb2e8177f80e6894e7ddb168b320f60" alt=""
- Listing:
data:image/s3,"s3://crabby-images/bf155/bf15504e5553e63d7f81498676d6bdc06e8e55fe" alt=""
- Reading flag.txt:
data:image/s3,"s3://crabby-images/e55f2/e55f2b10bc05f74e253c20fc3a11c3189bf1249b" alt=""
- Finally we have achieved the root password.
- Let's confirm that it is right:
data:image/s3,"s3://crabby-images/e48f9/e48f97c2efdc7676f01c23785a81f03c2b62a970" alt=""