This commit is contained in:
Half-Shot
2025-07-21 11:41:18 +01:00
parent b722d7bdab
commit 99c4686689
2 changed files with 11 additions and 14 deletions

View File

@@ -82,14 +82,11 @@ describe("UrlParams", () => {
getRoomIdentifierFromUrl("", `?roomId=${ROOM_ID}`, "").roomId,
).toBe(ROOM_ID);
});
it("(roomId with unprintable chatacters)", () => {
it("handles params with unprintable characters", () => {
const invisibleChar = "\u2066";
expect(
getRoomIdentifierFromUrl(
"",
`?roomId=${invisibleChar}${ROOM_ID}${invisibleChar}`,
"",
).roomId,
getRoomIdentifierFromUrl("", `?roomId=${ROOM_ID}${invisibleChar}`, "")
.roomId,
).toBe(ROOM_ID);
});
});

View File

@@ -220,6 +220,8 @@ class ParamParser {
private queryParams: URLSearchParams;
public constructor(search: string, hash: string) {
// Replace any non-printable characters that another client may have inserted.
search = search.replaceAll(/^[^ -~]+|[^ -~]+$/g, "");
this.queryParams = new URLSearchParams(search);
const fragmentQueryStart = hash.indexOf("?");
@@ -258,6 +260,8 @@ export const getUrlParams = (
search = window.location.search,
hash = window.location.hash,
): UrlParams => {
// Replace any non-printable characters that another client may have inserted.
search = search.replaceAll(/^[^ -~]+|[^ -~]+$/g, "");
const parser = new ParamParser(search, hash);
const fontScale = parseFloat(parser.getParam("fontScale") ?? "");
@@ -387,14 +391,10 @@ export function getRoomIdentifierFromUrl(
// Make sure roomId is valid
let roomId: string | null = parser.getParam("roomId");
if (roomId !== null) {
// Replace any non-printable characters that another client may have inserted.
roomId = roomId.replaceAll(/^[^ -~]+|[^ -~]+$/g, "");
if (!roomId.startsWith("!")) {
roomId = null;
} else if (!roomId.includes("")) {
roomId = null;
}
if (!roomId?.startsWith("!")) {
roomId = null;
} else if (!roomId.includes("")) {
roomId = null;
}
return {