mirror of
				https://github.com/NginxProxyManager/nginx-proxy-manager.git
				synced 2025-10-31 15:53: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; | ||||
		Reference in New Issue
	
	Block a user