This commit is contained in:
		
							parent
							
								
									1b6c587cc9
								
							
						
					
					
						commit
						e12225e595
					
				
					 1 changed files with 36 additions and 17 deletions
				
			
		|  | @ -275,9 +275,6 @@ class Monitor extends BeanModel { | ||||||
|                         ...(this.body ? { data: JSON.parse(this.body) } : {}), |                         ...(this.body ? { data: JSON.parse(this.body) } : {}), | ||||||
|                         timeout: this.interval * 1000 * 0.8, |                         timeout: this.interval * 1000 * 0.8, | ||||||
|                         headers: { |                         headers: { | ||||||
|                             // Fix #2253
 |  | ||||||
|                             // Read more: https://stackoverflow.com/questions/1759956/curl-error-18-transfer-closed-with-outstanding-read-data-remaining
 |  | ||||||
|                             "Accept-Encoding": "gzip, deflate", |  | ||||||
|                             "Accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9", |                             "Accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9", | ||||||
|                             "User-Agent": "Uptime-Kuma/" + version, |                             "User-Agent": "Uptime-Kuma/" + version, | ||||||
|                             ...(this.headers ? JSON.parse(this.headers) : {}), |                             ...(this.headers ? JSON.parse(this.headers) : {}), | ||||||
|  | @ -310,20 +307,8 @@ class Monitor extends BeanModel { | ||||||
|                     log.debug("monitor", `[${this.name}] Axios Options: ${JSON.stringify(options)}`); |                     log.debug("monitor", `[${this.name}] Axios Options: ${JSON.stringify(options)}`); | ||||||
|                     log.debug("monitor", `[${this.name}] Axios Request`); |                     log.debug("monitor", `[${this.name}] Axios Request`); | ||||||
| 
 | 
 | ||||||
|                     let res; |                     // Make Request
 | ||||||
|                     if (this.auth_method === "ntlm") { |                     let res = await this.makeAxiosRequest(options); | ||||||
|                         options.httpsAgent.keepAlive = true; |  | ||||||
| 
 |  | ||||||
|                         res = await httpNtlm(options, { |  | ||||||
|                             username: this.basic_auth_user, |  | ||||||
|                             password: this.basic_auth_pass, |  | ||||||
|                             domain: this.authDomain, |  | ||||||
|                             workstation: this.authWorkstation ? this.authWorkstation : undefined |  | ||||||
|                         }); |  | ||||||
| 
 |  | ||||||
|                     } else { |  | ||||||
|                         res = await axios.request(options); |  | ||||||
|                     } |  | ||||||
| 
 | 
 | ||||||
|                     bean.msg = `${res.status} - ${res.statusText}`; |                     bean.msg = `${res.status} - ${res.statusText}`; | ||||||
|                     bean.ping = dayjs().valueOf() - startTime; |                     bean.ping = dayjs().valueOf() - startTime; | ||||||
|  | @ -761,6 +746,40 @@ class Monitor extends BeanModel { | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     async makeAxiosRequest(options, finalCall = false) { | ||||||
|  |         try { | ||||||
|  |             let res; | ||||||
|  |             if (this.auth_method === "ntlm") { | ||||||
|  |                 options.httpsAgent.keepAlive = true; | ||||||
|  | 
 | ||||||
|  |                 res = await httpNtlm(options, { | ||||||
|  |                     username: this.basic_auth_user, | ||||||
|  |                     password: this.basic_auth_pass, | ||||||
|  |                     domain: this.authDomain, | ||||||
|  |                     workstation: this.authWorkstation ? this.authWorkstation : undefined | ||||||
|  |                 }); | ||||||
|  | 
 | ||||||
|  |             } else { | ||||||
|  |                 res = await axios.request(options); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             return res; | ||||||
|  |         } catch (e) { | ||||||
|  |             // Fix #2253
 | ||||||
|  |             // Read more: https://stackoverflow.com/questions/1759956/curl-error-18-transfer-closed-with-outstanding-read-data-remaining
 | ||||||
|  |             if (!finalCall && typeof e.message === "string" && e.message.includes("maxContentLength size of -1 exceeded")) { | ||||||
|  |                 log.debug("monitor", "makeAxiosRequest with gzip"); | ||||||
|  |                 options.headers["Accept-Encoding"] = "gzip, deflate"; | ||||||
|  |                 return this.makeAxiosRequest(options, true); | ||||||
|  |             } else { | ||||||
|  |                 if (typeof e.message === "string" && e.message.includes("maxContentLength size of -1 exceeded")) { | ||||||
|  |                     e.message = "response timeout: incomplete response within a interval"; | ||||||
|  |                 } | ||||||
|  |                 throw e; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     /** Stop monitor */ |     /** Stop monitor */ | ||||||
|     stop() { |     stop() { | ||||||
|         clearTimeout(this.heartbeatInterval); |         clearTimeout(this.heartbeatInterval); | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue