Slack

Slack bug paved the way user access theft

Pro
(Image: Slack)

6 March 2017

A bug in Slack, the popular work chat application, was enough for a security researcher to design a hack that could trick users into handing over access to their accounts.

Bug bounty hunter Frans Rosen noticed he could steal Slack access tokens to user accounts due to a flaw in the way the application communicates data in an internet browser.

“Slack missed an important step when using a technology called postMessage,” Rosen said on Wednesday in an email.

PostMessage is a kind of command that can let separate browser windows communicate with each other. In Slack, it is used whenever the chat application opens a new window to enable a voice call.

Ideally, an application that uses postMessage will validate the origin of all data exchanged between separate windows, to keep the process secure. However, Slack was not doing this, according to Rosen.

“Not validating them was a clear indication to me that I could start to do fun stuff,” he wrote in a blog post for security firm Detectify, which he advises.

Once he had discovered the problem, Rosen realised he could siphon a user’s access token through the postMessage bug.

“If you have a browser window, and open a new window by clicking on a link, those two windows can communicate using postMessage,” he said in an email.

But what if one of those windows is an imposter? That is what Rosen essentially created with a malicious web page that can hijack the Slack application.

He demonstrated the theoretical hack in a video. The malicious web page will open a Slack window that then forces a victim’s account to handover its access token.

Fortunately, Slack has fixed the issue. The company has found after a thorough investigation that the flaw was never exploited, according to a posting on HackerOne, a bug bounty platform.

“To work securely with postMessage you always need to verify the origin of every message,” Rosen added.

 

 

 

IDG News Service

Read More:


Back to Top ↑

TechCentral.ie