Files
old-web/index.js

60 lines
1.6 KiB
JavaScript
Raw Permalink Normal View History

const express = require("express");
const path = require("path");
const bodyParser = require("body-parser");
const layout = require("express-layout");
const compression = require("compression");
2019-10-16 12:49:58 +02:00
const forceSSL = require("./app/helpers/forceSSL");
2020-09-13 04:48:11 -07:00
const { logDebug } = require("./app/helpers/log");
const {
APP_PORT,
CRAWLER_INTERVAL,
STOP_CRAWLER
} = require("./app/config/appConfig");
const routes = require("./app/routes");
const { crawlAll } = require("./app/crawler/crawl");
2020-01-24 01:01:10 +01:00
const { checkUpNotify } = require("./app/services/notificationService");
const {
notifyForNewRealEstates
} = require("./app/services/notificationService");
const app = express();
2019-10-16 12:49:58 +02:00
app.use(forceSSL());
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: true }));
app.set("views", path.join(__dirname, "/app/views"));
app.set("view engine", "ejs");
app.use(layout());
2019-03-26 05:09:53 +01:00
2019-04-13 10:38:25 +02:00
app.use(compression());
app.use("/", routes);
app.use("/assets", express.static("./app/public"));
2019-03-13 05:43:48 +01:00
app.listen(APP_PORT, () =>
console.log(`Example app listening on port ${APP_PORT}!`)
);
let crawlerRunning = STOP_CRAWLER;
const crawl = () => {
2020-09-13 23:45:08 +02:00
logDebug("Crawl start. crawlerRunning: ", crawlerRunning);
if (!crawlerRunning) {
crawlerRunning = true;
crawlAll().then(newRealEstates => {
2020-09-13 04:48:11 -07:00
logDebug("crawlAll done, new real estate len: ", newRealEstates.length);
notifyForNewRealEstates(newRealEstates);
2020-09-14 14:46:21 -07:00
}).catch(e => {
console.error('Error happened: ', e);
}).finally(()=> {
crawlerRunning = false;
logDebug('Finally done!');
});
}
};
2020-01-24 01:01:10 +01:00
setInterval(crawl, CRAWLER_INTERVAL * 1000);
2020-01-24 01:01:10 +01:00
setInterval(checkUpNotify, 1000 * 60 * 60 * 24);