mirror of
				https://github.com/louislam/uptime-kuma.git
				synced 2025-11-04 13:46:13 +08:00 
			
		
		
		
	Fix: Add password filtering
This commit is contained in:
		
							
								
								
									
										88
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										88
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							@@ -64,7 +64,8 @@
 | 
			
		||||
                "socks-proxy-agent": "6.1.1",
 | 
			
		||||
                "tar": "~6.1.11",
 | 
			
		||||
                "tcp-ping": "~0.1.1",
 | 
			
		||||
                "thirty-two": "~1.0.2"
 | 
			
		||||
                "thirty-two": "~1.0.2",
 | 
			
		||||
                "whatwg-url": "^12.0.1"
 | 
			
		||||
            },
 | 
			
		||||
            "devDependencies": {
 | 
			
		||||
                "@actions/github": "~5.0.1",
 | 
			
		||||
@@ -7522,6 +7523,32 @@
 | 
			
		||||
                "node": ">=10"
 | 
			
		||||
            }
 | 
			
		||||
        },
 | 
			
		||||
        "node_modules/data-urls/node_modules/tr46": {
 | 
			
		||||
            "version": "2.1.0",
 | 
			
		||||
            "resolved": "https://registry.npmjs.org/tr46/-/tr46-2.1.0.tgz",
 | 
			
		||||
            "integrity": "sha512-15Ih7phfcdP5YxqiB+iDtLoaTz4Nd35+IiAv0kQ5FNKHzXgdWqPoTIqEDDJmXceQt4JZk6lVPT8lnDlPpGDppw==",
 | 
			
		||||
            "dev": true,
 | 
			
		||||
            "dependencies": {
 | 
			
		||||
                "punycode": "^2.1.1"
 | 
			
		||||
            },
 | 
			
		||||
            "engines": {
 | 
			
		||||
                "node": ">=8"
 | 
			
		||||
            }
 | 
			
		||||
        },
 | 
			
		||||
        "node_modules/data-urls/node_modules/whatwg-url": {
 | 
			
		||||
            "version": "8.7.0",
 | 
			
		||||
            "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-8.7.0.tgz",
 | 
			
		||||
            "integrity": "sha512-gAojqb/m9Q8a5IV96E3fHJM70AzCkgt4uXYX2O7EmuyOnLrViCQlsEBmF9UQIu3/aeAIp2U17rtbpZWNntQqdg==",
 | 
			
		||||
            "dev": true,
 | 
			
		||||
            "dependencies": {
 | 
			
		||||
                "lodash": "^4.7.0",
 | 
			
		||||
                "tr46": "^2.1.0",
 | 
			
		||||
                "webidl-conversions": "^6.1.0"
 | 
			
		||||
            },
 | 
			
		||||
            "engines": {
 | 
			
		||||
                "node": ">=10"
 | 
			
		||||
            }
 | 
			
		||||
        },
 | 
			
		||||
        "node_modules/date-fns": {
 | 
			
		||||
            "version": "2.30.0",
 | 
			
		||||
            "resolved": "https://registry.npmjs.org/date-fns/-/date-fns-2.30.0.tgz",
 | 
			
		||||
@@ -13040,6 +13067,18 @@
 | 
			
		||||
                "node": ">=6"
 | 
			
		||||
            }
 | 
			
		||||
        },
 | 
			
		||||
        "node_modules/jsdom/node_modules/tr46": {
 | 
			
		||||
            "version": "2.1.0",
 | 
			
		||||
            "resolved": "https://registry.npmjs.org/tr46/-/tr46-2.1.0.tgz",
 | 
			
		||||
            "integrity": "sha512-15Ih7phfcdP5YxqiB+iDtLoaTz4Nd35+IiAv0kQ5FNKHzXgdWqPoTIqEDDJmXceQt4JZk6lVPT8lnDlPpGDppw==",
 | 
			
		||||
            "dev": true,
 | 
			
		||||
            "dependencies": {
 | 
			
		||||
                "punycode": "^2.1.1"
 | 
			
		||||
            },
 | 
			
		||||
            "engines": {
 | 
			
		||||
                "node": ">=8"
 | 
			
		||||
            }
 | 
			
		||||
        },
 | 
			
		||||
        "node_modules/jsdom/node_modules/universalify": {
 | 
			
		||||
            "version": "0.2.0",
 | 
			
		||||
            "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.2.0.tgz",
 | 
			
		||||
@@ -13049,6 +13088,20 @@
 | 
			
		||||
                "node": ">= 4.0.0"
 | 
			
		||||
            }
 | 
			
		||||
        },
 | 
			
		||||
        "node_modules/jsdom/node_modules/whatwg-url": {
 | 
			
		||||
            "version": "8.7.0",
 | 
			
		||||
            "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-8.7.0.tgz",
 | 
			
		||||
            "integrity": "sha512-gAojqb/m9Q8a5IV96E3fHJM70AzCkgt4uXYX2O7EmuyOnLrViCQlsEBmF9UQIu3/aeAIp2U17rtbpZWNntQqdg==",
 | 
			
		||||
            "dev": true,
 | 
			
		||||
            "dependencies": {
 | 
			
		||||
                "lodash": "^4.7.0",
 | 
			
		||||
                "tr46": "^2.1.0",
 | 
			
		||||
                "webidl-conversions": "^6.1.0"
 | 
			
		||||
            },
 | 
			
		||||
            "engines": {
 | 
			
		||||
                "node": ">=10"
 | 
			
		||||
            }
 | 
			
		||||
        },
 | 
			
		||||
        "node_modules/jsesc": {
 | 
			
		||||
            "version": "3.0.2",
 | 
			
		||||
            "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-3.0.2.tgz",
 | 
			
		||||
@@ -17681,15 +17734,14 @@
 | 
			
		||||
            }
 | 
			
		||||
        },
 | 
			
		||||
        "node_modules/tr46": {
 | 
			
		||||
            "version": "2.1.0",
 | 
			
		||||
            "resolved": "https://registry.npmjs.org/tr46/-/tr46-2.1.0.tgz",
 | 
			
		||||
            "integrity": "sha512-15Ih7phfcdP5YxqiB+iDtLoaTz4Nd35+IiAv0kQ5FNKHzXgdWqPoTIqEDDJmXceQt4JZk6lVPT8lnDlPpGDppw==",
 | 
			
		||||
            "dev": true,
 | 
			
		||||
            "version": "4.1.1",
 | 
			
		||||
            "resolved": "https://registry.npmjs.org/tr46/-/tr46-4.1.1.tgz",
 | 
			
		||||
            "integrity": "sha512-2lv/66T7e5yNyhAAC4NaKe5nVavzuGJQVVtRYLyQ2OI8tsJ61PMLlelehb0wi2Hx6+hT/OJUWZcw8MjlSRnxvw==",
 | 
			
		||||
            "dependencies": {
 | 
			
		||||
                "punycode": "^2.1.1"
 | 
			
		||||
                "punycode": "^2.3.0"
 | 
			
		||||
            },
 | 
			
		||||
            "engines": {
 | 
			
		||||
                "node": ">=8"
 | 
			
		||||
                "node": ">=14"
 | 
			
		||||
            }
 | 
			
		||||
        },
 | 
			
		||||
        "node_modules/tree-kill": {
 | 
			
		||||
@@ -18598,17 +18650,23 @@
 | 
			
		||||
            "dev": true
 | 
			
		||||
        },
 | 
			
		||||
        "node_modules/whatwg-url": {
 | 
			
		||||
            "version": "8.7.0",
 | 
			
		||||
            "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-8.7.0.tgz",
 | 
			
		||||
            "integrity": "sha512-gAojqb/m9Q8a5IV96E3fHJM70AzCkgt4uXYX2O7EmuyOnLrViCQlsEBmF9UQIu3/aeAIp2U17rtbpZWNntQqdg==",
 | 
			
		||||
            "dev": true,
 | 
			
		||||
            "version": "12.0.1",
 | 
			
		||||
            "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-12.0.1.tgz",
 | 
			
		||||
            "integrity": "sha512-Ed/LrqB8EPlGxjS+TrsXcpUond1mhccS3pchLhzSgPCnTimUCKj3IZE75pAs5m6heB2U2TMerKFUXheyHY+VDQ==",
 | 
			
		||||
            "dependencies": {
 | 
			
		||||
                "lodash": "^4.7.0",
 | 
			
		||||
                "tr46": "^2.1.0",
 | 
			
		||||
                "webidl-conversions": "^6.1.0"
 | 
			
		||||
                "tr46": "^4.1.1",
 | 
			
		||||
                "webidl-conversions": "^7.0.0"
 | 
			
		||||
            },
 | 
			
		||||
            "engines": {
 | 
			
		||||
                "node": ">=10"
 | 
			
		||||
                "node": ">=14"
 | 
			
		||||
            }
 | 
			
		||||
        },
 | 
			
		||||
        "node_modules/whatwg-url/node_modules/webidl-conversions": {
 | 
			
		||||
            "version": "7.0.0",
 | 
			
		||||
            "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-7.0.0.tgz",
 | 
			
		||||
            "integrity": "sha512-VwddBukDzu71offAQR975unBIGqfKZpM+8ZX6ySk8nYhVoo5CYaZyzt3YBvYtRtO+aoGlqxPg/B87NGVZ/fu6g==",
 | 
			
		||||
            "engines": {
 | 
			
		||||
                "node": ">=12"
 | 
			
		||||
            }
 | 
			
		||||
        },
 | 
			
		||||
        "node_modules/which": {
 | 
			
		||||
 
 | 
			
		||||
@@ -123,7 +123,8 @@
 | 
			
		||||
        "socks-proxy-agent": "6.1.1",
 | 
			
		||||
        "tar": "~6.1.11",
 | 
			
		||||
        "tcp-ping": "~0.1.1",
 | 
			
		||||
        "thirty-two": "~1.0.2"
 | 
			
		||||
        "thirty-two": "~1.0.2",
 | 
			
		||||
        "whatwg-url": "^12.0.1"
 | 
			
		||||
    },
 | 
			
		||||
    "devDependencies": {
 | 
			
		||||
        "@actions/github": "~5.0.1",
 | 
			
		||||
 
 | 
			
		||||
@@ -7,7 +7,7 @@
 | 
			
		||||
                <Tag v-for="tag in monitor.tags" :key="tag.id" :item="tag" :size="'sm'" />
 | 
			
		||||
            </div>
 | 
			
		||||
            <p class="url">
 | 
			
		||||
                <a v-if="monitor.type === 'http' || monitor.type === 'keyword' " :href="monitor.url" target="_blank" rel="noopener noreferrer">{{ monitor.url }}</a>
 | 
			
		||||
                <a v-if="monitor.type === 'http' || monitor.type === 'keyword' " :href="monitor.url" target="_blank" rel="noopener noreferrer">{{ filterPassword(monitor.url) }}</a>
 | 
			
		||||
                <span v-if="monitor.type === 'port'">TCP Port {{ monitor.hostname }}:{{ monitor.port }}</span>
 | 
			
		||||
                <span v-if="monitor.type === 'ping'">Ping: {{ monitor.hostname }}</span>
 | 
			
		||||
                <span v-if="monitor.type === 'keyword'">
 | 
			
		||||
@@ -20,18 +20,18 @@
 | 
			
		||||
                </span>
 | 
			
		||||
                <span v-if="monitor.type === 'docker'">Docker container: {{ monitor.docker_container }}</span>
 | 
			
		||||
                <span v-if="monitor.type === 'gamedig'">Gamedig - {{ monitor.game }}: {{ monitor.hostname }}:{{ monitor.port }}</span>
 | 
			
		||||
                <span v-if="monitor.type === 'grpc-keyword'">gRPC - {{ monitor.grpcUrl }}
 | 
			
		||||
                <span v-if="monitor.type === 'grpc-keyword'">gRPC - {{ filterPassword(monitor.grpcUrl) }}
 | 
			
		||||
                    <br>
 | 
			
		||||
                    <span>{{ $t("Keyword") }}:</span> <span class="keyword">{{ monitor.keyword }}</span>
 | 
			
		||||
                </span>
 | 
			
		||||
                <span v-if="monitor.type === 'mongodb'">{{ monitor.databaseConnectionString }}</span>
 | 
			
		||||
                <span v-if="monitor.type === 'mongodb'">{{ filterPassword(monitor.databaseConnectionString) }}</span>
 | 
			
		||||
                <span v-if="monitor.type === 'mqtt'">MQTT: {{ monitor.hostname }}:{{ monitor.port }}/{{ monitor.mqttTopic }}</span>
 | 
			
		||||
                <span v-if="monitor.type === 'mysql'">{{ monitor.databaseConnectionString }}</span>
 | 
			
		||||
                <span v-if="monitor.type === 'postgres'">{{ monitor.databaseConnectionString }}</span>
 | 
			
		||||
                <span v-if="monitor.type === 'mysql'">{{ filterPassword(monitor.databaseConnectionString) }}</span>
 | 
			
		||||
                <span v-if="monitor.type === 'postgres'">{{ filterPassword(monitor.databaseConnectionString) }}</span>
 | 
			
		||||
                <span v-if="monitor.type === 'push'">Push: <a :href="pushURL" target="_blank" rel="noopener noreferrer">{{ pushURL }}</a></span>
 | 
			
		||||
                <span v-if="monitor.type === 'radius'">Radius: {{ monitor.hostname }}</span>
 | 
			
		||||
                <span v-if="monitor.type === 'redis'">{{ monitor.databaseConnectionString }}</span>
 | 
			
		||||
                <span v-if="monitor.type === 'sqlserver'">SQL Server: {{ monitor.databaseConnectionString }}</span>
 | 
			
		||||
                <span v-if="monitor.type === 'radius'">Radius: {{ filterPassword(monitor.hostname) }}</span>
 | 
			
		||||
                <span v-if="monitor.type === 'redis'">{{ filterPassword(monitor.databaseConnectionString) }}</span>
 | 
			
		||||
                <span v-if="monitor.type === 'sqlserver'">SQL Server: {{ filterPassword(monitor.databaseConnectionString) }}</span>
 | 
			
		||||
                <span v-if="monitor.type === 'steam'">Steam Game Server: {{ monitor.hostname }}:{{ monitor.port }}</span>
 | 
			
		||||
            </p>
 | 
			
		||||
 | 
			
		||||
@@ -208,6 +208,7 @@ import Pagination from "v-pagination-3";
 | 
			
		||||
const PingChart = defineAsyncComponent(() => import("../components/PingChart.vue"));
 | 
			
		||||
import Tag from "../components/Tag.vue";
 | 
			
		||||
import CertificateInfo from "../components/CertificateInfo.vue";
 | 
			
		||||
import { URL } from "whatwg-url";
 | 
			
		||||
 | 
			
		||||
export default {
 | 
			
		||||
    components: {
 | 
			
		||||
@@ -401,6 +402,20 @@ export default {
 | 
			
		||||
 | 
			
		||||
            return this.$t(translationPrefix + "Ping");
 | 
			
		||||
        },
 | 
			
		||||
 | 
			
		||||
        /** Filter and hide password in URL for display */
 | 
			
		||||
        filterPassword(urlString) {
 | 
			
		||||
            try {
 | 
			
		||||
                let parsedUrl = new URL(urlString);
 | 
			
		||||
                if (parsedUrl.password !== "") {
 | 
			
		||||
                    parsedUrl.password = "******";
 | 
			
		||||
                }
 | 
			
		||||
                return parsedUrl.toString();
 | 
			
		||||
            } catch (e) {
 | 
			
		||||
                // Handle SQL Server
 | 
			
		||||
                return urlString.replaceAll(/Password=(.+);/ig, "Password=******;");
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
    },
 | 
			
		||||
};
 | 
			
		||||
</script>
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user