You've already forked nginx-proxy-manager
							
							
				mirror of
				https://github.com/NginxProxyManager/nginx-proxy-manager.git
				synced 2025-10-30 18:05:34 +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;
 |