aboutsummaryrefslogtreecommitdiff
path: root/client-web/source
diff options
context:
space:
mode:
authormetamuffin <metamuffin@disroot.org>2022-09-09 19:27:18 +0200
committermetamuffin <metamuffin@disroot.org>2022-09-09 19:27:18 +0200
commitd71b0cb3b576e36ad4af64d40af584f05c4d89d3 (patch)
treea939a230011daa6bc8832df337fd72612264e82b /client-web/source
parent962ec1b9a0b44661e46acf81e867e81e87d53038 (diff)
downloadkeks-meet-d71b0cb3b576e36ad4af64d40af584f05c4d89d3.tar
keks-meet-d71b0cb3b576e36ad4af64d40af584f05c4d89d3.tar.bz2
keks-meet-d71b0cb3b576e36ad4af64d40af584f05c4d89d3.tar.zst
minor adjustments
Diffstat (limited to 'client-web/source')
-rw-r--r--client-web/source/index.ts2
-rw-r--r--client-web/source/protocol/crypto.ts25
2 files changed, 16 insertions, 11 deletions
diff --git a/client-web/source/index.ts b/client-web/source/index.ts
index e8bbc0b..7dfdb59 100644
--- a/client-web/source/index.ts
+++ b/client-web/source/index.ts
@@ -36,7 +36,7 @@ export async function main() {
if (!globalThis.isSecureContext) log({ scope: "*", warn: true }, "This page is not in a 'Secure Context'")
if (!globalThis.crypto.subtle) return log({ scope: "crypto", error: true }, "SubtleCrypto not availible")
if (room_name.length < 8) log({ scope: "crypto", warn: true }, "Room name is very short. e2ee is insecure!")
- if (room_name.length == 0) window.location.href = "/" // send them back to the start page
+ if (room_name.length == 0) return window.location.href = "/" // send them back to the start page
if (PREFS.warn_redirect) log({ scope: "crypto", warn: true }, "You were redirected from the old URL format. The server knows you room name now - e2ee is insecure!")
const conn = await (new SignalingConnection().connect(room_name))
diff --git a/client-web/source/protocol/crypto.ts b/client-web/source/protocol/crypto.ts
index 79b7e1d..654e80b 100644
--- a/client-web/source/protocol/crypto.ts
+++ b/client-web/source/protocol/crypto.ts
@@ -56,16 +56,21 @@ export async function crypto_encrypt(key: CryptoKey, data: string): Promise<stri
}
export async function crypt_decrypt(key: CryptoKey, data: string): Promise<string> {
- const buf = base64_to_buf(data);
- const iv = buf.slice(0, IV_LENGTH);
- const ciphertext = buf.slice(IV_LENGTH);
- const decryptedContent = await window.crypto.subtle.decrypt(
- { name: "AES-GCM", iv },
- key,
- ciphertext
- );
- const plain = new TextDecoder().decode(decryptedContent);
- return plain
+ try {
+ const buf = base64_to_buf(data);
+ const iv = buf.slice(0, IV_LENGTH);
+ const ciphertext = buf.slice(IV_LENGTH);
+ const decryptedContent = await window.crypto.subtle.decrypt(
+ { name: "AES-GCM", iv },
+ key,
+ ciphertext
+ );
+ const plain = new TextDecoder().decode(decryptedContent);
+ return plain
+ } catch (_e) {
+ log({ scope: "crypto", warn: true }, "unable to decrypt")
+ return "{}" // :)
+ }
}
export function base64_to_buf(data: string): Uint8Array {