Skip to content

Commit

Permalink
Merge pull request #499 from bitholla/bug-fixes
Browse files Browse the repository at this point in the history
Bug fixes
  • Loading branch information
abeikverdi authored Jan 26, 2021
2 parents 2f39a83 + 59d11f9 commit 5e8d348
Show file tree
Hide file tree
Showing 3 changed files with 61 additions and 24 deletions.
2 changes: 1 addition & 1 deletion server/ecosystem.config.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
const watch = process.env.NODE_ENV === 'production' ? false : true;
const ignore_watch = ['logs', 'node_modules', 'tools', 'db/functions', 'db/triggers', 'storage'];
const ignore_watch = ['logs', 'node_modules', 'tools', 'db/functions', 'db/triggers', 'storage', 'package.json', 'package.json.*', 'package-lock.json', 'package-lock.json.*'];
const max_memory_restart = '4000M';
const node_args = ['--max_old_space_size=4096'];
const mode = process.env.DEPLOYMENT_MODE || 'all';
Expand Down
5 changes: 3 additions & 2 deletions server/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@
"install": "0.10.4",
"json2csv": "4.5.4",
"jsonwebtoken": "7.4.3",
"latest-version": "5.1.0",
"lodash": "4.17.5",
"mathjs": "3.20.2",
"moment": "2.21.0",
Expand All @@ -43,7 +44,7 @@
"node-cron": "2.0.3",
"nodemailer": "6.4.6",
"npm": "5.7.1",
"npmi": "4.0.0",
"npm-programmatic": "0.0.12",
"otp": "0.1.3",
"pg": "6.4.2",
"pg-hstore": "2.3.2",
Expand All @@ -56,7 +57,7 @@
"request-promise": "4.2.2",
"sequelize": "4.37.7",
"swagger-express-mw": "0.1.0",
"uglify-es": "^3.3.9",
"uglify-es": "3.3.9",
"uuid": "3.2.1",
"validator": "9.4.1",
"winston": "3.2.1",
Expand Down
78 changes: 57 additions & 21 deletions server/plugins.js
Original file line number Diff line number Diff line change
Expand Up @@ -12,35 +12,67 @@ const morgan = require('morgan');
const { logEntryRequest, stream, loggerPlugin } = require('./config/logger');
const { domainMiddleware, helmetMiddleware } = require('./config/middleware');
const morganType = process.env.NODE_ENV === 'development' ? 'dev' : 'combined';
const npmi = require('npmi');
const multer = require('multer');
const moment = require('moment');
const { checkStatus } = require('./init');
const UglifyJS = require('uglify-es');
const cors = require('cors');
const mathjs = require('mathjs');
const bluebird = require('bluebird');
const rp = require('request-promise');
const uuid = require('uuid/v4');
const fs = require('fs');
const path = require('path');
const latestVersion = require('latest-version');
const { resolve } = bluebird;
const npm = require('npm-programmatic');

const getInstalledLibrary = async (name, version) => {
const jsonFilePath = path.resolve(__dirname, './node_modules', name, 'package.json');

let fileData = fs.readFileSync(jsonFilePath);
fileData = JSON.parse(fileData);

loggerPlugin.verbose(`${name} library found`);
if (version === 'latest') {
const v = await latestVersion(name);
if (fileData.version === v) {
loggerPlugin.verbose(`${name} version ${version} found`);
const lib = require(name);
return resolve(lib);
} else {
throw new Error('Version does not match');
}
} else {
if (fileData.version === version) {
loggerPlugin.verbose(`${name} version ${version} found`);
const lib = require(name);
return resolve(lib);
} else {
throw new Error('Version does not match');
}
}
};

const installLibrary = (library) => {
return new Promise((resolve, reject) => {
npmi({
name: library,
npmLoad: {
save: false,
forceInstall: false,
loglevel: 'silent'
}
}, (err, result) => {
if (err) {
reject(err);
} else {
try {
const lib = require(library);
resolve(lib);
} catch (err) {
reject(err);
}
}
const [name, version = 'latest'] = library.split('@');
return getInstalledLibrary(name, version)
.then((data) => {
return data;
})
.catch((err) => {
loggerPlugin.verbose(`${name} version ${version} installing`);
return npm.install([`${name}@${version}`], {
cwd: path.resolve(__dirname, './'),
save: true,
output: true
});
})
.then(() => {
loggerPlugin.verbose(`${name} version ${version} installed`);
const lib = require(name);
return lib;
});
});
};

app.use(morgan(morganType, { stream }));
Expand Down Expand Up @@ -1008,6 +1040,10 @@ checkStatus()
loggerPlugin,
multer,
moment,
mathjs,
bluebird,
rp,
uuid,
meta: plugin.meta,
installedLibraries: {}
};
Expand Down

0 comments on commit 5e8d348

Please sign in to comment.