Files
oneuptime/script-runner/index.js
2021-12-14 18:31:23 +01:00

102 lines
2.9 KiB
JavaScript

const { NODE_ENV } = process.env;
if (!NODE_ENV || NODE_ENV === 'development') {
// Load env vars from /backend/.env
require('custom-env').env();
}
process.on('exit', () => {
// eslint-disable-next-line no-console
console.log('Script runner Shutting Shutdown');
});
process.on('unhandledRejection', err => {
// eslint-disable-next-line no-console
console.error('Unhandled rejection in Script runner process occurred');
// eslint-disable-next-line no-console
console.error(err);
});
process.on('uncaughtException', err => {
// eslint-disable-next-line no-console
console.error('Uncaught exception in Script runner process occurred');
// eslint-disable-next-line no-console
console.error(err);
});
const express = require('express');
const Sentry = require('@sentry/node');
const app = express();
const http = require('http').createServer(app);
const cors = require('cors');
const bodyParser = require('body-parser');
const cron = require('node-cron');
const main = require('./workers/main');
Sentry.init({
dsn: process.env.SENTRY_DSN,
release: `script-runner@${process.env.npm_package_version}`,
environment: process.env.NODE_ENV,
tracesSampleRate: 0.0,
integrations: [
new Sentry.Integrations.OnUncaughtException({
onFatalError() {
// override default behaviour
return;
},
}),
],
});
// Sentry: The request handler must be the first middleware on the app
app.use(Sentry.Handlers.requestHandler());
app.use(cors());
app.use(function(req, res, next) {
if (typeof req.body === 'string') {
req.body = JSON.parse(req.body);
}
res.header('Access-Control-Allow-Credentials', true);
res.header('Access-Control-Allow-Origin', req.headers.origin);
res.header('Access-Control-Allow-Methods', 'GET,PUT,POST,DELETE,OPTIONS');
res.header(
'Access-Control-Allow-Headers',
'X-Requested-With, X-HTTP-Method-Override, Content-Type, Accept,Authorization'
);
return next();
});
app.set('port', process.env.PORT || 3009);
app.use(bodyParser.urlencoded({ limit: '10mb', extended: true }));
app.use(bodyParser.json({ limit: '10mb' }));
app.get(['/script/status', '/status'], function(req, res) {
res.setHeader('Content-Type', 'application/json');
res.send(
JSON.stringify({
status: 200,
message: 'Service Status - OK',
serviceType: 'oneuptime-script-runner',
})
);
});
app.use('/script', require('./api/script'));
app.use(Sentry.Handlers.errorHandler());
global.Sentry = Sentry;
http.listen(app.get('port'), function() {
// eslint-disable-next-line
console.log('Script runner started on port ' + app.get('port'));
});
const cronMinuteStartTime = Math.floor(Math.random() * 50);
// script monitor cron job
cron.schedule('* * * * *', () => {
setTimeout(() => main.runScriptMonitorsJob(), cronMinuteStartTime * 1000);
});