HACKDAY: ALBANIA
- Layout for this exercise:
data:image/s3,"s3://crabby-images/d9a85/d9a85508a985718703089ad758bc042d17782291" alt=""
1 - INTRODUCTION
- The goal of this exercise is to develop a hacking process for the vulnerable machine HackDay Albania
- HackDay Albania can be downloaded from here:
https://www.vulnhub.com/entry/hackday-albania,167/
- Once downloaded Albania and extracted with VirtualBox:
data:image/s3,"s3://crabby-images/94784/94784c0cb1d12959a9abc698cc5dcca96df8c5fd" alt=""
2 - ENUMERATION
- The IP for Albania is 192.168.1.21:
data:image/s3,"s3://crabby-images/ebc79/ebc79d2ca2ceb80bec985a589bef117ceb6ba884" alt=""
data:image/s3,"s3://crabby-images/f4eb5/f4eb5a878ba44f9019096700e4a63c134adcb6ea" alt=""
- Scanning with Nmap there are just two open ports, 22 for SSH and 8008 for HTTP:
data:image/s3,"s3://crabby-images/2f140/2f140f1517809215ce0823c1e9d19cdae1cf4ddb" alt=""
- Connecting to the web server at port 8008:
data:image/s3,"s3://crabby-images/f7fcd/f7fcd62a81a0e908a496bd520bb01a0cbb78260b" alt=""
- Google Translate helps us with Albanian language:
data:image/s3,"s3://crabby-images/78541/785417f219a37d2cf9e4116f8a9d276e14b936e1" alt=""
- Viewing the source, there is also another message in Albanian, telling us that this is not the right directory to search for information:
data:image/s3,"s3://crabby-images/ba90c/ba90c34e5bd2c488dd94b1630ce939d5f69eaabd" alt=""
data:image/s3,"s3://crabby-images/fd12f/fd12f9aa471d8408cc6a7c3e69337cbce0da1fd8" alt=""
- Launching nikto against the web server at port 8008 we discover that there are 26 possible directories, all of them listed at robots.txt:
data:image/s3,"s3://crabby-images/e1d8c/e1d8c07e9240004d9dd4770544f33c0a179f7ddf" alt=""
..................
data:image/s3,"s3://crabby-images/ec22c/ec22ce6ea29fed9574b4ab6258b5f9422671da81" alt=""
- Going directly to robots.txt:
data:image/s3,"s3://crabby-images/c7606/c760643b866961bff94367bba7a06ca42096a20e" alt=""
- All of the directories (except one) answer back with the same image:
data:image/s3,"s3://crabby-images/1315e/1315ed060837c0cf4b20786291ead05f2e7565c9" alt=""
- The translation of the message is doubtful:
data:image/s3,"s3://crabby-images/99a89/99a89e1c606ebc671b69a89b389cfe231efe2e7f" alt=""
- However, when going to unisxcudkqjydw the answer is quite different:
data:image/s3,"s3://crabby-images/1b2cf/1b2cff5eeb2d67e5f3c89f6107ced32e308e9ff7" alt=""
data:image/s3,"s3://crabby-images/9fc49/9fc49b156cf11ea3539c4b84a8fc3308a12ff61e" alt=""
- Trying a possible vulnbank directory:
data:image/s3,"s3://crabby-images/ea751/ea7510c64133cea6b5a9bffd185c81adaef09a2c" alt=""
- Clicking client, finally we find something valuable like a login form:
data:image/s3,"s3://crabby-images/83cd1/83cd1d0c19774ce61e2b32d0c32d4ee849688508" alt=""
3 - SQL INJECTION ATTACK
- It is immediate to check that the login form is vulnerable to some type of SQL injection attack, just by entering a quotation mark ('):
data:image/s3,"s3://crabby-images/c9c9f/c9c9ff59e2cccb62924b2140850a1f864f8054b2" alt=""
data:image/s3,"s3://crabby-images/252cf/252cf37010452a96430bb60a7b3593380b27250f" alt=""
- Trying different SQL injections ... the result is invalid:
data:image/s3,"s3://crabby-images/cec1d/cec1d14820ddfb9c2bbfcfceddb51dc6ca7f315c" alt=""
data:image/s3,"s3://crabby-images/08db2/08db2751b7e718b33aa6538ff303cfeb4c0ce88d" alt=""
data:image/s3,"s3://crabby-images/38f08/38f0811d50121917808f8fef0d28e4a2f8e86626" alt=""
- Thinking on the fact that MYSQL queries are finished with ; and comments with #
https://www.techonthenet.com/mysql/comments.php
- Let's try this input injection:
data:image/s3,"s3://crabby-images/f3981/f39814e71bb300d52f72d0a6ba02d9913d04b4fa" alt=""
- It works and the SQL injection is successful:
data:image/s3,"s3://crabby-images/42895/4289574d2f56eb1a8a5603467a4658d8931aba3d" alt=""
- Let's notice the interesting option of uploading files:
data:image/s3,"s3://crabby-images/7a7bf/7a7bfbebc9f33f04abac9d2ebc3f26d506823652" alt=""
4 - REMOTE SHELL WITH WEBSHELL
- Let's try uploading a simple text file:
data:image/s3,"s3://crabby-images/d259d/d259d8f759f27722a8002463df8532ce7c8e4d7d" alt=""
- The server says that only image files (jpg, jpeg, bmp, ...) are allowed:
data:image/s3,"s3://crabby-images/d8d64/d8d640b2b80a28106bec35ff3396f47eb5fe2704" alt=""
- There is a list available of uploaded files:
data:image/s3,"s3://crabby-images/fffcb/fffcbf1ecfce80e8846fa7168eebfbba697f29c2" alt=""
- Now, why not uploading a webshell with the purpose of getting a remote shell? For instance, let's copy php-reverse-shell.php to the working local directory:
data:image/s3,"s3://crabby-images/0301a/0301ad324604a41f5993ef8a40b4ad2be83e58d0" alt=""
- Renaming to .jpeg extension:
data:image/s3,"s3://crabby-images/5cddb/5cddb13cc01cb55d6a0b84c256ec16a5cd34a9bd" alt=""
- Adapting the webshell to our needs:
data:image/s3,"s3://crabby-images/f82be/f82be3988b87a78c5d9bc48436530e3a012c34f7" alt=""
data:image/s3,"s3://crabby-images/ec555/ec5557090d38dbd27038cdb03c0256fbdd4c008a" alt=""
- Setting a listening Netcat session on port 4444:
data:image/s3,"s3://crabby-images/ffe8b/ffe8bb788f9743ef64d49411ddfb63d2dbd91186" alt=""
- Uploading php-reverse-shell-php.jpeg:
data:image/s3,"s3://crabby-images/28f85/28f85c458973b4d2b2f6430482e67c5e2ec0f583" alt=""
- The upload is now successful:
data:image/s3,"s3://crabby-images/aeefc/aeefc6ef2fe89136e3c332d6185c9345c7e12d74" alt=""
data:image/s3,"s3://crabby-images/6064b/6064b8e58700fddb2a842340b8e0fd2061a4d67c" alt=""
- To run the webshell just click View Ticket:
data:image/s3,"s3://crabby-images/3cdad/3cdad6cda68480aa15311802d08e08e144546e77" alt=""
- As a consequence a remote shell is achieved:
data:image/s3,"s3://crabby-images/9f1ae/9f1aea71067afd8c555633e8b29fde527969875b" alt=""
data:image/s3,"s3://crabby-images/80105/80105f4cde3c0eb23f77ef5646238ceee4848e21" alt=""
5 - PRIVILEGE ESCALATION BY EDITING /etc/passwd
- Finding a writable file we discover that /etc/passwd can be modified because it is "world writable":
data:image/s3,"s3://crabby-images/03f5c/03f5cd74c454a069d27d3219b771500d7ac69c59" alt=""
data:image/s3,"s3://crabby-images/054e0/054e0bc702565c38a345356bf9fc7e417994468a" alt=""
data:image/s3,"s3://crabby-images/38dee/38dee85621def9c03bf8445bcb15fe67dcf16590" alt=""
- We can take advantage of this circumstance in two ways:
1) modifying an existing user's credentials
2) creating a new user with root privileges
5.1) modifying an existing user's credentials
- For instance let's focus our attention on the user taviso:
data:image/s3,"s3://crabby-images/5a370/5a37092d8278602d2b9d44fe065b41cfce29bff0" alt=""
- Openssl helps creating an encrypted MD5 salted password, for instance being hello the salt and bye the password:
data:image/s3,"s3://crabby-images/fcdb2/fcdb28a125dc098773a1183a25231df76f1562da" alt=""
- Now, we must combine the /etc/passwd entry for user taviso and the recently created salted password, just replacing the x in this way:
data:image/s3,"s3://crabby-images/91fef/91fef9293d6f308ead8186711f0b0c6817ba8055" alt=""
- Creating a new file passwd by replacing the taviso entry of /etc/passwd with the last line of previous picture:
data:image/s3,"s3://crabby-images/9410b/9410bef6f33dde1145c4e22c8a84a0efcc1badb1" alt=""
- Transferring passwd to Albania:
data:image/s3,"s3://crabby-images/5aaf2/5aaf24556ba0a0bbcf6f2b8e9134bfedec8e05e6" alt=""
data:image/s3,"s3://crabby-images/da566/da566a8bebe0b5c8a8d0b649c23685e87697e7bd" alt=""
- Once the transfer is successful passwd is copied to /etc/passwd:
data:image/s3,"s3://crabby-images/4e804/4e804d7e755301ec4a915d383fa137396eb50660" alt=""
data:image/s3,"s3://crabby-images/fb5e1/fb5e14cd876ce77358a53e0e0ffd685d60d8df26" alt=""
- Finally, SSH-ing to albania with new credentials taviso:bye
data:image/s3,"s3://crabby-images/257c3/257c3657400c82ded231c371406908c563b66c37" alt=""
- Checking sudoer privileges we discover that taviso is able to run ALL commands:
data:image/s3,"s3://crabby-images/aee15/aee15266b5b4f4369c850be69821bd607ac8685a" alt=""
- Getting a root shell:
data:image/s3,"s3://crabby-images/4cdb4/4cdb4e843d484041e0ff336ba69722ed7a897394" alt=""
- Also, instead of SSH-ing it could be possible to follow this procedure:
data:image/s3,"s3://crabby-images/60868/6086886267585fd54e5ce983525180d733fc574f" alt=""
5.2) creating a new user with root privileges
- Using again openssl:
data:image/s3,"s3://crabby-images/e0b81/e0b81ffd2f4f994f1b551a0bd616435b3d00632e" alt=""
- Adding an entry for a new user whitelist and following the procedures in a similar way than 5.1 a), finally we have an /etc/passwd like this:
data:image/s3,"s3://crabby-images/193cb/193cb5308702c204304cde155c7e25d27a72e327" alt=""
- whitelist is ready to start his login session:
data:image/s3,"s3://crabby-images/bce1c/bce1cacbf0e28e6da74bf8f7df893700d3d96ffe" alt=""
- Improving the shell:
data:image/s3,"s3://crabby-images/963ea/963ea5405aed4043cd57efbd10eaaaedccb139fb" alt=""
- Now it works, we check that we have successfully added a new user with root privileges:
data:image/s3,"s3://crabby-images/1b4f8/1b4f8d7752ddaf0dfbd4665bc59cdefefbe3a29b" alt=""
6 - CAPTURING THE FLAG
- Going to the /root folder we can read flag.txt:
data:image/s3,"s3://crabby-images/fafd5/fafd5280fde45164bd3b603bbac54220092b5a1b" alt=""
- Translating flag.txt from Albanian:
data:image/s3,"s3://crabby-images/e5d9b/e5d9b73e1844719b2776ffbb5a9ff9fd7418bff2" alt=""
- About the last string:
data:image/s3,"s3://crabby-images/2cc14/2cc14e823932f1ca08b905abe6d8e49dcbd58c6b" alt=""