mirror of
				https://github.com/NginxProxyManager/nginx-proxy-manager.git
				synced 2025-10-31 07:43:33 +00:00 
			
		
		
		
	v2.1.0 (#293)
* 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>
This commit is contained in:
		
							
								
								
									
										142
									
								
								test/cypress/plugins/backendApi/client.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										142
									
								
								test/cypress/plugins/backendApi/client.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,142 @@ | ||||
| const logger  = require('./logger'); | ||||
| const restler = require('@jc21/restler'); | ||||
|  | ||||
| const BackendApi = function(config, token) { | ||||
| 	this.config = config; | ||||
| 	this.token  = token; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * @param {string} token | ||||
|  */ | ||||
| BackendApi.prototype.setToken = function(token) { | ||||
| 	this.token = token; | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * @param {string} path | ||||
|  * @param {bool}   [returnOnError] | ||||
|  * @returns {Promise<object>} | ||||
|  */ | ||||
| BackendApi.prototype.get = function(path, returnOnError) { | ||||
| 	return new Promise((resolve, reject) => { | ||||
| 		let headers = { | ||||
| 			Accept: 'application/json' | ||||
| 		}; | ||||
| 		if (this.token) { | ||||
| 			headers.Authorization = 'Bearer ' + this.token; | ||||
| 		} | ||||
|  | ||||
| 		logger('GET ', this.config.baseUrl + path); | ||||
|  | ||||
| 		restler | ||||
| 			.get(this.config.baseUrl + path, { | ||||
| 				headers: headers, | ||||
| 			}) | ||||
| 			.on('complete', function(data, response) { | ||||
| 				logger('Response data:', data); | ||||
| 				if (!returnOnError && data instanceof Error) { | ||||
| 					reject(data); | ||||
| 				} else if (!returnOnError && response.statusCode != 200) { | ||||
| 					if (typeof data === 'object' && typeof data.error === 'object' && typeof data.error.message !== 'undefined') { | ||||
| 						reject(new Error(data.error.code + ': ' + data.error.message)); | ||||
| 					} else { | ||||
| 						reject(new Error('Error ' + response.statusCode)); | ||||
| 					} | ||||
| 				} else { | ||||
| 					resolve(data); | ||||
| 				} | ||||
| 			}); | ||||
| 	}); | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * @param {string} path | ||||
|  * @param {bool}   [returnOnError] | ||||
|  * @returns {Promise<object>} | ||||
|  */ | ||||
| BackendApi.prototype.delete = function(path, returnOnError) { | ||||
| 	return new Promise((resolve, reject) => { | ||||
| 		let headers = { | ||||
| 			Accept: 'application/json' | ||||
| 		}; | ||||
| 		if (this.token) { | ||||
| 			headers.Authorization = 'Bearer ' + this.token; | ||||
| 		} | ||||
|  | ||||
| 		logger('DELETE ', this.config.baseUrl + path); | ||||
|  | ||||
| 		restler | ||||
| 			.del(this.config.baseUrl + path, { | ||||
| 				headers: headers, | ||||
| 			}) | ||||
| 			.on('complete', function(data, response) { | ||||
| 				logger('Response data:', data); | ||||
| 				if (!returnOnError && data instanceof Error) { | ||||
| 					reject(data); | ||||
| 				} else if (!returnOnError && response.statusCode != 200) { | ||||
| 					if (typeof data === 'object' && typeof data.error === 'object' && typeof data.error.message !== 'undefined') { | ||||
| 						reject(new Error(data.error.code + ': ' + data.error.message)); | ||||
| 					} else { | ||||
| 						reject(new Error('Error ' + response.statusCode)); | ||||
| 					} | ||||
| 				} else { | ||||
| 					resolve(data); | ||||
| 				} | ||||
| 			}); | ||||
| 	}); | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * @param {string} path | ||||
|  * @param {object} data | ||||
|  * @param {bool}   [returnOnError] | ||||
|  * @returns {Promise<object>} | ||||
|  */ | ||||
| BackendApi.prototype.postJson = function(path, data, returnOnError) { | ||||
| 	logger('POST ', this.config.baseUrl + path); | ||||
| 	return this._putPostJson('postJson', path, data, returnOnError); | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * @param {string} path | ||||
|  * @param {object} data | ||||
|  * @param {bool}   [returnOnError] | ||||
|  * @returns {Promise<object>} | ||||
|  */ | ||||
| BackendApi.prototype.putJson = function(path, data, returnOnError) { | ||||
| 	logger('PUT ', this.config.baseUrl + path); | ||||
| 	return this._putPostJson('putJson', path, data, returnOnError); | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * @param {string} path | ||||
|  * @param {object} data | ||||
|  * @param {bool}   [returnOnError] | ||||
|  * @returns {Promise<object>} | ||||
|  */ | ||||
| BackendApi.prototype._putPostJson = function(fn, path, data, returnOnError) { | ||||
| 	return new Promise((resolve, reject) => { | ||||
| 		restler[fn](this.config.baseUrl + path, data, { | ||||
| 			headers: { | ||||
| 				Accept:        'application/json', | ||||
| 				Authorization: 'Bearer ' + this.token, | ||||
| 			}, | ||||
| 		}).on('complete', function(data, response) { | ||||
| 			logger('Response data:', data); | ||||
| 			if (!returnOnError && data instanceof Error) { | ||||
| 				reject(data); | ||||
| 			} else if (!returnOnError && response.statusCode != 200) { | ||||
| 				if (typeof data === 'object' && typeof data.error === 'object' && typeof data.error.message !== 'undefined') { | ||||
| 					reject(new Error(data.error.code + ': ' + data.error.message)); | ||||
| 				} else { | ||||
| 					reject(new Error('Error ' + response.statusCode)); | ||||
| 				} | ||||
| 			} else { | ||||
| 				resolve(data); | ||||
| 			} | ||||
| 		}); | ||||
| 	}); | ||||
| }; | ||||
|  | ||||
| module.exports = BackendApi; | ||||
							
								
								
									
										8
									
								
								test/cypress/plugins/backendApi/logger.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								test/cypress/plugins/backendApi/logger.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | ||||
| const _     = require('lodash'); | ||||
| const chalk = require('chalk'); | ||||
|  | ||||
| module.exports = function () { | ||||
| 	var arr = _.values(arguments); | ||||
| 	arr.unshift(chalk.blue.bold('[') + chalk.yellow.bold('Backend API') + chalk.blue.bold(']')); | ||||
| 	console.log.apply(null, arr); | ||||
| }; | ||||
							
								
								
									
										64
									
								
								test/cypress/plugins/backendApi/task.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										64
									
								
								test/cypress/plugins/backendApi/task.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,64 @@ | ||||
| const logger = require('./logger'); | ||||
| const Client = require('./client'); | ||||
|  | ||||
| module.exports = function (config) { | ||||
|  | ||||
| 	logger('Client Ready using', config.baseUrl); | ||||
|  | ||||
| 	return { | ||||
|  | ||||
| 		/** | ||||
| 		 * @param   {object}    options | ||||
| 		 * @param   {string}    options.path         API path | ||||
| 		 * @param   {string}    [options.token]      JWT | ||||
| 		 * @param   {bool}      [options.returnOnError] If true, will return instead of throwing errors | ||||
| 		 * @returns {string} | ||||
| 		 */ | ||||
| 		backendApiGet: (options) => { | ||||
| 			const api = new Client(config); | ||||
| 			api.setToken(options.token); | ||||
| 			return api.get(options.path, options.returnOnError || false); | ||||
| 		}, | ||||
|  | ||||
| 		/** | ||||
| 		 * @param   {object}    options | ||||
| 		 * @param   {string}    options.token        JWT | ||||
| 		 * @param   {string}    options.path         API path | ||||
| 		 * @param   {object}    options.data | ||||
| 		 * @param   {bool}      [options.returnOnError] If true, will return instead of throwing errors | ||||
| 		 * @returns {string} | ||||
| 		 */ | ||||
| 		backendApiPost: (options) => { | ||||
| 			const api = new Client(config); | ||||
| 			api.setToken(options.token); | ||||
| 			return api.postJson(options.path, options.data, options.returnOnError || false); | ||||
| 		}, | ||||
|  | ||||
| 		/** | ||||
| 		 * @param   {object}    options | ||||
| 		 * @param   {string}    options.token        JWT | ||||
| 		 * @param   {string}    options.path         API path | ||||
| 		 * @param   {object}    options.data | ||||
| 		 * @param   {bool}      [options.returnOnError] If true, will return instead of throwing errors | ||||
| 		 * @returns {string} | ||||
| 		 */ | ||||
| 		backendApiPut: (options) => { | ||||
| 			const api = new Client(config); | ||||
| 			api.setToken(options.token); | ||||
| 			return api.putJson(options.path, options.data, options.returnOnError || false); | ||||
| 		}, | ||||
|  | ||||
| 		/** | ||||
| 		 * @param   {object}    options | ||||
| 		 * @param   {string}    options.token        JWT | ||||
| 		 * @param   {string}    options.path         API path | ||||
| 		 * @param   {bool}      [options.returnOnError] If true, will return instead of throwing errors | ||||
| 		 * @returns {string} | ||||
| 		 */ | ||||
| 		backendApiDelete: (options) => { | ||||
| 			const api = new Client(config); | ||||
| 			api.setToken(options.token); | ||||
| 			return api.delete(options.path, options.returnOnError || false); | ||||
| 		} | ||||
| 	}; | ||||
| }; | ||||
		Reference in New Issue
	
	Block a user