data:image/s3,"s3://crabby-images/c4fc3/c4fc3d5b00bc36e95ac50db29df85ba59ac0bf7c" alt="Slack online web"
data:image/s3,"s3://crabby-images/d5d57/d5d57ef95c12189c5ade1a70234cd3124de3ef74" alt="slack online web slack online web"
What we’ve done is saved a reference to a real pong (which we cannot easily clone), and made the data attribute writeable. It’s okay to admit that forging a trusted message is exciting. To save you yet more time, one cannot just forge a trusted EventMessage object (a real message received by WebSocket) and modify it some engineering needs to be done to tamper with a read-only event message to return a valid pong, such as making the data attribute writeable. It’s trivial to spoof a pong from the DevTools console, but we shouldn’t be satisfied sending a simple JSON string as a pong, though let’s really forge a trusted EventMessage with all the trappings and attributes of a real message received on the wire. Instead, let’s intercept the ping, massage it into a tickle, and “receive” a well-crafted pong into the WebSocket layer so the client-side JavaScript is satisfied.
data:image/s3,"s3://crabby-images/5de07/5de074b6ba2ff242274af9a4813d0bb416452f80" alt="slack online web slack online web"
What happened is no more pings were sent after one ping was framejacked and then Slack just stopped working a short while later. Should we prevent the socket from being closed? Here is an experiment I ran by editing the cache of a Slack JavaScript file. Let’s not interfere with the Slack JavaScript or try to hack private variables.
data:image/s3,"s3://crabby-images/58b3a/58b3a7380bb3ab1e861b1854fe18f64501959823" alt="slack online web slack online web"
Question: How can we safely framejack a ping then?
data:image/s3,"s3://crabby-images/c4fc3/c4fc3d5b00bc36e95ac50db29df85ba59ac0bf7c" alt="Slack online web"