You've already forked nginx-proxy-manager
							
							
				mirror of
				https://github.com/NginxProxyManager/nginx-proxy-manager.git
				synced 2025-11-04 04:11:42 +03:00 
			
		
		
		
	* 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;
 |