mirror of
				https://github.com/louislam/uptime-kuma.git
				synced 2025-10-26 00:19:21 +08:00 
			
		
		
		
	Handle cookies on redirection (#3589)
* feat: Set and send cookies on redirection (louislam#3587). * feat: Make proxy agents handle cookies * Merge package-lock.json * Merge package-lock.json * Fix lint --------- Co-authored-by: Louis Lam <louislam@users.noreply.github.com>
This commit is contained in:
		
							
								
								
									
										52
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										52
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							| @@ -34,6 +34,7 @@ | |||||||
|                 "form-data": "~4.0.0", |                 "form-data": "~4.0.0", | ||||||
|                 "gamedig": "~4.1.0", |                 "gamedig": "~4.1.0", | ||||||
|                 "html-escaper": "^3.0.3", |                 "html-escaper": "^3.0.3", | ||||||
|  |                 "http-cookie-agent": "~5.0.4", | ||||||
|                 "http-graceful-shutdown": "~3.1.7", |                 "http-graceful-shutdown": "~3.1.7", | ||||||
|                 "http-proxy-agent": "~5.0.0", |                 "http-proxy-agent": "~5.0.0", | ||||||
|                 "https-proxy-agent": "~5.0.1", |                 "https-proxy-agent": "~5.0.1", | ||||||
| @@ -76,6 +77,7 @@ | |||||||
|                 "tar": "~6.1.11", |                 "tar": "~6.1.11", | ||||||
|                 "tcp-ping": "~0.1.1", |                 "tcp-ping": "~0.1.1", | ||||||
|                 "thirty-two": "~1.0.2", |                 "thirty-two": "~1.0.2", | ||||||
|  |                 "tough-cookie": "~4.1.3", | ||||||
|                 "ws": "^8.13.0" |                 "ws": "^8.13.0" | ||||||
|             }, |             }, | ||||||
|             "devDependencies": { |             "devDependencies": { | ||||||
| @@ -9077,6 +9079,44 @@ | |||||||
|             "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.1.1.tgz", |             "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.1.1.tgz", | ||||||
|             "integrity": "sha512-er295DKPVsV82j5kw1Gjt+ADA/XYHsajl82cGNQG2eyoPkvgUhX+nDIyelzhIWbbsXP39EHcI6l5tYs2FYqYXQ==" |             "integrity": "sha512-er295DKPVsV82j5kw1Gjt+ADA/XYHsajl82cGNQG2eyoPkvgUhX+nDIyelzhIWbbsXP39EHcI6l5tYs2FYqYXQ==" | ||||||
|         }, |         }, | ||||||
|  |         "node_modules/http-cookie-agent": { | ||||||
|  |             "version": "5.0.4", | ||||||
|  |             "resolved": "https://registry.npmjs.org/http-cookie-agent/-/http-cookie-agent-5.0.4.tgz", | ||||||
|  |             "integrity": "sha512-OtvikW69RvfyP6Lsequ0fN5R49S+8QcS9zwd58k6VSr6r57T8G29BkPdyrBcSwLq6ExLs9V+rBlfxu7gDstJag==", | ||||||
|  |             "dependencies": { | ||||||
|  |                 "agent-base": "^7.1.0" | ||||||
|  |             }, | ||||||
|  |             "engines": { | ||||||
|  |                 "node": ">=14.18.0 <15.0.0 || >=16.0.0" | ||||||
|  |             }, | ||||||
|  |             "funding": { | ||||||
|  |                 "url": "https://github.com/sponsors/3846masa" | ||||||
|  |             }, | ||||||
|  |             "peerDependencies": { | ||||||
|  |                 "deasync": "^0.1.26", | ||||||
|  |                 "tough-cookie": "^4.0.0", | ||||||
|  |                 "undici": "^5.11.0" | ||||||
|  |             }, | ||||||
|  |             "peerDependenciesMeta": { | ||||||
|  |                 "deasync": { | ||||||
|  |                     "optional": true | ||||||
|  |                 }, | ||||||
|  |                 "undici": { | ||||||
|  |                     "optional": true | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         }, | ||||||
|  |         "node_modules/http-cookie-agent/node_modules/agent-base": { | ||||||
|  |             "version": "7.1.0", | ||||||
|  |             "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-7.1.0.tgz", | ||||||
|  |             "integrity": "sha512-o/zjMZRhJxny7OyEF+Op8X+efiELC7k7yOjMzgfzVqOzXqkBkWI79YoTdOtsuWd5BWhAGAuOY/Xa6xpiaWXiNg==", | ||||||
|  |             "dependencies": { | ||||||
|  |                 "debug": "^4.3.4" | ||||||
|  |             }, | ||||||
|  |             "engines": { | ||||||
|  |                 "node": ">= 14" | ||||||
|  |             } | ||||||
|  |         }, | ||||||
|         "node_modules/http-errors": { |         "node_modules/http-errors": { | ||||||
|             "version": "1.8.1", |             "version": "1.8.1", | ||||||
|             "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.8.1.tgz", |             "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.8.1.tgz", | ||||||
| @@ -13000,8 +13040,7 @@ | |||||||
|         "node_modules/psl": { |         "node_modules/psl": { | ||||||
|             "version": "1.9.0", |             "version": "1.9.0", | ||||||
|             "resolved": "https://registry.npmjs.org/psl/-/psl-1.9.0.tgz", |             "resolved": "https://registry.npmjs.org/psl/-/psl-1.9.0.tgz", | ||||||
|             "integrity": "sha512-E/ZsdU4HLs/68gYzgGTkMicWTLPdAftJLfJFlLUAAKZGkStNU72sZjT66SnMDVOfOWY/YAoiD7Jxa9iHvngcag==", |             "integrity": "sha512-E/ZsdU4HLs/68gYzgGTkMicWTLPdAftJLfJFlLUAAKZGkStNU72sZjT66SnMDVOfOWY/YAoiD7Jxa9iHvngcag==" | ||||||
|             "dev": true |  | ||||||
|         }, |         }, | ||||||
|         "node_modules/pump": { |         "node_modules/pump": { | ||||||
|             "version": "3.0.0", |             "version": "3.0.0", | ||||||
| @@ -13155,8 +13194,7 @@ | |||||||
|         "node_modules/querystringify": { |         "node_modules/querystringify": { | ||||||
|             "version": "2.2.0", |             "version": "2.2.0", | ||||||
|             "resolved": "https://registry.npmjs.org/querystringify/-/querystringify-2.2.0.tgz", |             "resolved": "https://registry.npmjs.org/querystringify/-/querystringify-2.2.0.tgz", | ||||||
|             "integrity": "sha512-FIqgj2EUvTa7R50u0rGsyTftzjYmv/a3hO345bZNrqabNqjtgiDMgmo4mkUjd+nzU5oF3dClKqFIPUKybUyqoQ==", |             "integrity": "sha512-FIqgj2EUvTa7R50u0rGsyTftzjYmv/a3hO345bZNrqabNqjtgiDMgmo4mkUjd+nzU5oF3dClKqFIPUKybUyqoQ==" | ||||||
|             "dev": true |  | ||||||
|         }, |         }, | ||||||
|         "node_modules/queue-microtask": { |         "node_modules/queue-microtask": { | ||||||
|             "version": "1.2.3", |             "version": "1.2.3", | ||||||
| @@ -13640,8 +13678,7 @@ | |||||||
|         "node_modules/requires-port": { |         "node_modules/requires-port": { | ||||||
|             "version": "1.0.0", |             "version": "1.0.0", | ||||||
|             "resolved": "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz", |             "resolved": "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz", | ||||||
|             "integrity": "sha512-KigOCHcocU3XODJxsu8i/j8T9tzT4adHiecwORRQ0ZZFcp7ahwXuRU1m+yuO90C5ZUyGeGfocHDI14M3L3yDAQ==", |             "integrity": "sha512-KigOCHcocU3XODJxsu8i/j8T9tzT4adHiecwORRQ0ZZFcp7ahwXuRU1m+yuO90C5ZUyGeGfocHDI14M3L3yDAQ==" | ||||||
|             "dev": true |  | ||||||
|         }, |         }, | ||||||
|         "node_modules/resolve": { |         "node_modules/resolve": { | ||||||
|             "version": "1.22.8", |             "version": "1.22.8", | ||||||
| @@ -15320,7 +15357,6 @@ | |||||||
|             "version": "4.1.3", |             "version": "4.1.3", | ||||||
|             "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-4.1.3.tgz", |             "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-4.1.3.tgz", | ||||||
|             "integrity": "sha512-aX/y5pVRkfRnfmuX+OdbSdXvPe6ieKX/G2s7e98f4poJHnqH3281gDPm/metm6E/WRamfx7WC4HUqkWHfQHprw==", |             "integrity": "sha512-aX/y5pVRkfRnfmuX+OdbSdXvPe6ieKX/G2s7e98f4poJHnqH3281gDPm/metm6E/WRamfx7WC4HUqkWHfQHprw==", | ||||||
|             "dev": true, |  | ||||||
|             "dependencies": { |             "dependencies": { | ||||||
|                 "psl": "^1.1.33", |                 "psl": "^1.1.33", | ||||||
|                 "punycode": "^2.1.1", |                 "punycode": "^2.1.1", | ||||||
| @@ -15335,7 +15371,6 @@ | |||||||
|             "version": "0.2.0", |             "version": "0.2.0", | ||||||
|             "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.2.0.tgz", |             "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.2.0.tgz", | ||||||
|             "integrity": "sha512-CJ1QgKmNg3CwvAv/kOFmtnEN05f0D/cn9QntgNOQlQF9dgvVTHj3t+8JPdjqawCHk7V/KA+fbUqzZ9XWhcqPUg==", |             "integrity": "sha512-CJ1QgKmNg3CwvAv/kOFmtnEN05f0D/cn9QntgNOQlQF9dgvVTHj3t+8JPdjqawCHk7V/KA+fbUqzZ9XWhcqPUg==", | ||||||
|             "dev": true, |  | ||||||
|             "engines": { |             "engines": { | ||||||
|                 "node": ">= 4.0.0" |                 "node": ">= 4.0.0" | ||||||
|             } |             } | ||||||
| @@ -15670,7 +15705,6 @@ | |||||||
|             "version": "1.5.10", |             "version": "1.5.10", | ||||||
|             "resolved": "https://registry.npmjs.org/url-parse/-/url-parse-1.5.10.tgz", |             "resolved": "https://registry.npmjs.org/url-parse/-/url-parse-1.5.10.tgz", | ||||||
|             "integrity": "sha512-WypcfiRhfeUP9vvF0j6rw0J3hrWrw6iZv3+22h6iRMJ/8z1Tj6XfLP4DsUix5MhMPnXpiHDoKyoZ/bdCkwBCiQ==", |             "integrity": "sha512-WypcfiRhfeUP9vvF0j6rw0J3hrWrw6iZv3+22h6iRMJ/8z1Tj6XfLP4DsUix5MhMPnXpiHDoKyoZ/bdCkwBCiQ==", | ||||||
|             "dev": true, |  | ||||||
|             "dependencies": { |             "dependencies": { | ||||||
|                 "querystringify": "^2.1.1", |                 "querystringify": "^2.1.1", | ||||||
|                 "requires-port": "^1.0.0" |                 "requires-port": "^1.0.0" | ||||||
|   | |||||||
| @@ -97,6 +97,7 @@ | |||||||
|         "express-static-gzip": "~2.1.7", |         "express-static-gzip": "~2.1.7", | ||||||
|         "form-data": "~4.0.0", |         "form-data": "~4.0.0", | ||||||
|         "gamedig": "~4.1.0", |         "gamedig": "~4.1.0", | ||||||
|  |         "http-cookie-agent": "~5.0.4", | ||||||
|         "html-escaper": "^3.0.3", |         "html-escaper": "^3.0.3", | ||||||
|         "http-graceful-shutdown": "~3.1.7", |         "http-graceful-shutdown": "~3.1.7", | ||||||
|         "http-proxy-agent": "~5.0.0", |         "http-proxy-agent": "~5.0.0", | ||||||
| @@ -140,6 +141,7 @@ | |||||||
|         "tar": "~6.1.11", |         "tar": "~6.1.11", | ||||||
|         "tcp-ping": "~0.1.1", |         "tcp-ping": "~0.1.1", | ||||||
|         "thirty-two": "~1.0.2", |         "thirty-two": "~1.0.2", | ||||||
|  |         "tough-cookie": "~4.1.3", | ||||||
|         "ws": "^8.13.0" |         "ws": "^8.13.0" | ||||||
|     }, |     }, | ||||||
|     "devDependencies": { |     "devDependencies": { | ||||||
|   | |||||||
| @@ -1,4 +1,3 @@ | |||||||
| const https = require("https"); |  | ||||||
| const dayjs = require("dayjs"); | const dayjs = require("dayjs"); | ||||||
| const axios = require("axios"); | const axios = require("axios"); | ||||||
| const { Prometheus } = require("../prometheus"); | const { Prometheus } = require("../prometheus"); | ||||||
| @@ -23,6 +22,8 @@ const jsonata = require("jsonata"); | |||||||
| const jwt = require("jsonwebtoken"); | const jwt = require("jsonwebtoken"); | ||||||
| const crypto = require("crypto"); | const crypto = require("crypto"); | ||||||
| const { UptimeCalculator } = require("../uptime-calculator"); | const { UptimeCalculator } = require("../uptime-calculator"); | ||||||
|  | const { CookieJar } = require("tough-cookie"); | ||||||
|  | const { HttpsCookieAgent } = require("http-cookie-agent/http"); | ||||||
|  |  | ||||||
| const rootCertificates = rootCertificatesFingerprints(); | const rootCertificates = rootCertificatesFingerprints(); | ||||||
|  |  | ||||||
| @@ -507,7 +508,12 @@ class Monitor extends BeanModel { | |||||||
|                     } |                     } | ||||||
|  |  | ||||||
|                     if (!options.httpsAgent) { |                     if (!options.httpsAgent) { | ||||||
|                         options.httpsAgent = new https.Agent(httpsAgentOptions); |                         let jar = new CookieJar(); | ||||||
|  |                         let httpsCookieAgentOptions = { | ||||||
|  |                             ...httpsAgentOptions, | ||||||
|  |                             cookies: { jar } | ||||||
|  |                         }; | ||||||
|  |                         options.httpsAgent = new HttpsCookieAgent(httpsCookieAgentOptions); | ||||||
|                     } |                     } | ||||||
|  |  | ||||||
|                     if (this.auth_method === "mtls") { |                     if (this.auth_method === "mtls") { | ||||||
|   | |||||||
| @@ -4,6 +4,8 @@ const HttpsProxyAgent = require("https-proxy-agent"); | |||||||
| const SocksProxyAgent = require("socks-proxy-agent"); | const SocksProxyAgent = require("socks-proxy-agent"); | ||||||
| const { debug } = require("../src/util"); | const { debug } = require("../src/util"); | ||||||
| const { UptimeKumaServer } = require("./uptime-kuma-server"); | const { UptimeKumaServer } = require("./uptime-kuma-server"); | ||||||
|  | const { CookieJar } = require("tough-cookie"); | ||||||
|  | const { createCookieAgent } = require("http-cookie-agent/http"); | ||||||
|  |  | ||||||
| class Proxy { | class Proxy { | ||||||
|  |  | ||||||
| @@ -95,10 +97,13 @@ class Proxy { | |||||||
|         let httpAgent; |         let httpAgent; | ||||||
|         let httpsAgent; |         let httpsAgent; | ||||||
|  |  | ||||||
|  |         let jar = new CookieJar(); | ||||||
|  |  | ||||||
|         const proxyOptions = { |         const proxyOptions = { | ||||||
|             protocol: proxy.protocol, |             protocol: proxy.protocol, | ||||||
|             host: proxy.host, |             host: proxy.host, | ||||||
|             port: proxy.port, |             port: proxy.port, | ||||||
|  |             cookies: { jar }, | ||||||
|         }; |         }; | ||||||
|  |  | ||||||
|         if (proxy.auth) { |         if (proxy.auth) { | ||||||
| @@ -112,12 +117,17 @@ class Proxy { | |||||||
|         switch (proxy.protocol) { |         switch (proxy.protocol) { | ||||||
|             case "http": |             case "http": | ||||||
|             case "https": |             case "https": | ||||||
|                 httpAgent = new HttpProxyAgent({ |                 // eslint-disable-next-line no-case-declarations | ||||||
|  |                 const HttpCookieProxyAgent = createCookieAgent(HttpProxyAgent); | ||||||
|  |                 // eslint-disable-next-line no-case-declarations | ||||||
|  |                 const HttpsCookieProxyAgent = createCookieAgent(HttpsProxyAgent); | ||||||
|  |  | ||||||
|  |                 httpAgent = new HttpCookieProxyAgent({ | ||||||
|                     ...httpAgentOptions || {}, |                     ...httpAgentOptions || {}, | ||||||
|                     ...proxyOptions |                     ...proxyOptions, | ||||||
|                 }); |                 }); | ||||||
|  |  | ||||||
|                 httpsAgent = new HttpsProxyAgent({ |                 httpsAgent = new HttpsCookieProxyAgent({ | ||||||
|                     ...httpsAgentOptions || {}, |                     ...httpsAgentOptions || {}, | ||||||
|                     ...proxyOptions, |                     ...proxyOptions, | ||||||
|                 }); |                 }); | ||||||
| @@ -126,7 +136,9 @@ class Proxy { | |||||||
|             case "socks5": |             case "socks5": | ||||||
|             case "socks5h": |             case "socks5h": | ||||||
|             case "socks4": |             case "socks4": | ||||||
|                 agent = new SocksProxyAgent({ |                 // eslint-disable-next-line no-case-declarations | ||||||
|  |                 const SocksCookieProxyAgent = createCookieAgent(SocksProxyAgent); | ||||||
|  |                 agent = new SocksCookieProxyAgent({ | ||||||
|                     ...httpAgentOptions, |                     ...httpAgentOptions, | ||||||
|                     ...httpsAgentOptions, |                     ...httpsAgentOptions, | ||||||
|                     ...proxyOptions, |                     ...proxyOptions, | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user