Percent-encode URL path when reporting spam
This commit is contained in:
parent
6ddb12cd99
commit
7f0ed2599d
3 changed files with 27 additions and 3 deletions
|
@ -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'
|
||||
);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
|
|
@ -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',
|
||||
});
|
||||
}
|
||||
|
|
|
@ -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('/')}`;
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue