-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathindex.js
79 lines (65 loc) · 1.82 KB
/
index.js
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
const Logger = new (require("./src/Logger"))("index");
const Goggles = require("./src/Goggles");
const OMXPlayer = require("./src/OMXPlayer");
const HttpServer = require("./src/HttpServer");
const WebSocketServer = require("./src/WebSocketServer");
const FFmpeg = require("./src/FFmpeg");
let http = new HttpServer(__dirname + "/public", 80);
let ws = new WebSocketServer(http);
let ffmpeg = new FFmpeg();
let consumers = [new OMXPlayer(2), new OMXPlayer(7)];
http.listen();
let lastProcessed = 0;
ws.on("connection", (socket, request) => {
Logger.info(`client connected from ${request.socket.remoteAddress}`);
lastProcessed = Date.now();
ffmpeg.start();
socket.on("close", () => {
if (ws.clients.size === 0) {
ffmpeg.stop();
}
});
});
ffmpeg.on("data", (data) => {
lastProcessed = Date.now();
ws.broadcast(data);
});
setInterval(() => {
if (Goggles.goggles && !ffmpeg.stopped && ws.clients.size > 0 && Date.now() - lastProcessed > 5000) {
Logger.error("ffmpeg stopped sending data to websocket, restarting!");
ffmpeg.stop();
ffmpeg.start();
lastProcessed = Date.now();
}
}, 1000);
Goggles.scan();
Goggles.on("attach", () => {
Logger.info("attach");
for (let consumer of consumers) consumer.start();
});
Goggles.on("data", (data) => {
for (let consumer of consumers) consumer.feed(data);
ffmpeg.feed(data);
});
Goggles.on("error", (error) => {
Logger.error(error);
});
Goggles.on("detach", () => {
Logger.info("detach");
for (let consumer of consumers) consumer.stop();
ffmpeg.stop();
});
Goggles.on("stop", () => {
Logger.info("stop");
for (let consumer of consumers) consumer.stop();
ffmpeg.stop();
Logger.info("Bye!");
process.exit(0);
});
process.on("SIGINT", () => {
Goggles.stop();
});
process.on("uncaughtException", (err) => {
Logger.error(err);
Goggles.stop();
});