-
1
-
2
-
3
-
4
-
5
-
6
-
7
-
8
-
9
-
10
-
11
-
12
-
13
-
14
-
15
-
16
-
17
-
18
-
19
-
20
-
21
-
22
-
23
-
24
-
25
-
26
-
27
-
28
-
29
-
30
-
31
-
32
-
33
-
34
-
35
-
36
-
37
-
38
-
39
-
40
-
41
-
42
-
43
-
44
-
45
-
46
-
47
-
48
-
49
-
50
-
51
-
52
-
53
-
54
-
55
-
56
-
57
-
58
-
59
-
60
-
61
-
62
-
63
-
64
-
65
-
66
-
67
-
68
-
69
-
70
-
71
-
72
-
73
-
74
-
75
-
76
-
77
-
78
-
79
-
80
-
81
-
82
-
83
// SPDX-FileCopyrightText: 2024 Shota FUJI <pockawoooh@gmail.com>
// SPDX-License-Identifier: AGPL-3.0-only
import { isValidMessage, type Message } from "./worker/message.ts";
import { encode_list_request, decode_list_response } from "./app.gleam";
const button = document.createElement("button");
button.textContent = "Send Message";
button.disabled = true;
document.body.appendChild(button);
const pre = document.createElement("pre");
const output = document.createElement("output");
pre.appendChild(output);
document.body.appendChild(pre);
const worker = new Worker(new URL("./worker/main.ts", import.meta.url), {
type: "module",
});
interface RequestParameters {
service: string;
method: string;
request: Uint8Array;
}
function request({ service, method, request }: RequestParameters): Promise<Uint8Array> {
const id = crypto.randomUUID();
return new Promise((resolve) => {
const handler = (event: MessageEvent) => {
if (!isValidMessage(event.data) || event.data.id !== id) {
return;
}
worker.removeEventListener("message", handler);
if (event.data.service !== service || event.data.method !== method) {
throw new Error(
`Received response with incorrect service/method: expected=${service}.${method}, received=${event.data.service}/${event.data.method}`,
);
}
resolve(event.data.data);
};
worker.addEventListener("message", handler);
worker.postMessage(
{
id,
service,
method,
data: request,
} satisfies Message,
{
transfer: [request.buffer],
},
);
});
}
worker.addEventListener(
"message",
(ev) => {
if (ev.data === "ready") {
button.disabled = false;
button.addEventListener("click", async (ev) => {
ev.preventDefault();
const resp = await request({
service: "yamori.workspace.v1.KeyValueStorageBasedWorkspaceService",
method: "List",
request: encode_list_request(),
});
output.textContent += "\n" + JSON.stringify(decode_list_response(resp), null, 2);
});
}
},
{ once: true },
);