mirror of
				https://github.com/louislam/uptime-kuma.git
				synced 2025-10-25 07:10:47 +08:00 
			
		
		
		
	Merge manually
This commit is contained in:
		
							
								
								
									
										29
									
								
								.github/workflows/auto-test.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										29
									
								
								.github/workflows/auto-test.yml
									
									
									
									
										vendored
									
									
								
							| @@ -78,20 +78,21 @@ jobs: | ||||
|     - run: npm install | ||||
|     - run: npm run lint:prod | ||||
|  | ||||
|   e2e-tests: | ||||
|     needs: [ check-linters ] | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|     - run: git config --global core.autocrlf false  # Mainly for Windows | ||||
|     - uses: actions/checkout@v4 | ||||
|  | ||||
|     - name: Use Node.js 14 | ||||
|       uses: actions/setup-node@v4 | ||||
|       with: | ||||
|         node-version: 14 | ||||
|     - run: npm install | ||||
|     - run: npm run build | ||||
|     - run: npm run cy:test | ||||
| # TODO: Temporarily disable, as it cannot pass the test in 2.0.0 yet | ||||
| #  e2e-tests: | ||||
| #    needs: [ check-linters ] | ||||
| #    runs-on: ubuntu-latest | ||||
| #    steps: | ||||
| #    - run: git config --global core.autocrlf false  # Mainly for Windows | ||||
| #    - uses: actions/checkout@v4 | ||||
| # | ||||
| #    - name: Use Node.js 14 | ||||
| #      uses: actions/setup-node@v4 | ||||
| #      with: | ||||
| #        node-version: 14 | ||||
| #    - run: npm install | ||||
| #    - run: npm run build | ||||
| #    - run: npm run cy:test | ||||
|  | ||||
|   frontend-unit-tests: | ||||
|     needs: [ check-linters ] | ||||
|   | ||||
| @@ -87,6 +87,12 @@ function question(question) { | ||||
|     }); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Disconnect all socket clients of the user | ||||
|  * @param {string} username Username | ||||
|  * @param {string} password Password | ||||
|  * @returns {Promise<void>} Promise | ||||
|  */ | ||||
| function disconnectAllSocketClients(username, password) { | ||||
|     return new Promise((resolve) => { | ||||
|         console.log("Connecting to " + localWebSocketURL + " to disconnect all other socket clients"); | ||||
|   | ||||
							
								
								
									
										31
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										31
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							| @@ -127,7 +127,6 @@ | ||||
|                 "typescript": "~4.4.4", | ||||
|                 "v-pagination-3": "~0.1.7", | ||||
|                 "vite": "~4.4.1", | ||||
|                 "vite-plugin-commonjs": "^0.8.0", | ||||
|                 "vite-plugin-compression": "^0.5.1", | ||||
|                 "vue": "~3.3.4", | ||||
|                 "vue-chartjs": "~5.2.0", | ||||
| @@ -7486,12 +7485,6 @@ | ||||
|                 "url": "https://github.com/sponsors/ljharb" | ||||
|             } | ||||
|         }, | ||||
|         "node_modules/es-module-lexer": { | ||||
|             "version": "1.4.1", | ||||
|             "resolved": "https://registry.npmjs.org/es-module-lexer/-/es-module-lexer-1.4.1.tgz", | ||||
|             "integrity": "sha512-cXLGjP0c4T3flZJKQSuziYoq7MlT+rnvfZjfp7h+I7K9BNX54kP9nyWvdbwjQ4u1iWbOL4u96fgeZLToQlZC7w==", | ||||
|             "dev": true | ||||
|         }, | ||||
|         "node_modules/es-set-tostringtag": { | ||||
|             "version": "2.0.2", | ||||
|             "resolved": "https://registry.npmjs.org/es-set-tostringtag/-/es-set-tostringtag-2.0.2.tgz", | ||||
| @@ -15860,18 +15853,6 @@ | ||||
|                 } | ||||
|             } | ||||
|         }, | ||||
|         "node_modules/vite-plugin-commonjs": { | ||||
|             "version": "0.8.2", | ||||
|             "resolved": "https://registry.npmjs.org/vite-plugin-commonjs/-/vite-plugin-commonjs-0.8.2.tgz", | ||||
|             "integrity": "sha512-UJlvuioutS7Tno3p3Dqxkr0G4xXt8ILYsJzOiyvFlEsyAxFRofsBGHN/Sl15q0Y4vtvvC7+QZCc6GuUxOM6Cmg==", | ||||
|             "dev": true, | ||||
|             "dependencies": { | ||||
|                 "acorn": "^8.8.2", | ||||
|                 "fast-glob": "^3.2.12", | ||||
|                 "magic-string": "^0.30.1", | ||||
|                 "vite-plugin-dynamic-import": "^1.5.0" | ||||
|             } | ||||
|         }, | ||||
|         "node_modules/vite-plugin-compression": { | ||||
|             "version": "0.5.1", | ||||
|             "resolved": "https://registry.npmjs.org/vite-plugin-compression/-/vite-plugin-compression-0.5.1.tgz", | ||||
| @@ -15900,18 +15881,6 @@ | ||||
|                 "node": ">=12" | ||||
|             } | ||||
|         }, | ||||
|         "node_modules/vite-plugin-dynamic-import": { | ||||
|             "version": "1.5.0", | ||||
|             "resolved": "https://registry.npmjs.org/vite-plugin-dynamic-import/-/vite-plugin-dynamic-import-1.5.0.tgz", | ||||
|             "integrity": "sha512-Qp85c+AVJmLa8MLni74U4BDiWpUeFNx7NJqbGZyR2XJOU7mgW0cb7nwlAMucFyM4arEd92Nfxp4j44xPi6Fu7g==", | ||||
|             "dev": true, | ||||
|             "dependencies": { | ||||
|                 "acorn": "^8.8.2", | ||||
|                 "es-module-lexer": "^1.2.1", | ||||
|                 "fast-glob": "^3.2.12", | ||||
|                 "magic-string": "^0.30.1" | ||||
|             } | ||||
|         }, | ||||
|         "node_modules/vue": { | ||||
|             "version": "3.3.8", | ||||
|             "resolved": "https://registry.npmjs.org/vue/-/vue-3.3.8.tgz", | ||||
|   | ||||
| @@ -19,6 +19,10 @@ const sslKeyPassphrase = args["ssl-key-passphrase"] || process.env.UPTIME_KUMA_S | ||||
|  | ||||
| const isSSL = sslKey && sslCert; | ||||
|  | ||||
| /** | ||||
|  * Get the local WebSocket URL | ||||
|  * @returns {string} The local WebSocket URL | ||||
|  */ | ||||
| function getLocalWebSocketURL() { | ||||
|     const protocol = isSSL ? "wss" : "ws"; | ||||
|     const host = hostname || "localhost"; | ||||
|   | ||||
| @@ -38,6 +38,7 @@ if (!semver.satisfies(nodeVersion, requiredNodeVersions)) { | ||||
|  | ||||
| const args = require("args-parser")(process.argv); | ||||
| const { sleep, log, getRandomInt, genSecret, isDev } = require("../src/util"); | ||||
| const config = require("./config"); | ||||
|  | ||||
| log.debug("server", "Arguments"); | ||||
| log.debug("server", args); | ||||
| @@ -86,7 +87,7 @@ const Monitor = require("./model/monitor"); | ||||
| const User = require("./model/user"); | ||||
|  | ||||
| log.debug("server", "Importing Settings"); | ||||
| const { getSettings, setSettings, setting, initJWTSecret, checkLogin, startUnitTest, doubleCheckPassword, startE2eTests, shake256, SHAKE256_LENGTH, allowDevAllOrigin, | ||||
| const { getSettings, setSettings, setting, initJWTSecret, checkLogin, doubleCheckPassword, startE2eTests, shake256, SHAKE256_LENGTH, allowDevAllOrigin, | ||||
| } = require("./util-server"); | ||||
|  | ||||
| log.debug("server", "Importing Notification"); | ||||
|   | ||||
| @@ -65,7 +65,6 @@ class UptimeKumaServer { | ||||
|     /** | ||||
|      * Get the current instance of the server if it exists, otherwise | ||||
|      * create a new instance. | ||||
|      * @param {object} args Arguments to pass to instance constructor | ||||
|      * @returns {UptimeKumaServer} Server instance | ||||
|      */ | ||||
|     static getInstance() { | ||||
| @@ -76,14 +75,9 @@ class UptimeKumaServer { | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param {object} args Arguments to initialise server with | ||||
|      * | ||||
|      */ | ||||
|     constructor() { | ||||
|         // SSL | ||||
|         const sslKey = args["ssl-key"] || process.env.UPTIME_KUMA_SSL_KEY || process.env.SSL_KEY || undefined; | ||||
|         const sslCert = args["ssl-cert"] || process.env.UPTIME_KUMA_SSL_CERT || process.env.SSL_CERT || undefined; | ||||
|         const sslKeyPassphrase = args["ssl-key-passphrase"] || process.env.UPTIME_KUMA_SSL_KEY_PASSPHRASE || process.env.SSL_KEY_PASSPHRASE || undefined; | ||||
|  | ||||
|         // Set axios default user-agent to Uptime-Kuma/version | ||||
|         axios.defaults.headers.common["User-Agent"] = this.getUserAgent(); | ||||
|  | ||||
| @@ -463,8 +457,9 @@ class UptimeKumaServer { | ||||
|     /** | ||||
|      * Force connected sockets of a user to refresh and disconnect. | ||||
|      * Used for resetting password. | ||||
|      * @param {string} userID | ||||
|      * @param {string?} currentSocketID | ||||
|      * @param {string} userID User ID | ||||
|      * @param {string?} currentSocketID Current socket ID | ||||
|      * @returns {void} | ||||
|      */ | ||||
|     disconnectAllSocketClients(userID, currentSocketID = undefined) { | ||||
|         for (const socket of this.io.sockets.sockets.values()) { | ||||
|   | ||||
							
								
								
									
										22
									
								
								src/util.js
									
									
									
									
									
								
							
							
						
						
									
										22
									
								
								src/util.js
									
									
									
									
									
								
							| @@ -10,8 +10,8 @@ | ||||
| */ | ||||
| var _a; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| exports.ucfirst = exports.sleep = exports.flipStatus = exports.CONSOLE_STYLE_BgGray = exports.CONSOLE_STYLE_BgWhite = exports.CONSOLE_STYLE_BgCyan = exports.CONSOLE_STYLE_BgMagenta = exports.CONSOLE_STYLE_BgBlue = exports.CONSOLE_STYLE_BgYellow = exports.CONSOLE_STYLE_BgGreen = exports.CONSOLE_STYLE_BgRed = exports.CONSOLE_STYLE_BgBlack = exports.CONSOLE_STYLE_FgPink = exports.CONSOLE_STYLE_FgBrown = exports.CONSOLE_STYLE_FgViolet = exports.CONSOLE_STYLE_FgLightBlue = exports.CONSOLE_STYLE_FgLightGreen = exports.CONSOLE_STYLE_FgOrange = exports.CONSOLE_STYLE_FgGray = exports.CONSOLE_STYLE_FgWhite = exports.CONSOLE_STYLE_FgCyan = exports.CONSOLE_STYLE_FgMagenta = exports.CONSOLE_STYLE_FgBlue = exports.CONSOLE_STYLE_FgYellow = exports.CONSOLE_STYLE_FgGreen = exports.CONSOLE_STYLE_FgRed = exports.CONSOLE_STYLE_FgBlack = exports.CONSOLE_STYLE_Hidden = exports.CONSOLE_STYLE_Reverse = exports.CONSOLE_STYLE_Blink = exports.CONSOLE_STYLE_Underscore = exports.CONSOLE_STYLE_Dim = exports.CONSOLE_STYLE_Bright = exports.CONSOLE_STYLE_Reset = exports.MIN_INTERVAL_SECOND = exports.MAX_INTERVAL_SECOND = exports.SQL_DATETIME_FORMAT_WITHOUT_SECOND = exports.SQL_DATETIME_FORMAT = exports.SQL_DATE_FORMAT = exports.STATUS_PAGE_MAINTENANCE = exports.STATUS_PAGE_PARTIAL_DOWN = exports.STATUS_PAGE_ALL_UP = exports.STATUS_PAGE_ALL_DOWN = exports.MAINTENANCE = exports.PENDING = exports.UP = exports.DOWN = exports.appName = exports.isNode = exports.isDev = void 0; | ||||
| exports.intHash = exports.localToUTC = exports.utcToLocal = exports.utcToISODateTime = exports.isoToUTCDateTime = exports.parseTimeFromTimeObject = exports.parseTimeObject = exports.getMaintenanceRelativeURL = exports.getMonitorRelativeURL = exports.genSecret = exports.getCryptoRandomInt = exports.getRandomInt = exports.getRandomArbitrary = exports.TimeLogger = exports.polyfill = exports.log = exports.debug = void 0; | ||||
| exports.sleep = exports.flipStatus = exports.badgeConstants = exports.CONSOLE_STYLE_BgGray = exports.CONSOLE_STYLE_BgWhite = exports.CONSOLE_STYLE_BgCyan = exports.CONSOLE_STYLE_BgMagenta = exports.CONSOLE_STYLE_BgBlue = exports.CONSOLE_STYLE_BgYellow = exports.CONSOLE_STYLE_BgGreen = exports.CONSOLE_STYLE_BgRed = exports.CONSOLE_STYLE_BgBlack = exports.CONSOLE_STYLE_FgPink = exports.CONSOLE_STYLE_FgBrown = exports.CONSOLE_STYLE_FgViolet = exports.CONSOLE_STYLE_FgLightBlue = exports.CONSOLE_STYLE_FgLightGreen = exports.CONSOLE_STYLE_FgOrange = exports.CONSOLE_STYLE_FgGray = exports.CONSOLE_STYLE_FgWhite = exports.CONSOLE_STYLE_FgCyan = exports.CONSOLE_STYLE_FgMagenta = exports.CONSOLE_STYLE_FgBlue = exports.CONSOLE_STYLE_FgYellow = exports.CONSOLE_STYLE_FgGreen = exports.CONSOLE_STYLE_FgRed = exports.CONSOLE_STYLE_FgBlack = exports.CONSOLE_STYLE_Hidden = exports.CONSOLE_STYLE_Reverse = exports.CONSOLE_STYLE_Blink = exports.CONSOLE_STYLE_Underscore = exports.CONSOLE_STYLE_Dim = exports.CONSOLE_STYLE_Bright = exports.CONSOLE_STYLE_Reset = exports.MIN_INTERVAL_SECOND = exports.MAX_INTERVAL_SECOND = exports.SQL_DATETIME_FORMAT_WITHOUT_SECOND = exports.SQL_DATETIME_FORMAT = exports.SQL_DATE_FORMAT = exports.STATUS_PAGE_MAINTENANCE = exports.STATUS_PAGE_PARTIAL_DOWN = exports.STATUS_PAGE_ALL_UP = exports.STATUS_PAGE_ALL_DOWN = exports.MAINTENANCE = exports.PENDING = exports.UP = exports.DOWN = exports.appName = exports.isNode = exports.isDev = void 0; | ||||
| exports.intHash = exports.localToUTC = exports.utcToLocal = exports.utcToISODateTime = exports.isoToUTCDateTime = exports.parseTimeFromTimeObject = exports.parseTimeObject = exports.getMaintenanceRelativeURL = exports.getMonitorRelativeURL = exports.genSecret = exports.getCryptoRandomInt = exports.getRandomInt = exports.getRandomArbitrary = exports.TimeLogger = exports.polyfill = exports.log = exports.debug = exports.ucfirst = void 0; | ||||
| const dayjs = require("dayjs"); | ||||
| exports.isDev = process.env.NODE_ENV === "development"; | ||||
| exports.isNode = typeof process !== "undefined" && ((_a = process === null || process === void 0 ? void 0 : process.versions) === null || _a === void 0 ? void 0 : _a.node); | ||||
| @@ -78,6 +78,24 @@ const consoleLevelColors = { | ||||
|     "ERROR": exports.CONSOLE_STYLE_FgRed, | ||||
|     "DEBUG": exports.CONSOLE_STYLE_FgGray, | ||||
| }; | ||||
| exports.badgeConstants = { | ||||
|     naColor: "#999", | ||||
|     defaultUpColor: "#66c20a", | ||||
|     defaultWarnColor: "#eed202", | ||||
|     defaultDownColor: "#c2290a", | ||||
|     defaultPendingColor: "#f8a306", | ||||
|     defaultMaintenanceColor: "#1747f5", | ||||
|     defaultPingColor: "blue", | ||||
|     defaultStyle: "flat", | ||||
|     defaultPingValueSuffix: "ms", | ||||
|     defaultPingLabelSuffix: "h", | ||||
|     defaultUptimeValueSuffix: "%", | ||||
|     defaultUptimeLabelSuffix: "h", | ||||
|     defaultCertExpValueSuffix: " days", | ||||
|     defaultCertExpLabelSuffix: "h", | ||||
|     defaultCertExpireWarnDays: "14", | ||||
|     defaultCertExpireDownDays: "7" | ||||
| }; | ||||
| function flipStatus(s) { | ||||
|     if (s === exports.UP) { | ||||
|         return exports.DOWN; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user