mirror of
https://github.com/socketio/socket.io.git
synced 2026-04-30 03:00:39 -04:00
A specially crafted packet could be incorrectly decoded.
Example:
```js
const decoder = new Decoder();
decoder.on("decoded", (packet) => {
console.log(packet.data); // prints [ 'hello', [Function: splice] ]
})
decoder.add('51-["hello",{"_placeholder":true,"num":"splice"}]');
decoder.add(Buffer.from("world"));
```
As usual, please remember not to trust user input.
Backported from b5d0cb7dc5
69 lines
2.0 KiB
JavaScript
69 lines
2.0 KiB
JavaScript
var parser = require('../index.js');
|
|
var expect = require('expect.js');
|
|
var helpers = require('./helpers.js');
|
|
var Decoder = parser.Decoder;
|
|
|
|
describe('parser', function() {
|
|
it('encodes a Buffer', function() {
|
|
helpers.test_bin({
|
|
type: parser.BINARY_EVENT,
|
|
data: ['a', new Buffer('abc', 'utf8')],
|
|
id: 23,
|
|
nsp: '/cool'
|
|
});
|
|
});
|
|
|
|
it("encodes a nested Buffer", function() {
|
|
helpers.test_bin({
|
|
type: parser.BINARY_EVENT,
|
|
data: ["a", { b: ["c", Buffer.from("abc", "utf8")] }],
|
|
id: 23,
|
|
nsp: "/cool",
|
|
});
|
|
});
|
|
|
|
it('encodes a binary ack with Buffer', function() {
|
|
helpers.test_bin({
|
|
type: parser.BINARY_ACK,
|
|
data: ['a', new Buffer('xxx', 'utf8'), {}],
|
|
id: 127,
|
|
nsp: '/back'
|
|
})
|
|
});
|
|
|
|
it("throws an error when adding an attachment with an invalid 'num' attribute (string)", function() {
|
|
var decoder = new Decoder();
|
|
|
|
expect(function() {
|
|
decoder.add('51-["hello",{"_placeholder":true,"num":"splice"}]');
|
|
decoder.add(Buffer.from("world"));
|
|
}).to.throwException(/^illegal attachments$/);
|
|
});
|
|
|
|
it("throws an error when adding an attachment with an invalid 'num' attribute (out-of-bound)", function() {
|
|
var decoder = new Decoder();
|
|
|
|
expect(function() {
|
|
decoder.add('51-["hello",{"_placeholder":true,"num":1}]');
|
|
decoder.add(Buffer.from("world"));
|
|
}).to.throwException(/^illegal attachments$/);
|
|
});
|
|
|
|
it("throws an error when adding an attachment without header", function() {
|
|
var decoder = new Decoder();
|
|
|
|
expect(function() {
|
|
decoder.add(Buffer.from("world"));
|
|
}).to.throwException(/^got binary data when not reconstructing a packet$/);
|
|
});
|
|
|
|
it("throws an error when decoding a binary event without attachments", function() {
|
|
var decoder = new Decoder();
|
|
|
|
expect(function() {
|
|
decoder.add('51-["hello",{"_placeholder":true,"num":0}]');
|
|
decoder.add('2["hello"]');
|
|
}).to.throwException(/^got plaintext data when reconstructing a packet$/);
|
|
});
|
|
});
|