155 lines
4.5 KiB
JavaScript
155 lines
4.5 KiB
JavaScript
const Base = require("./Base");
|
|
const OBSWebSocket = require('obs-websocket-js');
|
|
const db = require("../db.json");
|
|
|
|
class OBS extends Base {
|
|
static name = "OBS";
|
|
static type = "obs";
|
|
static fields = {
|
|
cmd: {
|
|
type: "select",
|
|
options: ["startStreaming", "stopStreaming", "toggleStreaming", "startRecording", "stopRecording", "toggleRecording"],
|
|
name: "Action",
|
|
required: true
|
|
}
|
|
};
|
|
static obs = new OBSWebSocket();
|
|
|
|
constructor(text, image = null, options = null) {
|
|
super(text, image, options);
|
|
}
|
|
|
|
static config() {
|
|
return {
|
|
host: {
|
|
type: "text",
|
|
name: "Address",
|
|
required: true,
|
|
value: db.types[OBS.type].host,
|
|
},
|
|
port: {
|
|
type: "number",
|
|
name: "Port",
|
|
required: true,
|
|
value: db.types[OBS.type].port,
|
|
},
|
|
password: {
|
|
type: "password",
|
|
name: "password",
|
|
value: db.types[OBS.type].password
|
|
}
|
|
}
|
|
};
|
|
|
|
/**
|
|
* @override
|
|
*/
|
|
static saveConfig(configuration) {
|
|
super.saveConfig(OBS.type, configuration)
|
|
}
|
|
|
|
/**
|
|
* @override
|
|
*/
|
|
static staticToJSON() {
|
|
return super.staticToJSON(OBS.name, OBS.type, OBS.fields, OBS.config());
|
|
}
|
|
|
|
/**
|
|
* @override
|
|
*/
|
|
toJSON() {
|
|
return super.toJSON(OBS.type)
|
|
}
|
|
|
|
static async connect() {
|
|
const config = OBS.config();
|
|
try {
|
|
await OBS.obs.connect({
|
|
address: config.host.value + ":" + config.port.value,
|
|
password: config.password.value
|
|
});
|
|
return true;
|
|
} catch (err) {
|
|
console.error("Fail to connect !");
|
|
console.error(err);
|
|
return false;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @override
|
|
*/
|
|
async trigger(socket) {
|
|
try {
|
|
switch (this.options.cmd) {
|
|
case "startStreaming":
|
|
await OBS.obs.send("StartStreaming");
|
|
break;
|
|
case "stopStreaming":
|
|
await OBS.obs.send("StopStreaming");
|
|
break;
|
|
case "toggleStreaming":
|
|
try {
|
|
await OBS.obs.send("StartStreaming");
|
|
} catch (err) {
|
|
if (err.error === "streaming already active")
|
|
await OBS.obs.send("StopStreaming");
|
|
else
|
|
throw err;
|
|
}
|
|
break;
|
|
case "startRecording":
|
|
await OBS.obs.send("StartRecording");
|
|
break;
|
|
case "stopRecording":
|
|
await OBS.obs.send("StopRecording");
|
|
break;
|
|
case "toggleRecording":
|
|
try {
|
|
await OBS.obs.send("StartRecording");
|
|
} catch (err) {
|
|
if (err.error === "recording already active")
|
|
await OBS.obs.send("StopRecording");
|
|
else
|
|
throw err;
|
|
}
|
|
break;
|
|
}
|
|
} catch (err) {
|
|
switch (err.error) {
|
|
case "There is no Socket connection available.":
|
|
if (!await OBS.connect())
|
|
socket.emit("trigger", {error: "failToConnectOBS"});
|
|
else
|
|
this.trigger(socket);
|
|
break;
|
|
case "streaming already active":
|
|
console.error("Streaming already active");
|
|
break;
|
|
case "streaming not active":
|
|
console.error("Streaming not active");
|
|
break;
|
|
case "recording already active":
|
|
console.error("Recording already active");
|
|
break;
|
|
case "recording not active":
|
|
console.error("Recording not active");
|
|
break;
|
|
default:
|
|
throw err;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
if (!(OBS.type in db.types)) {
|
|
db.types[OBS.type] = {};
|
|
OBS.write();
|
|
}
|
|
|
|
OBS.obs.on("error", err => {
|
|
console.error("socket error:", err);
|
|
});
|
|
|
|
module.exports = OBS;
|