Percent-encode URL path when reporting spam

This commit is contained in:
Evan Hahn 2023-01-19 13:53:04 -06:00 committed by GitHub
parent 6ddb12cd99
commit 7f0ed2599d
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 27 additions and 3 deletions

View file

@ -4,7 +4,11 @@
import { assert } from 'chai';
import { size } from '../../util/iterables';
import { maybeParseUrl, setUrlSearchParams } from '../../util/url';
import {
maybeParseUrl,
setUrlSearchParams,
urlPathFromComponents,
} from '../../util/url';
describe('URL utilities', () => {
describe('maybeParseUrl', () => {
@ -84,4 +88,18 @@ describe('URL utilities', () => {
assert.strictEqual(newUrl.search, '?foo=bar');
});
});
describe('urlPathFromComponents', () => {
it('returns / if no components are provided', () => {
assert.strictEqual(urlPathFromComponents([]), '/');
});
it('joins components, percent-encoding them and removing empty components', () => {
const components = ['foo', '', '~', 'bar / baz qúx'];
assert.strictEqual(
urlPathFromComponents(components),
'/foo/~/bar%20%2F%20baz%20q%C3%BAx'
);
});
});
});

View file

@ -54,7 +54,7 @@ import type {
} from './Types.d';
import { handleStatusCode, translateError } from './Utils';
import * as log from '../logging/log';
import { maybeParseUrl } from '../util/url';
import { maybeParseUrl, urlPathFromComponents } from '../util/url';
// Note: this will break some code that expects to be able to use err.response when a
// web request fails, because it will force it to text. But it is very useful for
@ -1780,7 +1780,7 @@ export function initialize({
await _ajax({
call: 'reportMessage',
httpType: 'POST',
urlParameters: `/${senderUuid}/${serverGuid}`,
urlParameters: urlPathFromComponents([senderUuid, serverGuid]),
responseType: 'bytes',
});
}

View file

@ -33,3 +33,9 @@ function cloneUrl(url: Readonly<URL>): URL {
function stringifySearchParamValue(value: unknown): string {
return value == null ? '' : String(value);
}
export function urlPathFromComponents(
components: ReadonlyArray<string>
): string {
return `/${components.filter(Boolean).map(encodeURIComponent).join('/')}`;
}