aboutsummaryrefslogtreecommitdiff
path: root/source/client/room.ts
blob: 72d7df1d52b403fba873839f69dc9da82694c289 (plain)
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
import { log } from "./logger.ts";
import { RemoteUser } from "./remote_user.ts";
import { User } from "./user.ts";
import { LocalUser } from "./local_user.ts";
import { hex_id, parameter_string } from "./helper.ts";
import { CSPacket, SCPacket } from "../packets.ts";


export class Room {
    el: HTMLElement
    name: string
    users: Map<string, User> = new Map()
    remote_users: Map<string, RemoteUser> = new Map()
    local_user: LocalUser
    websocket: WebSocket

    constructor(name: string) {
        this.name = name
        this.el = document.createElement("div")
        this.el.classList.add("room")
        this.websocket = new WebSocket(`${window.location.protocol.endsWith("s:") ? "wss" : "ws"}://${window.location.host}/signaling/${encodeURIComponent(name)}`)
        this.websocket.onclose = () => this.websocket_close()
        this.websocket.onopen = () => this.websocket_open()
        this.websocket.onmessage = (ev) => {
            this.websocket_message(JSON.parse(ev.data))
        }
        this.local_user = new LocalUser(this, parameter_string("username", `guest-${hex_id()}`))
    }

    websocket_send(data: CSPacket) {
        log("ws", `-> ${data.receiver ?? "*"}`, data)
        this.websocket.send(JSON.stringify(data))
    }
    websocket_message(packet: SCPacket) {
        if (packet.join) {
            log("*", `${this.name} ${packet.sender} joined`);
            const ru = new RemoteUser(this, packet.sender)
            this.local_user.add_initial_to_remote(ru)
            if (!packet.stable) ru.offer()
            this.users.set(packet.sender, ru)
            this.remote_users.set(packet.sender, ru)
            return
        }
        const sender = this.remote_users.get(packet.sender)
        if (!sender) return console.warn(`unknown sender ${packet.sender}`)
        if (packet.leave) {
            log("*", `${this.name} ${packet.sender} left`);
            sender.leave()
            this.users.delete(packet.sender)
            this.remote_users.delete(packet.sender)
            return
        }
        if (!packet.data) return console.warn("dataless packet")
        log("ws", `<- ${packet.sender}: `, packet.data);
        if (packet.data.ice_candiate) sender.add_ice_candidate(packet.data.ice_candiate)
        if (packet.data.offer) sender.on_offer(packet.data.offer)
        if (packet.data.answer) sender.on_answer(packet.data.answer)
    }
    websocket_close() {
        log("ws", "websocket closed");
        setTimeout(() => {
            window.location.reload()
        }, 1000)
    }
    websocket_open() {
        log("ws", "websocket opened");
        this.websocket.send(this.local_user.name)
    }
}