Skip to content

Commit

Permalink
[Fix] parses comma delimited array while having percent-encoded comma…
Browse files Browse the repository at this point in the history
… treated as normal text

Co-authored-by: Mohamed Omar <[email protected]>
Co-authored-by: Quentin de Longraye <[email protected]>
  • Loading branch information
2 people authored and ljharb committed Oct 18, 2019
1 parent 37f6a6b commit cd9a3cd
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 1 deletion.
10 changes: 9 additions & 1 deletion lib/parse.js
Original file line number Diff line number Diff line change
Expand Up @@ -85,7 +85,15 @@ var parseValues = function parseQueryStringValues(str, options) {
val = options.strictNullHandling ? null : '';
} else {
key = options.decoder(part.slice(0, pos), defaults.decoder, charset, 'key');
val = options.decoder(part.slice(pos + 1), defaults.decoder, charset, 'value');
var encodedVal = part.slice(pos + 1);
if (options.comma && encodedVal.indexOf(',') !== -1) {
val = encodedVal.split(',')
.map(function (encodedFragment) {
return options.decoder(encodedFragment, defaults.decoder, charset, 'value');
});
} else {
val = options.decoder(encodedVal, defaults.decoder, charset, 'value');
}
}

if (val && options.interpretNumericEntities && charset === 'iso-8859-1') {
Expand Down
8 changes: 8 additions & 0 deletions test/parse.js
Original file line number Diff line number Diff line change
Expand Up @@ -429,6 +429,14 @@ test('parse()', function (t) {
st.end();
});

t.test('parses comma delimited array while having percent-encoded comma treated as normal text', function (st) {
st.deepEqual(qs.parse('foo=a%2Cb', { comma: true }), { foo: ['a', 'b'] });
st.deepEqual(qs.parse('foo=a%2C%20b,d', { comma: true }), { foo: ['a, b', 'd'] });
st.deepEqual(qs.parse('foo=a%2C%20b,c%2C%20d', { comma: true }), { foo: ['a, b', 'c, d'] });

st.end();
});

t.test('parses an object in dot notation', function (st) {
var input = {
'user.name': { 'pop[bob]': 3 },
Expand Down

0 comments on commit cd9a3cd

Please sign in to comment.