summaryrefslogtreecommitdiff
path: root/client-web
diff options
context:
space:
mode:
authormetamuffin <metamuffin@disroot.org>2022-10-13 09:11:56 +0200
committermetamuffin <metamuffin@disroot.org>2022-10-13 09:11:56 +0200
commitbc8bba637e51d1c813c3edcf8747991dc69319e9 (patch)
treedba56c517f5de623ce46ec18a065cc274d8e92dc /client-web
parentc8ac1b899f7a79898b3ec84157db642051e8e1ae (diff)
downloadkeks-meet-bc8bba637e51d1c813c3edcf8747991dc69319e9.tar
keks-meet-bc8bba637e51d1c813c3edcf8747991dc69319e9.tar.bz2
keks-meet-bc8bba637e51d1c813c3edcf8747991dc69319e9.tar.zst
modify client-web to not sent big messages
Diffstat (limited to 'client-web')
-rw-r--r--client-web/source/helper.ts2
-rw-r--r--client-web/source/resource/file.ts8
2 files changed, 7 insertions, 3 deletions
diff --git a/client-web/source/helper.ts b/client-web/source/helper.ts
index adb5f08..f53c945 100644
--- a/client-web/source/helper.ts
+++ b/client-web/source/helper.ts
@@ -85,4 +85,4 @@ export function notify(body: string, author?: string) {
new Notification(`keks-meet`, { body })
}
-export function sleep(delay: number) { return new Promise(r => setTimeout(r, delay)) } \ No newline at end of file
+export function sleep(delay: number) { return new Promise(r => setTimeout(r, delay)) }
diff --git a/client-web/source/resource/file.ts b/client-web/source/resource/file.ts
index 6cf3ff6..18a1ac7 100644
--- a/client-web/source/resource/file.ts
+++ b/client-web/source/resource/file.ts
@@ -9,6 +9,8 @@ import { ebutton, ediv, espan, sleep } from "../helper.ts";
import { log } from "../logger.ts";
import { LocalResource, ResourceHandlerDecl } from "./mod.ts";
+const MAX_CHUNK_SIZE = 1 << 15;
+
export const resource_file: ResourceHandlerDecl = {
kind: "file",
new_remote(info, user, enable) {
@@ -111,11 +113,13 @@ function file_res_inner(file: File): LocalResource {
return channel.close()
}
const feed = async () => {
- const { value: chunk, done } = await reader.read()
+ const { value: chunk, done }: { value: Uint8Array, done: boolean } = await reader.read()
if (done) return await finish()
if (!chunk) console.warn("no chunk");
position += chunk.length
- channel.send(chunk)
+ for (let i = 0; i < chunk.length; i += MAX_CHUNK_SIZE) {
+ channel.send(chunk.slice(i, Math.min(i + MAX_CHUNK_SIZE, chunk.length)))
+ }
display.status = `${position} / ${file.size} (buffer: ${channel.bufferedAmount})`
}
const feed_until_full = async () => {