mirror of
https://gh.catmak.name/https://github.com/mihomo-party-org/mihomo-party
synced 2025-12-27 05:00:30 +08:00
fix windows auto start
This commit is contained in:
parent
fb6e81080d
commit
daf5152dd3
@ -2,7 +2,7 @@ import { electronApp, optimizer, is } from '@electron-toolkit/utils'
|
|||||||
import { registerIpcMainHandlers } from './utils/ipc'
|
import { registerIpcMainHandlers } from './utils/ipc'
|
||||||
import windowStateKeeper from 'electron-window-state'
|
import windowStateKeeper from 'electron-window-state'
|
||||||
import { app, shell, BrowserWindow, Menu, dialog, Notification } from 'electron'
|
import { app, shell, BrowserWindow, Menu, dialog, Notification } from 'electron'
|
||||||
import { startMihomoMemory, stopMihomoMemory } from './core/mihomoApi'
|
import { pauseWebsockets, startMihomoMemory, stopMihomoMemory } from './core/mihomoApi'
|
||||||
import { addProfileItem, getAppConfig } from './config'
|
import { addProfileItem, getAppConfig } from './config'
|
||||||
import { stopCore } from './core/manager'
|
import { stopCore } from './core/manager'
|
||||||
import { triggerSysProxy } from './sys/sysproxy'
|
import { triggerSysProxy } from './sys/sysproxy'
|
||||||
@ -43,6 +43,7 @@ app.on('window-all-closed', (e) => {
|
|||||||
})
|
})
|
||||||
|
|
||||||
app.on('before-quit', () => {
|
app.on('before-quit', () => {
|
||||||
|
pauseWebsockets()
|
||||||
stopCore()
|
stopCore()
|
||||||
triggerSysProxy(false)
|
triggerSysProxy(false)
|
||||||
app.exit()
|
app.exit()
|
||||||
|
|||||||
@ -8,8 +8,8 @@ import path from 'path'
|
|||||||
|
|
||||||
const appName = 'mihomo-party'
|
const appName = 'mihomo-party'
|
||||||
|
|
||||||
const taskXml = `
|
const taskXml = `<?xml version="1.0" encoding="UTF-16"?>
|
||||||
<Task version="1.2" xmlns="http://schemas.microsoft.com/windows/2004/02/mit/task">
|
<Task version="1.2" xmlns="http://schemas.microsoft.com/windows/2004/02/mit/task">
|
||||||
<RegistrationInfo>
|
<RegistrationInfo>
|
||||||
<Date>${new Date().toISOString()}</Date>
|
<Date>${new Date().toISOString()}</Date>
|
||||||
<Author>${process.env.USERNAME}</Author>
|
<Author>${process.env.USERNAME}</Author>
|
||||||
@ -49,7 +49,7 @@ const taskXml = `
|
|||||||
<Command>${exePath()}</Command>
|
<Command>${exePath()}</Command>
|
||||||
</Exec>
|
</Exec>
|
||||||
</Actions>
|
</Actions>
|
||||||
</Task>
|
</Task>
|
||||||
`
|
`
|
||||||
|
|
||||||
export async function checkAutoRun(): Promise<boolean> {
|
export async function checkAutoRun(): Promise<boolean> {
|
||||||
@ -77,7 +77,7 @@ export async function enableAutoRun(): Promise<void> {
|
|||||||
if (process.platform === 'win32') {
|
if (process.platform === 'win32') {
|
||||||
const execPromise = promisify(exec)
|
const execPromise = promisify(exec)
|
||||||
const taskFilePath = path.join(dataDir(), `${appName}.xml`)
|
const taskFilePath = path.join(dataDir(), `${appName}.xml`)
|
||||||
await writeFile(taskFilePath, taskXml)
|
await writeFile(taskFilePath, Buffer.from(`\ufeff${taskXml}`, 'utf-16le'))
|
||||||
await execPromise(`schtasks /create /tn "${appName}" /xml "${taskFilePath}" /f`)
|
await execPromise(`schtasks /create /tn "${appName}" /xml "${taskFilePath}" /f`)
|
||||||
}
|
}
|
||||||
if (process.platform === 'darwin') {
|
if (process.platform === 'darwin') {
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user