🍀🚘 Checkpoint

./server.js:933874/30256
This commit is contained in:
Glitch (hello-express) 2019-11-04 22:56:58 +00:00
parent 4fcf7d3979
commit 5b893c58a2
1 changed files with 34 additions and 15 deletions

View File

@ -1,6 +1,6 @@
const express = require("express"); const express = require("express");
const app = express(); const app = express();
const https = require('https'); const request = require("request");
var fuzIsOpen = false; var fuzIsOpen = false;
var lastSeen = new Date("1970-01-01"); var lastSeen = new Date("1970-01-01");
@ -75,21 +75,40 @@ const listener = app.listen(process.env.PORT, function() {
console.log("Your app is listening on port " + listener.address().port); console.log("Your app is listening on port " + listener.address().port);
}); });
const loop = () => { request
console.log("loop", lastClosed); .post({
if (lastSeen < new Date() - 2 * 60 * 1000 && lastClosed < lastSeen) { url:
// the Fuz is newly closed, notify on matrix and write file to survive reboot "https://" +
lastClosed = new Date(); process.env.MATRIXUSERNAME.substring(
//lastNofified = new Date(); process.env.MATRIXUSERNAME.indexOf(":") + 1
//https.post ... send message to Fuz process.env.MATRIXROOM ) +
try { "/_matrix/client/r0/login",
fs.writeFileSync(db, JSON.stringify({ fuzIsOpen, lastSeen, lastClosed })); body: JSON.stringify({ type: "m.login.password", user: }),
} catch (err) {} headers: {
} "Content-Type": "application/json"
}
})
.on("response", function(response) {
const loop = () => {
console.log("loop", lastClosed);
if (lastSeen < new Date() - 2 * 60 * 1000 && lastClosed < lastSeen) {
// the Fuz is newly closed, notify on matrix and write file to survive reboot
lastClosed = new Date();
//lastNofified = new Date();
//https.post ... send message to Fuz process.env.MATRIXROOM
setTimeout(loop, 10 * 1000); try {
}; fs.writeFileSync(
setTimeout(loop, 1 * 1000); // give some time for presence button to show up (1 min) db,
JSON.stringify({ fuzIsOpen, lastSeen, lastClosed })
);
} catch (err) {}
}
setTimeout(loop, 10 * 1000);
};
setTimeout(loop, 1 * 1000); // give some time for presence button to show up (1 min)
});
if (process.env.PROJECT_DOMAIN != "") { if (process.env.PROJECT_DOMAIN != "") {
process.on("SIGTERM", function() { process.on("SIGTERM", function() {