3.8.12
parent
a89b162eed
commit
50e150199e
10
Readme.md
10
Readme.md
|
@ -14,6 +14,16 @@
|
||||||
![preview](./preview.png)
|
![preview](./preview.png)
|
||||||
|
|
||||||
|
|
||||||
|
## 更新日志
|
||||||
|
|
||||||
|
- 2022.04.24
|
||||||
|
1. electron升级为18.0
|
||||||
|
2. 修复自动登录功能
|
||||||
|
3. 禁用`nodejs`, 注入更为安全
|
||||||
|
4. 包名修改为`top.yutent.dtalk`, 之前有安装过旧版的, 请先卸载
|
||||||
|
5. 不再打包`AppImage`版本, 其他非`debian`系发行版的, 请自行编译
|
||||||
|
|
||||||
|
|
||||||
## 打包好的安装包
|
## 打包好的安装包
|
||||||
|
|
||||||
下载地址请转到`release`页面
|
下载地址请转到`release`页面
|
||||||
|
|
24
package.json
24
package.json
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "dtalk",
|
"name": "dtalk",
|
||||||
"version": "3.8.8",
|
"version": "3.8.12",
|
||||||
"description": "钉钉-Linux版",
|
"description": "钉钉-Linux版",
|
||||||
"main": "src/main.js",
|
"main": "src/main.js",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
|
@ -9,31 +9,33 @@
|
||||||
},
|
},
|
||||||
"author": {
|
"author": {
|
||||||
"name": "yutent",
|
"name": "yutent",
|
||||||
"email": "yutent@doui.cc"
|
"email": "yutent.io@gmail.com"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"electron": "^6.0.0",
|
"electron": "^18.0.0",
|
||||||
"electron-builder": "^21.2.0"
|
"electron-builder": "^23.0.0"
|
||||||
},
|
},
|
||||||
"build": {
|
"build": {
|
||||||
"appId": "cc.doui.dtalk",
|
"appId": "top.yutent.dtalk",
|
||||||
"productName": "DingDing",
|
"productName": "钉钉(DingTalk)",
|
||||||
|
"electronDownload": {
|
||||||
|
"version": "18.1.0",
|
||||||
|
"mirror": "https://npm.taobao.org/mirrors/electron/"
|
||||||
|
},
|
||||||
"copyright": "Copyright © 2019 ${author}",
|
"copyright": "Copyright © 2019 ${author}",
|
||||||
"directories": {
|
"directories": {
|
||||||
"buildResources": "icons",
|
"buildResources": "icons",
|
||||||
"output": "build"
|
"output": "build"
|
||||||
},
|
},
|
||||||
"files": ["src/**/*"],
|
"files": [
|
||||||
|
"src/**/*"
|
||||||
|
],
|
||||||
"linux": {
|
"linux": {
|
||||||
"category": "Network;Chat",
|
"category": "Network;Chat",
|
||||||
"target": [
|
"target": [
|
||||||
{
|
{
|
||||||
"target": "deb",
|
"target": "deb",
|
||||||
"arch": "x64"
|
"arch": "x64"
|
||||||
},
|
|
||||||
{
|
|
||||||
"target": "AppImage",
|
|
||||||
"arch": "x64"
|
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"icon": "./icons/"
|
"icon": "./icons/"
|
||||||
|
|
58
src/main.js
58
src/main.js
|
@ -1,13 +1,15 @@
|
||||||
/* app */
|
/* app */
|
||||||
const { app, session, Menu } = require('electron')
|
const { app, session, Menu, ipcMain } = require('electron')
|
||||||
const path = require('path')
|
const { join } = require('path')
|
||||||
|
const fs = require('fs')
|
||||||
const log = console.log
|
|
||||||
|
|
||||||
const createTray = require('./tools/tray')
|
const createTray = require('./tools/tray')
|
||||||
const { createMainWindow } = require('./tools/windows')
|
const { createMainWindow } = require('./tools/windows')
|
||||||
|
|
||||||
const ROOT = __dirname
|
const ROOT = __dirname
|
||||||
|
const APP_DIR = join(app.getPath('appData'), './dtalk')
|
||||||
|
const sessionFile = join(APP_DIR, './login_session.json')
|
||||||
|
const cookieFile = join(APP_DIR, './login_cookie.json')
|
||||||
|
|
||||||
/* ----------------------------------------------------- */
|
/* ----------------------------------------------------- */
|
||||||
|
|
||||||
|
@ -22,10 +24,54 @@ Menu.setApplicationMenu(null)
|
||||||
app.once('ready', () => {
|
app.once('ready', () => {
|
||||||
// 修改app的UA
|
// 修改app的UA
|
||||||
session.defaultSession.setUserAgent(
|
session.defaultSession.setUserAgent(
|
||||||
'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/76.0.3809.100 Safari/537.36'
|
'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/100.0.4896.127 Safari/537.36'
|
||||||
)
|
)
|
||||||
|
|
||||||
let win = createMainWindow(path.join(ROOT, './images/app.png'))
|
let win = createMainWindow(join(ROOT, './images/app.png'))
|
||||||
|
|
||||||
createTray(win)
|
createTray(win)
|
||||||
})
|
})
|
||||||
|
|
||||||
|
ipcMain.on('app', (ev, conn) => {
|
||||||
|
switch (conn.type) {
|
||||||
|
case 'saveToken':
|
||||||
|
fs.writeFile(sessionFile, conn.data, function (err) {})
|
||||||
|
ev.returnValue = true
|
||||||
|
break
|
||||||
|
|
||||||
|
case 'readToken':
|
||||||
|
{
|
||||||
|
let cache = ''
|
||||||
|
try {
|
||||||
|
cache = fs.readFileSync(sessionFile).toString()
|
||||||
|
} catch (err) {}
|
||||||
|
ev.returnValue = cache
|
||||||
|
}
|
||||||
|
break
|
||||||
|
|
||||||
|
case 'restoreCookie':
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
let cache = fs.readFileSync(cookieFile).toString()
|
||||||
|
cache = JSON.parse(cache)
|
||||||
|
for (let it of cache) {
|
||||||
|
it.url = 'https://im.dingtalk.com'
|
||||||
|
|
||||||
|
session.defaultSession.cookies.set(it)
|
||||||
|
}
|
||||||
|
} catch (err) {}
|
||||||
|
ev.returnValue = true
|
||||||
|
}
|
||||||
|
break
|
||||||
|
|
||||||
|
case 'saveCookie':
|
||||||
|
{
|
||||||
|
let cookie = session.defaultSession.cookies.get({})
|
||||||
|
cookie.then(r => {
|
||||||
|
fs.writeFile(cookieFile, JSON.stringify(r), function (err) {})
|
||||||
|
})
|
||||||
|
ev.returnValue = true
|
||||||
|
}
|
||||||
|
break
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
|
@ -0,0 +1,28 @@
|
||||||
|
const { ipcRenderer, shell, contextBridge } = require('electron')
|
||||||
|
|
||||||
|
contextBridge.exposeInMainWorld('electron', {
|
||||||
|
open(url) {
|
||||||
|
shell.openExternal(url)
|
||||||
|
},
|
||||||
|
saveToken(id, token) {
|
||||||
|
token = JSON.parse(token)
|
||||||
|
// token.isAutoLogin = true
|
||||||
|
token = JSON.stringify(token)
|
||||||
|
|
||||||
|
ipcRenderer.sendSync('app', {
|
||||||
|
data: JSON.stringify({ id, token }),
|
||||||
|
type: 'saveToken'
|
||||||
|
})
|
||||||
|
},
|
||||||
|
readToken() {
|
||||||
|
return ipcRenderer.sendSync('app', { type: 'readToken' })
|
||||||
|
},
|
||||||
|
|
||||||
|
restoreCookie() {
|
||||||
|
return ipcRenderer.sendSync('app', { type: 'restoreCookie' })
|
||||||
|
},
|
||||||
|
|
||||||
|
saveCookie() {
|
||||||
|
return ipcRenderer.sendSync('app', { type: 'saveCookie' })
|
||||||
|
}
|
||||||
|
})
|
|
@ -1,16 +1,14 @@
|
||||||
/**
|
/**
|
||||||
* 托盘
|
* 托盘
|
||||||
* @author yutent<yutent@doui.cc>
|
* @author yutent<yutent.io@gmail.com>
|
||||||
* @date 2019/01/21 20:42:07
|
* @date 2019/01/21 20:42:07
|
||||||
*/
|
*/
|
||||||
|
|
||||||
'use strict'
|
|
||||||
|
|
||||||
const { app, Tray, Menu } = require('electron')
|
const { app, Tray, Menu } = require('electron')
|
||||||
const path = require('path')
|
const path = require('path')
|
||||||
const ROOT = __dirname
|
const ROOT = __dirname
|
||||||
|
|
||||||
module.exports = function(win) {
|
module.exports = function (win) {
|
||||||
app.__TRAY__ = new Tray(path.join(ROOT, '../images/tray.png'))
|
app.__TRAY__ = new Tray(path.join(ROOT, '../images/tray.png'))
|
||||||
let menuList = Menu.buildFromTemplate([
|
let menuList = Menu.buildFromTemplate([
|
||||||
{
|
{
|
||||||
|
|
|
@ -1,17 +1,16 @@
|
||||||
/**
|
/**
|
||||||
* 各种窗口创建
|
* 各种窗口创建
|
||||||
* @author yutent<yutent@doui.cc>
|
* @author yutent<yutent.io@gmail.com>
|
||||||
* @date 2019/01/26 18:28:22
|
* @date 2019/01/26 18:28:22
|
||||||
*/
|
*/
|
||||||
|
|
||||||
'use strict'
|
const { join } = require('path')
|
||||||
|
|
||||||
const { BrowserWindow } = require('electron')
|
const { BrowserWindow } = require('electron')
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 应用主窗口
|
* 应用主窗口
|
||||||
*/
|
*/
|
||||||
exports.createMainWindow = function(icon) {
|
exports.createMainWindow = function (icon) {
|
||||||
// 创建浏览器窗口
|
// 创建浏览器窗口
|
||||||
let win = new BrowserWindow({
|
let win = new BrowserWindow({
|
||||||
title: '钉钉-electron版',
|
title: '钉钉-electron版',
|
||||||
|
@ -23,14 +22,12 @@ exports.createMainWindow = function(icon) {
|
||||||
webPreferences: {
|
webPreferences: {
|
||||||
webSecurity: false,
|
webSecurity: false,
|
||||||
experimentalFeatures: true,
|
experimentalFeatures: true,
|
||||||
nodeIntegration: true
|
// nodeIntegration: true,
|
||||||
|
preload: join(__dirname, './inject.js')
|
||||||
},
|
},
|
||||||
show: false
|
show: false
|
||||||
})
|
})
|
||||||
|
|
||||||
// 然后加载应用的 index.html。
|
|
||||||
|
|
||||||
// win.loadURL('app://local/index.html')
|
|
||||||
win.loadURL('https://im.dingtalk.com')
|
win.loadURL('https://im.dingtalk.com')
|
||||||
|
|
||||||
win.on('ready-to-show', _ => {
|
win.on('ready-to-show', _ => {
|
||||||
|
@ -42,13 +39,10 @@ exports.createMainWindow = function(icon) {
|
||||||
win.webContents.on('dom-ready', ev => {
|
win.webContents.on('dom-ready', ev => {
|
||||||
win.webContents.executeJavaScript(
|
win.webContents.executeJavaScript(
|
||||||
`
|
`
|
||||||
|
|
||||||
const shell = require('electron').shell;
|
|
||||||
|
|
||||||
$(document).on('click', 'a[href^="http"]', function(event) {
|
$(document).on('click', 'a[href^="http"]', function(event) {
|
||||||
if(!this.hasAttribute('nwdirectory')){
|
if(!this.hasAttribute('nwdirectory')){
|
||||||
event.preventDefault();
|
event.preventDefault();
|
||||||
shell.openExternal(this.href);
|
electron.open(this.href)
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -56,18 +50,28 @@ exports.createMainWindow = function(icon) {
|
||||||
localStorage.setItem("notification", "true");
|
localStorage.setItem("notification", "true");
|
||||||
localStorage.setItem("newUserState", "secTip");
|
localStorage.setItem("newUserState", "secTip");
|
||||||
localStorage.setItem("latest_lang_info", "zh_CN");
|
localStorage.setItem("latest_lang_info", "zh_CN");
|
||||||
|
localStorage.setItem("login_method", "autoLogin");
|
||||||
|
|
||||||
if(localStorage.getItem('fuck2')){
|
|
||||||
|
|
||||||
sessionStorage.setItem('wk_device_id', localStorage.getItem('fuck1'))
|
let cache = electron.readToken()
|
||||||
sessionStorage.setItem('wk_token', localStorage.getItem('fuck2'))
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
if(cache){
|
||||||
|
cache = JSON.parse(cache)
|
||||||
|
sessionStorage.setItem('wk_device_id', cache.id)
|
||||||
|
sessionStorage.setItem('wk_token', cache.token)
|
||||||
|
|
||||||
|
electron.restoreCookie()
|
||||||
|
|
||||||
|
// 第一次进来刷新一下页面, 才会自动登录
|
||||||
if(!sessionStorage.getItem('first_in')){
|
if(!sessionStorage.getItem('first_in')){
|
||||||
sessionStorage.setItem('first_in', 1)
|
sessionStorage.setItem('first_in', 1)
|
||||||
|
setTimeout(function(){
|
||||||
location.reload()
|
location.reload()
|
||||||
|
}, 2000)
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
`,
|
`,
|
||||||
true
|
true
|
||||||
|
@ -80,9 +84,12 @@ exports.createMainWindow = function(icon) {
|
||||||
`
|
`
|
||||||
if(sessionStorage.getItem('wk_token')){
|
if(sessionStorage.getItem('wk_token')){
|
||||||
|
|
||||||
localStorage.setItem('fuck1', sessionStorage.getItem('wk_device_id'))
|
electron.saveCookie()
|
||||||
|
|
||||||
localStorage.setItem('fuck2', sessionStorage.getItem('wk_token'))
|
electron.saveToken(
|
||||||
|
sessionStorage.getItem('wk_device_id'),
|
||||||
|
sessionStorage.getItem('wk_token')
|
||||||
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
`,
|
`,
|
||||||
|
|
Reference in New Issue