yamori

有給休暇計算を主目的とした簡易勤怠管理システム

  1. 1
  2. 2
  3. 3
  4. 4
  5. 5
  6. 6
  7. 7
  8. 8
  9. 9
  10. 10
  11. 11
  12. 12
  13. 13
  14. 14
  15. 15
  16. 16
  17. 17
  18. 18
  19. 19
  20. 20
  21. 21
  22. 22
  23. 23
  24. 24
  25. 25
  26. 26
  27. 27
  28. 28
  29. 29
  30. 30
  31. 31
  32. 32
  33. 33
  34. 34
  35. 35
  36. 36
  37. 37
  38. 38
  39. 39
  40. 40
  41. 41
  42. 42
  43. 43
  44. 44
  45. 45
  46. 46
  47. 47
  48. 48
  49. 49
  50. 50
  51. 51
  52. 52
  53. 53
  54. 54
  55. 55
  56. 56
  57. 57
// SPDX-FileCopyrightText: 2025 Shota FUJI <pockawoooh@gmail.com>
// SPDX-License-Identifier: AGPL-3.0-only
//
// go-wasm-http-server の sw.js を WebWorker で動くようにしたもの。
// I/F を揃えているが、 Go の JS シムに触れているため、 Go や
// go-wasm-http-server をアップグレードする際には入念に確認すること。

import initSqlJs from "sql.js";
import sqlJsWasmUrl from "sql.js/dist/sql-wasm.wasm?url";

import "./backend_prelude.js";

const wasmUrl = new URL("./backend.wasm", import.meta.url);

async function setup() {
	const handler = new Promise((resolve) => {
		self.wasmhttp = {
			path: "/",
			setHandler: resolve,
		};
	});

	self.addEventListener("message", async (event) => {
		const req = new Request(event.data.input, event.data.options);

		const resp = await (await handler)(req);

		const body = await resp.arrayBuffer();

		self.postMessage(
			{
				id: event.data.id,
				body,
				headers: Object.fromEntries(resp.headers.entries()),
			},
			{
				transfer: [body],
			},
		);
	});

	const [wasm, sqlJs] = await Promise.all([
		fetch(wasmUrl),
		initSqlJs({ locateFile: (_file) => sqlJsWasmUrl }),
	]);

	self._go_sqlite = sqlJs;

	const go = new Go();
	go.argv = [wasmUrl];

	WebAssembly.instantiateStreaming(wasm, go.importObject).then(({ instance }) =>
		go.run(instance),
	);
}

setup();