bb0f4bfa62
* Fix wrapping when too many hosts are shown (#207) * Update npm packages, fixes CVE-2019-10757 * Revert some breaking packages * Major overhaul - Docker buildx support in CI - Cypress API Testing in CI - Restructured folder layout (insert clean face meme) - Added Swagger documentation and validate API against that (to be completed) - Use common base image for all supported archs, which includes updated nginx with ipv6 support - Updated certbot and changes required for it - Large amount of Hosts names will wrap in UI - Updated packages for frontend - Version bump 2.1.0 * Updated documentation * Fix JWT expire time going crazy. Now set to 1day * Backend JS formatting rules * Remove v1 importer, I doubt anyone is using v1 anymore * Added backend formatting rules and enforce them in Jenkins builds * Fix CI, doesn't need a tty * Thanks bcrypt. Why can't you just be normal. * Cleanup after syntax check Co-authored-by: Marcelo Castagna <margaale@users.noreply.github.com>
134 lines
2.9 KiB
JavaScript
134 lines
2.9 KiB
JavaScript
const fs = require('fs');
|
|
const error = require('../lib/error');
|
|
const settingModel = require('../models/setting');
|
|
const internalNginx = require('./nginx');
|
|
|
|
const internalSetting = {
|
|
|
|
/**
|
|
* @param {Access} access
|
|
* @param {Object} data
|
|
* @param {String} data.id
|
|
* @return {Promise}
|
|
*/
|
|
update: (access, data) => {
|
|
return access.can('settings:update', data.id)
|
|
.then((/*access_data*/) => {
|
|
return internalSetting.get(access, {id: data.id});
|
|
})
|
|
.then((row) => {
|
|
if (row.id !== data.id) {
|
|
// Sanity check that something crazy hasn't happened
|
|
throw new error.InternalValidationError('Setting could not be updated, IDs do not match: ' + row.id + ' !== ' + data.id);
|
|
}
|
|
|
|
return settingModel
|
|
.query()
|
|
.where({id: data.id})
|
|
.patch(data);
|
|
})
|
|
.then(() => {
|
|
return internalSetting.get(access, {
|
|
id: data.id
|
|
});
|
|
})
|
|
.then((row) => {
|
|
if (row.id === 'default-site') {
|
|
// write the html if we need to
|
|
if (row.value === 'html') {
|
|
fs.writeFileSync('/data/nginx/default_www/index.html', row.meta.html, {encoding: 'utf8'});
|
|
}
|
|
|
|
// Configure nginx
|
|
return internalNginx.deleteConfig('default')
|
|
.then(() => {
|
|
return internalNginx.generateConfig('default', row);
|
|
})
|
|
.then(() => {
|
|
return internalNginx.test();
|
|
})
|
|
.then(() => {
|
|
return internalNginx.reload();
|
|
})
|
|
.then(() => {
|
|
return row;
|
|
})
|
|
.catch((/*err*/) => {
|
|
internalNginx.deleteConfig('default')
|
|
.then(() => {
|
|
return internalNginx.test();
|
|
})
|
|
.then(() => {
|
|
return internalNginx.reload();
|
|
})
|
|
.then(() => {
|
|
// I'm being slack here I know..
|
|
throw new error.ValidationError('Could not reconfigure Nginx. Please check logs.');
|
|
});
|
|
});
|
|
} else {
|
|
return row;
|
|
}
|
|
});
|
|
},
|
|
|
|
/**
|
|
* @param {Access} access
|
|
* @param {Object} data
|
|
* @param {String} data.id
|
|
* @return {Promise}
|
|
*/
|
|
get: (access, data) => {
|
|
return access.can('settings:get', data.id)
|
|
.then(() => {
|
|
return settingModel
|
|
.query()
|
|
.where('id', data.id)
|
|
.first();
|
|
})
|
|
.then((row) => {
|
|
if (row) {
|
|
return row;
|
|
} else {
|
|
throw new error.ItemNotFoundError(data.id);
|
|
}
|
|
});
|
|
},
|
|
|
|
/**
|
|
* This will only count the settings
|
|
*
|
|
* @param {Access} access
|
|
* @returns {*}
|
|
*/
|
|
getCount: (access) => {
|
|
return access.can('settings:list')
|
|
.then(() => {
|
|
return settingModel
|
|
.query()
|
|
.count('id as count')
|
|
.first();
|
|
})
|
|
.then((row) => {
|
|
return parseInt(row.count, 10);
|
|
});
|
|
},
|
|
|
|
/**
|
|
* All settings
|
|
*
|
|
* @param {Access} access
|
|
* @returns {Promise}
|
|
*/
|
|
getAll: (access) => {
|
|
return access.can('settings:list')
|
|
.then(() => {
|
|
return settingModel
|
|
.query()
|
|
.orderBy('description', 'ASC');
|
|
});
|
|
}
|
|
};
|
|
|
|
module.exports = internalSetting;
|