Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/bobbyrsec/Microsoft-Teams-GIFShell
https://github.com/bobbyrsec/Microsoft-Teams-GIFShell
Last synced: about 2 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/bobbyrsec/Microsoft-Teams-GIFShell
- Owner: bobbyrsec
- Created: 2022-05-17T01:33:58.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2022-09-13T18:15:13.000Z (over 2 years ago)
- Last Synced: 2024-08-03T21:02:03.745Z (5 months ago)
- Language: Python
- Size: 55.7 KB
- Stars: 222
- Watchers: 5
- Forks: 34
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- Awesome-Azure-Pentest - Microsoft-Teams-GIFShell - Microsoft Teams can be leveraged by an attacker, to execute a reverse shell between an attacker and victim piped through malicious GIFs sent in Teams messages (Tools / Exploitation)
README
# Microsoft-Teams-GIFShell
Press:
https://www.bleepingcomputer.com/news/security/gifshell-attack-creates-reverse-shell-using-microsoft-teams-gifs/
Technical Blogs:
https://medium.com/@bobbyrsec/gifshell-covert-attack-chain-and-c2-utilizing-microsoft-teams-gifs-1618c4e64ed7
https://medium.com/@bobbyrsec/microsoft-teams-attachment-spoofing-and-lack-of-permissions-enforcement-leads-to-rce-via-ntlm-458aea1826c5
**Replication Steps:**
There are a few prerequisites required to replicate the attack chain above:
* The GIFShell Python script, which should be executed on the attacker’s machine
* The GIFShell Powershell stager, executed on the victim’s machine
* Two Microsoft Azure Organizations or Tenants. The attacker organization or tenant should have at least 2 users, and the victim organization should have at least 1 user. This is for testing the Microsoft Teams Work Edition
* Two Microsoft Teams users for personal use. This is for testing the Microsoft Teams Home Edition
* A Teams channel with a publicly available webhook
* A GIF of your choice
* A public facing IP which can be used as a listener for incoming web requests**Steps:**
1) Open the Python script, and edit instances of the `token` variable with the `skypetoken_asm` cookie value from your authenticated browser session running Microsoft Teams as the attacker
2) Open Microsoft Teams as an attacker, and create a new chat with the victim. Look at the network traffic, and extract the Teams URL of this conversation. The URL should be in the form
`“https://amer.ng.msg.teams.microsoft.com/v1/users/ME/conversations/@unq.gbl.spaces/messages”`3) Open the GIFShell Python script, and edit instances of the `burp_url` variable with the URL from Step #2
4) Open the Microsoft Teams chat associated with the webhook created by the attacker, in the authenticated browser session running Microsoft Teams as the attacker
5) Run the GIFShell Python script on the attacking machine - this will create a prompt to enter desired commands to be run on the victim’s machine.
6) Open the GIFShell Powershell stager script, and edit the $originalendpoint and $gifendpoint variables, changing the domain to the public IP address of the attacking machine
7) Open The GIFShell Powershell stager script, and edit the $response variable, changing the webhook, to the value of the attacker’s publicly available webhook
8) Run the Powershell stager script on the victim’s machine
9) Execute the desired commands in the GIFShell Python script prompt
10) Ensure that while the desired commands are being executed, the Teams application is open to the chat associated with the publicly available webhook.