From 2617f41417ff619b3207ca86e9cc58a6d343f0b7 Mon Sep 17 00:00:00 2001 From: xVanTuring Date: Mon, 16 Mar 2020 15:41:44 +0800 Subject: [PATCH 1/7] force win user to use http proxy as global proxy * remove toggle http ptoxy --- src/main/http-proxy.js | 4 ++-- src/main/pac.js | 13 +++++-------- src/main/proxy.js | 5 +---- src/main/tray.js | 18 ++---------------- src/renderer/views/option/Common.vue | 12 +++++------- src/shared/config.js | 6 ++---- 6 files changed, 17 insertions(+), 41 deletions(-) diff --git a/src/main/http-proxy.js b/src/main/http-proxy.js index fd15c36..47f4403 100644 --- a/src/main/http-proxy.js +++ b/src/main/http-proxy.js @@ -18,7 +18,7 @@ let socks2httpInstance * @param {Object} appConfig 应用配置 */ async function startHttpProxyServer (appConfig, isProxyStarted) { - if (isProxyStarted && appConfig.httpProxyEnable) { + if (isProxyStarted) { const host = appConfig.shareOverLan ? '0.0.0.0' : '127.0.0.1' try { await ensureHostPortValid(host, appConfig.httpProxyPort) @@ -87,7 +87,7 @@ appConfig$.subscribe(data => { startHttpProxyServer(appConfig, isProxyStarted) } else { // 数据变更 - if (['shareOverLan', 'httpProxyEnable', 'httpProxyPort'].some(key => changed.indexOf(key) > -1) || isProxyStarted !== isOldProxyStarted) { + if (['shareOverLan', 'httpProxyPort'].some(key => changed.indexOf(key) > -1) || isProxyStarted !== isOldProxyStarted) { stopHttpProxyServer().then(() => { startHttpProxyServer(appConfig, isProxyStarted) }) diff --git a/src/main/pac.js b/src/main/pac.js index 88b1c22..830717e 100644 --- a/src/main/pac.js +++ b/src/main/pac.js @@ -16,10 +16,8 @@ const $t = i18n.default let pacServer httpShutdown.extend() - -/** - * 下载pac文件 - */ +const replacePac = (str) => str.replace(/__PROXY__/g, + `SOCKS5 127.0.0.1:${currentConfig.localPort}; SOCKS 127.0.0.1:${currentConfig.localPort}; PROXY 127.0.0.1:${currentConfig.localPort}; PROXY 127.0.0.1:${currentConfig.httpProxyPort}; DIRECT`) export async function downloadPac (force = false) { await bootstrapPromise const pacExisted = await pathExists(pacRawPath) @@ -33,13 +31,12 @@ export async function downloadPac (force = false) { // always gen pac from raw pac = (await readFile(pacRawPath)).toString() } - pac = pac.replace(/__PROXY__/g, - `SOCKS5 127.0.0.1:${currentConfig.localPort}; SOCKS 127.0.0.1:${currentConfig.localPort}; PROXY 127.0.0.1:${currentConfig.localPort}; ${currentConfig.httpProxyEnable ? 'PROXY 127.0.0.1:' + currentConfig.httpProxyPort + ';' : ''} DIRECT`) + pac = replacePac(pac) await writeFile(pacPath, pac) } async function updatePacProxy () { let content = (await readFile(pacRawPath)).toString() - content = content.replace(/__PROXY__/g, `SOCKS5 127.0.0.1:${currentConfig.localPort}; SOCKS 127.0.0.1:${currentConfig.localPort}; PROXY 127.0.0.1:${currentConfig.localPort}; ${currentConfig.httpProxyEnable ? 'PROXY 127.0.0.1:' + currentConfig.httpProxyPort + ';' : ''} DIRECT`) + content = replacePac(content) await writeFile(pacPath, content) } let ensurePacPromise = null @@ -125,7 +122,7 @@ appConfig$.subscribe(data => { serverPac(appConfig, isProxyStarted) }) } - if (['localPort', 'httpProxyEnable', 'httpProxyPort'].some(key => changed.indexOf(key) > -1)) { + if (['localPort', 'httpProxyPort'].some(key => changed.indexOf(key) > -1)) { console.log('Ported UPdated') updatePacProxy() } diff --git a/src/main/proxy.js b/src/main/proxy.js index 8730d63..d7b0b1a 100644 --- a/src/main/proxy.js +++ b/src/main/proxy.js @@ -98,7 +98,7 @@ async function setProxyByMode (mode) { } else if (mode === 1) { await setProxyToPac(`http://127.0.0.1:${currentConfig.pacPort}/proxy.pac`) } else if (mode === 2) { - await setProxyToGlobal('127.0.0.1', currentConfig.preferHTTPGlobal ? currentConfig.httpProxyPort : currentConfig.localPort) + await setProxyToGlobal('127.0.0.1', (isWin || currentConfig.preferHTTPGlobal) ? currentConfig.httpProxyPort : currentConfig.localPort) } } @@ -116,9 +116,6 @@ export function startProxy (mode) { if (mode === undefined) { mode = currentConfig.sysProxyMode } - if (isWin && mode === 2 && currentConfig.preferHTTPGlobal === 1 && !currentConfig.httpProxyEnable) { - updateAppConfig({ httpProxyEnable: true }) - } setProxyByMode(mode) } diff --git a/src/main/tray.js b/src/main/tray.js index 1503774..e8c25a8 100644 --- a/src/main/tray.js +++ b/src/main/tray.js @@ -1,5 +1,5 @@ -import { Menu, nativeImage, Tray, dialog } from 'electron' -import { appConfig$, updateAppConfig } from './data' +import { Menu, nativeImage, Tray } from 'electron' +import { appConfig$ } from './data' import * as handler from './tray-handler' import { groupConfigs } from '@/shared/utils' import { isMac, isWin, isOldMacVersion } from '../shared/env' @@ -121,20 +121,6 @@ export function changeProxy (e, mode, appConfig) { if (mode === appConfig.sysProxyMode) { e.checked = true } else { - if (isWin && mode === 2 && appConfig.preferHTTPGlobal === -1) { - dialog.showMessageBox({ - title: $t('MENU_SUB_GLOBAL_PROXY'), - message: $t('NOTO_WIND_GLOBAL_PROXY'), - buttons: ['Yes', 'No'], - type: 'info' - }).then((response) => { - if (response.response === 0) { - updateAppConfig({ preferHTTPGlobal: 1 }) - } else { - updateAppConfig({ preferHTTPGlobal: 0 }) - } - }) - } handler.toggleProxy(mode) } } diff --git a/src/renderer/views/option/Common.vue b/src/renderer/views/option/Common.vue index 601faa5..038d668 100644 --- a/src/renderer/views/option/Common.vue +++ b/src/renderer/views/option/Common.vue @@ -20,9 +20,6 @@ - - -
@@ -50,7 +47,7 @@ /> - +
@@ -67,6 +64,7 @@ import { mapActions } from 'vuex' import { isSSRPathAvaliable, debounce } from '@/shared/utils' import { openDialog } from '@/renderer/ipc' import i18n from '@/renderer/i18n' +import { isWin } from '@/shared/env' export default { data () { const appConfig = this.$store.state.appConfig @@ -78,10 +76,9 @@ export default { shareOverLan: appConfig.shareOverLan, localPort: appConfig.localPort, pacPort: appConfig.pacPort, - httpProxyEnable: appConfig.httpProxyEnable, httpProxyPort: appConfig.httpProxyPort, lang: appConfig.lang, - preferHTTPGlobal: appConfig.preferHTTPGlobal === 1 + preferHTTPGlobal: isWin ? true : appConfig.preferHTTPGlobal === 1 }, rules: { ssrPath: [ @@ -98,7 +95,8 @@ export default { } } ] - } + }, + diabledPreferSwitch: isWin } }, watch: { diff --git a/src/shared/config.js b/src/shared/config.js index 40856f9..b216693 100644 --- a/src/shared/config.js +++ b/src/shared/config.js @@ -1,4 +1,4 @@ -import { isLinux } from './env' +import { isLinux, isWin } from './env' const defaultConfig = { // 配置集合 @@ -22,8 +22,6 @@ const defaultConfig = { sysProxyMode: 0, // 订阅列表 serverSubscribes: [], - // 是否开启http proxy - httpProxyEnable: false, // 全局快捷键 globalShortcuts: { toggleWindow: { @@ -44,7 +42,7 @@ const defaultConfig = { lang: 'en-US', isMacToolInstalled: false, noMacToolInstall: false, - preferHTTPGlobal: -1 + preferHTTPGlobal: isWin ? 1 : -1 } export default defaultConfig From ca221fdf83c56bac87df7ee270a4ee0a6a5a123b Mon Sep 17 00:00:00 2001 From: xVanTuring Date: Mon, 16 Mar 2020 15:44:28 +0800 Subject: [PATCH 2/7] use absolute path --- src/renderer/views/Setup.vue | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/renderer/views/Setup.vue b/src/renderer/views/Setup.vue index 4391e5c..4866cfc 100644 --- a/src/renderer/views/Setup.vue +++ b/src/renderer/views/Setup.vue @@ -36,12 +36,12 @@ import { ipcRenderer } from 'electron' import { join } from 'path' import { mapState, mapMutations } from 'vuex' import { openDialog } from '../ipc' -import { isSSRPathAvaliable } from '../../shared/utils' +import { isSSRPathAvaliable } from '@/shared/utils' import { STORE_KEY_AUTO_DOWNLOAD } from '../constants' import { EVENT_SSR_DOWNLOAD_RENDERER, EVENT_SSR_DOWNLOAD_MAIN -} from '../../shared/events' +} from '@/shared/events' import Dot from '../components/Dot' export default { From 5bd48a5cb449ebbdb685f1942422fb66eb0efc37 Mon Sep 17 00:00:00 2001 From: xVanTuring Date: Mon, 16 Mar 2020 17:31:30 +0800 Subject: [PATCH 3/7] fix: prefer http proxy in gnome --- src/main/proxy.js | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/src/main/proxy.js b/src/main/proxy.js index d7b0b1a..b4205eb 100644 --- a/src/main/proxy.js +++ b/src/main/proxy.js @@ -72,7 +72,11 @@ export async function setProxyToGlobal (host, port) { } else if (isMac && await pathExists(macToolPath) && !await isOldMacVersion) { command = `"${macToolPath}" -m global -p ${port}` } else if (isLinux && await isGsettingsAvaliable) { - command = `gsettings set org.gnome.system.proxy mode 'manual' && gsettings set org.gnome.system.proxy.socks host '${host}' && gsettings set org.gnome.system.proxy.socks port ${port}` + if (currentConfig.preferHTTPGlobal === 1) { + command = `gsettings set org.gnome.system.proxy mode 'manual' && gsettings set org.gnome.system.proxy.http host '${host}' && gsettings set org.gnome.system.proxy.http port ${port} && gsettings set org.gnome.system.proxy.https host '${host}' && gsettings set org.gnome.system.proxy.https port ${port}` + } else { + command = `gsettings set org.gnome.system.proxy mode 'manual' && gsettings set org.gnome.system.proxy.socks host '${host}' && gsettings set org.gnome.system.proxy.socks port ${port}` + } } await runCommand(command) } From 0f46f0ed42c29482f86d28a94c75679fe0b5c89a Mon Sep 17 00:00:00 2001 From: xVanTuring Date: Mon, 16 Mar 2020 17:32:47 +0800 Subject: [PATCH 4/7] remove unused export in proxy.js --- src/main/proxy.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/main/proxy.js b/src/main/proxy.js index b4205eb..11172f3 100644 --- a/src/main/proxy.js +++ b/src/main/proxy.js @@ -65,7 +65,7 @@ export async function setProxyToNone (force = true) { /** * 设置代理为全局 */ -export async function setProxyToGlobal (host, port) { +async function setProxyToGlobal (host, port) { let command if (isWin && await pathExists(winToolPath)) { command = `${winToolPath} global ${host}:${port} "localhost;127.*;10.*;172.16.*;172.17.*;172.18.*;172.19.*;172.20.*;172.21.*;172.22.*;172.23.*;172.24.*;172.25.*;172.26.*;172.27.*;172.28.*;172.29.*;172.30.*;172.31.*;192.168.*;"` @@ -84,7 +84,7 @@ export async function setProxyToGlobal (host, port) { /** * 设置代理为PAC代理 */ -export async function setProxyToPac (pacUrl) { +async function setProxyToPac (pacUrl) { let command if (isWin && await pathExists(winToolPath)) { command = `${winToolPath} pac ${pacUrl}` From 9f2c94dcfd0ae349358e6402feb70d92c8ef3419 Mon Sep 17 00:00:00 2001 From: xVanTuring Date: Tue, 2 Jun 2020 07:39:28 +0800 Subject: [PATCH 5/7] add python3 detection --- src/main/client.js | 12 ++++++------ src/shared/env.js | 22 ++++++++++++++-------- 2 files changed, 20 insertions(+), 14 deletions(-) diff --git a/src/main/client.js b/src/main/client.js index 83a6161..817764a 100644 --- a/src/main/client.js +++ b/src/main/client.js @@ -9,7 +9,7 @@ import { isConfigEqual } from '../shared/utils' import { showNotification } from './notification' import { toggleEnable } from './tray-handler' import * as i18n from './locales' -import { isWin } from '@/shared/env' +import { isWin, pythonName } from '@/shared/env' const $t = i18n.default let quitByCommand = false /** @@ -21,8 +21,8 @@ let pythonSSRInstance * 运行shell命令并写入到日志中 * @param {string[]} params 待执行的shell命令 */ -function runPythonSSR (params) { - let command = 'python' +function runPythonSSR(params) { + let command = pythonName const commandStr = `${command} ${params.join(' ')}` logger.info('run command: %s', commandStr.replace(/-k [\d\w]* /, '-k ****** ')) if (isWin) { @@ -71,7 +71,7 @@ function runPythonSSR (params) { * 运行ssr * @param {Object} appConfig ssr配置 */ -export async function run (appConfig) { +export async function run(appConfig) { const listenHost = appConfig.shareOverLan ? '0.0.0.0' : '127.0.0.1' // 先结束之前的 await stop() @@ -123,7 +123,7 @@ export async function run (appConfig) { * 结束command的后台运行 * @returns {Promise} */ -export function stop (force = false) { +export function stop(force = false) { if (pythonSSRInstance && !pythonSSRInstance.killed) { logger.log('Kill client') return new Promise((resolve) => { @@ -157,7 +157,7 @@ export function stop (force = false) { * 根据配置运行SSR命令 * @param {Object} appConfig 应用配置 */ -export function runWithConfig (appConfig) { +export function runWithConfig(appConfig) { if (appConfig.ssrPath && appConfig.enable && appConfig.configs && appConfig.index >= 0 && appConfig.configs[appConfig.index]) { run(appConfig) } diff --git a/src/shared/env.js b/src/shared/env.js index 07b1ae6..0857244 100644 --- a/src/shared/env.js +++ b/src/shared/env.js @@ -1,22 +1,28 @@ import os from 'os' import { exec } from 'child_process' - +import util from 'util' export const platform = os.platform() export const isWin = platform === 'win32' export const isMac = platform === 'darwin' export const isLinux = platform === 'linux' - +export let pythonName = 'python' +const execAsync = util.promisify(exec) // python 是否已安装 -export let isPythonInstalled = new Promise((resolve) => { - exec(`python -c "print('hello')"`, (err, stdout) => { - if (err) { +export let isPythonInstalled = new Promise(async (resolve) => { + try { + let result = await execAsync(`python -c "print('hello')"`) + resolve(/^hello$/.test(result.stdout.toString().trim())) + } catch (error) { + try { + let result = await execAsync(`python3 -c "print('hello')"`) + pythonName = 'python3' + resolve(/^hello$/.test(result.stdout.toString().trim())) + } catch (error) { resolve(false) - } else { - resolve(/^hello$/.test(stdout.toString().trim())) } - }) + } }) // mac版本号 From 0a021cfa0a38e41bda384fa3c15b06409daa68ad Mon Sep 17 00:00:00 2001 From: xVanTuring Date: Tue, 2 Jun 2020 08:44:47 +0800 Subject: [PATCH 6/7] lint --- src/main/client.js | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/main/client.js b/src/main/client.js index 817764a..a83baaf 100644 --- a/src/main/client.js +++ b/src/main/client.js @@ -21,7 +21,7 @@ let pythonSSRInstance * 运行shell命令并写入到日志中 * @param {string[]} params 待执行的shell命令 */ -function runPythonSSR(params) { +function runPythonSSR (params) { let command = pythonName const commandStr = `${command} ${params.join(' ')}` logger.info('run command: %s', commandStr.replace(/-k [\d\w]* /, '-k ****** ')) @@ -71,7 +71,7 @@ function runPythonSSR(params) { * 运行ssr * @param {Object} appConfig ssr配置 */ -export async function run(appConfig) { +export async function run (appConfig) { const listenHost = appConfig.shareOverLan ? '0.0.0.0' : '127.0.0.1' // 先结束之前的 await stop() @@ -123,7 +123,7 @@ export async function run(appConfig) { * 结束command的后台运行 * @returns {Promise} */ -export function stop(force = false) { +export function stop (force = false) { if (pythonSSRInstance && !pythonSSRInstance.killed) { logger.log('Kill client') return new Promise((resolve) => { @@ -157,7 +157,7 @@ export function stop(force = false) { * 根据配置运行SSR命令 * @param {Object} appConfig 应用配置 */ -export function runWithConfig(appConfig) { +export function runWithConfig (appConfig) { if (appConfig.ssrPath && appConfig.enable && appConfig.configs && appConfig.index >= 0 && appConfig.configs[appConfig.index]) { run(appConfig) } From d777cab29d38f185ddbdc6136904349bc64f6f1d Mon Sep 17 00:00:00 2001 From: xVanTuring Date: Tue, 2 Jun 2020 08:47:40 +0800 Subject: [PATCH 7/7] version update --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index 4508701..b9b4ec8 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "electron-ssr", - "version": "0.3.0-alpha.5", + "version": "0.3.0-alpha.6", "description": "Cross platform ShadowsocksR GUI client built with electron", "author": { "name": "The Electron-SSR Authors",