mirror of
https://github.com/lan-tianxiang/JS_TOOL.git
synced 2025-07-13 13:52:36 +08:00
更新于 07-14 22:36
This commit is contained in:
464
.AutoConfig/Env.js
Executable file
464
.AutoConfig/Env.js
Executable file
@ -0,0 +1,464 @@
|
||||
const canRequest = (url) => {
|
||||
const [, , host] = url.split('/')
|
||||
|
||||
if (
|
||||
![
|
||||
'oapi.dingtalk.com',
|
||||
'cdn.jsdelivr.net',
|
||||
'lkyl.dianpusoft.cn',
|
||||
'raw.githubusercontent.com',
|
||||
'www.fastmock.site',
|
||||
].includes(host) &&
|
||||
!/\.jd\.com$/.test(host) &&
|
||||
!/\.jingxi\.com/.test(host) &&
|
||||
!/\.isvjcloud\.com/.test(host)
|
||||
) {
|
||||
console.log(host, url)
|
||||
throw new Error(`该请求url不合法: ${url}`)
|
||||
}
|
||||
}
|
||||
|
||||
function Env(t, e) {
|
||||
'undefined' != typeof process &&
|
||||
JSON.stringify(process.env).indexOf('GITHUB') > -1 &&
|
||||
process.exit(0)
|
||||
|
||||
class s {
|
||||
constructor(t) {
|
||||
this.env = t
|
||||
}
|
||||
|
||||
send(t, e = 'GET') {
|
||||
t = 'string' == typeof t ? { url: t } : t
|
||||
let s = this.get
|
||||
return (
|
||||
'POST' === e && (s = this.post),
|
||||
new Promise((e, i) => {
|
||||
s.call(this, t, (t, s, r) => {
|
||||
t ? i(t) : e(s)
|
||||
})
|
||||
})
|
||||
)
|
||||
}
|
||||
|
||||
get(t) {
|
||||
return this.send.call(this.env, t)
|
||||
}
|
||||
|
||||
post(t) {
|
||||
return this.send.call(this.env, t, 'POST')
|
||||
}
|
||||
}
|
||||
|
||||
return new (class {
|
||||
constructor(t, e) {
|
||||
;(this.name = t),
|
||||
(this.http = new s(this)),
|
||||
(this.data = null),
|
||||
(this.dataFile = 'box.dat'),
|
||||
(this.logs = []),
|
||||
(this.isMute = !1),
|
||||
(this.isNeedRewrite = !1),
|
||||
(this.logSeparator = '\n'),
|
||||
(this.startTime = new Date().getTime()),
|
||||
Object.assign(this, e),
|
||||
this.log('', `🔔${this.name}, 开始!`)
|
||||
}
|
||||
|
||||
isNode() {
|
||||
return 'undefined' != typeof module && !!module.exports
|
||||
}
|
||||
|
||||
isQuanX() {
|
||||
return 'undefined' != typeof $task
|
||||
}
|
||||
|
||||
isSurge() {
|
||||
return 'undefined' != typeof $httpClient && 'undefined' == typeof $loon
|
||||
}
|
||||
|
||||
isLoon() {
|
||||
return 'undefined' != typeof $loon
|
||||
}
|
||||
|
||||
toObj(t, e = null) {
|
||||
try {
|
||||
return JSON.parse(t)
|
||||
} catch {
|
||||
return e
|
||||
}
|
||||
}
|
||||
|
||||
toStr(t, e = null) {
|
||||
try {
|
||||
return JSON.stringify(t)
|
||||
} catch {
|
||||
return e
|
||||
}
|
||||
}
|
||||
|
||||
getjson(t, e) {
|
||||
let s = e
|
||||
const i = this.getdata(t)
|
||||
if (i)
|
||||
try {
|
||||
s = JSON.parse(this.getdata(t))
|
||||
} catch {}
|
||||
return s
|
||||
}
|
||||
|
||||
setjson(t, e) {
|
||||
try {
|
||||
return this.setdata(JSON.stringify(t), e)
|
||||
} catch {
|
||||
return !1
|
||||
}
|
||||
}
|
||||
|
||||
getScript(t) {
|
||||
return new Promise((e) => {
|
||||
this.get({ url: t }, (t, s, i) => e(i))
|
||||
})
|
||||
}
|
||||
|
||||
runScript(t, e) {
|
||||
return new Promise((s) => {
|
||||
let i = this.getdata('@chavy_boxjs_userCfgs.httpapi')
|
||||
i = i ? i.replace(/\n/g, '').trim() : i
|
||||
let r = this.getdata('@chavy_boxjs_userCfgs.httpapi_timeout')
|
||||
;(r = r ? 1 * r : 20), (r = e && e.timeout ? e.timeout : r)
|
||||
const [o, h] = i.split('@'),
|
||||
n = {
|
||||
url: `http://${h}/v1/scripting/evaluate`,
|
||||
body: { script_text: t, mock_type: 'cron', timeout: r },
|
||||
headers: { 'X-Key': o, Accept: '*/*' },
|
||||
}
|
||||
this.post(n, (t, e, i) => s(i))
|
||||
}).catch((t) => this.logErr(t))
|
||||
}
|
||||
|
||||
loaddata() {
|
||||
if (!this.isNode()) return {}
|
||||
{
|
||||
;(this.fs = this.fs ? this.fs : require('fs')),
|
||||
(this.path = this.path ? this.path : require('path'))
|
||||
const t = this.path.resolve(this.dataFile),
|
||||
e = this.path.resolve(process.cwd(), this.dataFile),
|
||||
s = this.fs.existsSync(t),
|
||||
i = !s && this.fs.existsSync(e)
|
||||
if (!s && !i) return {}
|
||||
{
|
||||
const i = s ? t : e
|
||||
try {
|
||||
return JSON.parse(this.fs.readFileSync(i))
|
||||
} catch (t) {
|
||||
return {}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
writedata() {
|
||||
if (this.isNode()) {
|
||||
;(this.fs = this.fs ? this.fs : require('fs')),
|
||||
(this.path = this.path ? this.path : require('path'))
|
||||
const t = this.path.resolve(this.dataFile),
|
||||
e = this.path.resolve(process.cwd(), this.dataFile),
|
||||
s = this.fs.existsSync(t),
|
||||
i = !s && this.fs.existsSync(e),
|
||||
r = JSON.stringify(this.data)
|
||||
s
|
||||
? this.fs.writeFileSync(t, r)
|
||||
: i
|
||||
? this.fs.writeFileSync(e, r)
|
||||
: this.fs.writeFileSync(t, r)
|
||||
}
|
||||
}
|
||||
|
||||
lodash_get(t, e, s) {
|
||||
const i = e.replace(/\[(\d+)\]/g, '.$1').split('.')
|
||||
let r = t
|
||||
for (const t of i) if (((r = Object(r)[t]), void 0 === r)) return s
|
||||
return r
|
||||
}
|
||||
|
||||
lodash_set(t, e, s) {
|
||||
return Object(t) !== t
|
||||
? t
|
||||
: (Array.isArray(e) || (e = e.toString().match(/[^.[\]]+/g) || []),
|
||||
(e
|
||||
.slice(0, -1)
|
||||
.reduce(
|
||||
(t, s, i) =>
|
||||
Object(t[s]) === t[s]
|
||||
? t[s]
|
||||
: (t[s] = Math.abs(e[i + 1]) >> 0 == +e[i + 1] ? [] : {}),
|
||||
t
|
||||
)[e[e.length - 1]] = s),
|
||||
t)
|
||||
}
|
||||
|
||||
getdata(t) {
|
||||
let e = this.getval(t)
|
||||
if (/^@/.test(t)) {
|
||||
const [, s, i] = /^@(.*?)\.(.*?)$/.exec(t),
|
||||
r = s ? this.getval(s) : ''
|
||||
if (r)
|
||||
try {
|
||||
const t = JSON.parse(r)
|
||||
e = t ? this.lodash_get(t, i, '') : e
|
||||
} catch (t) {
|
||||
e = ''
|
||||
}
|
||||
}
|
||||
return e
|
||||
}
|
||||
|
||||
setdata(t, e) {
|
||||
let s = !1
|
||||
if (/^@/.test(e)) {
|
||||
const [, i, r] = /^@(.*?)\.(.*?)$/.exec(e),
|
||||
o = this.getval(i),
|
||||
h = i ? ('null' === o ? null : o || '{}') : '{}'
|
||||
try {
|
||||
const e = JSON.parse(h)
|
||||
this.lodash_set(e, r, t), (s = this.setval(JSON.stringify(e), i))
|
||||
} catch (e) {
|
||||
const o = {}
|
||||
this.lodash_set(o, r, t), (s = this.setval(JSON.stringify(o), i))
|
||||
}
|
||||
} else s = this.setval(t, e)
|
||||
return s
|
||||
}
|
||||
|
||||
getval(t) {
|
||||
return this.isSurge() || this.isLoon()
|
||||
? $persistentStore.read(t)
|
||||
: this.isQuanX()
|
||||
? $prefs.valueForKey(t)
|
||||
: this.isNode()
|
||||
? ((this.data = this.loaddata()), this.data[t])
|
||||
: (this.data && this.data[t]) || null
|
||||
}
|
||||
|
||||
setval(t, e) {
|
||||
return this.isSurge() || this.isLoon()
|
||||
? $persistentStore.write(t, e)
|
||||
: this.isQuanX()
|
||||
? $prefs.setValueForKey(t, e)
|
||||
: this.isNode()
|
||||
? ((this.data = this.loaddata()),
|
||||
(this.data[e] = t),
|
||||
this.writedata(),
|
||||
!0)
|
||||
: (this.data && this.data[e]) || null
|
||||
}
|
||||
|
||||
initGotEnv(t) {
|
||||
;(this.got = this.got ? this.got : require('got')),
|
||||
(this.cktough = this.cktough ? this.cktough : require('tough-cookie')),
|
||||
(this.ckjar = this.ckjar ? this.ckjar : new this.cktough.CookieJar()),
|
||||
t &&
|
||||
((t.headers = t.headers ? t.headers : {}),
|
||||
void 0 === t.headers.Cookie &&
|
||||
void 0 === t.cookieJar &&
|
||||
(t.cookieJar = this.ckjar))
|
||||
}
|
||||
|
||||
get(t, e = () => {}) {
|
||||
canRequest(t.url)
|
||||
|
||||
t.headers &&
|
||||
(delete t.headers['Content-Type'], delete t.headers['Content-Length']),
|
||||
this.isSurge() || this.isLoon()
|
||||
? (this.isSurge() &&
|
||||
this.isNeedRewrite &&
|
||||
((t.headers = t.headers || {}),
|
||||
Object.assign(t.headers, { 'X-Surge-Skip-Scripting': !1 })),
|
||||
$httpClient.get(t, (t, s, i) => {
|
||||
!t && s && ((s.body = i), (s.statusCode = s.status)), e(t, s, i)
|
||||
}))
|
||||
: this.isQuanX()
|
||||
? (this.isNeedRewrite &&
|
||||
((t.opts = t.opts || {}), Object.assign(t.opts, { hints: !1 })),
|
||||
$task.fetch(t).then(
|
||||
(t) => {
|
||||
const { statusCode: s, statusCode: i, headers: r, body: o } = t
|
||||
e(null, { status: s, statusCode: i, headers: r, body: o }, o)
|
||||
},
|
||||
(t) => e(t)
|
||||
))
|
||||
: this.isNode() &&
|
||||
(this.initGotEnv(t),
|
||||
this.got(t)
|
||||
.on('redirect', (t, e) => {
|
||||
try {
|
||||
if (t.headers['set-cookie']) {
|
||||
const s = t.headers['set-cookie']
|
||||
.map(this.cktough.Cookie.parse)
|
||||
.toString()
|
||||
s && this.ckjar.setCookieSync(s, null),
|
||||
(e.cookieJar = this.ckjar)
|
||||
}
|
||||
} catch (t) {
|
||||
this.logErr(t)
|
||||
}
|
||||
})
|
||||
.then(
|
||||
(t) => {
|
||||
const {
|
||||
statusCode: s,
|
||||
statusCode: i,
|
||||
headers: r,
|
||||
body: o,
|
||||
} = t
|
||||
e(null, { status: s, statusCode: i, headers: r, body: o }, o)
|
||||
},
|
||||
(t) => {
|
||||
const { message: s, response: i } = t
|
||||
e(s, i, i && i.body)
|
||||
}
|
||||
))
|
||||
}
|
||||
|
||||
post(t, e = () => {}) {
|
||||
canRequest(t.url)
|
||||
|
||||
if (
|
||||
(t.body &&
|
||||
t.headers &&
|
||||
!t.headers['Content-Type'] &&
|
||||
(t.headers['Content-Type'] = 'application/x-www-form-urlencoded'),
|
||||
t.headers && delete t.headers['Content-Length'],
|
||||
this.isSurge() || this.isLoon())
|
||||
)
|
||||
this.isSurge() &&
|
||||
this.isNeedRewrite &&
|
||||
((t.headers = t.headers || {}),
|
||||
Object.assign(t.headers, { 'X-Surge-Skip-Scripting': !1 })),
|
||||
$httpClient.post(t, (t, s, i) => {
|
||||
!t && s && ((s.body = i), (s.statusCode = s.status)), e(t, s, i)
|
||||
})
|
||||
else if (this.isQuanX())
|
||||
(t.method = 'POST'),
|
||||
this.isNeedRewrite &&
|
||||
((t.opts = t.opts || {}), Object.assign(t.opts, { hints: !1 })),
|
||||
$task.fetch(t).then(
|
||||
(t) => {
|
||||
const { statusCode: s, statusCode: i, headers: r, body: o } = t
|
||||
e(null, { status: s, statusCode: i, headers: r, body: o }, o)
|
||||
},
|
||||
(t) => e(t)
|
||||
)
|
||||
else if (this.isNode()) {
|
||||
this.initGotEnv(t)
|
||||
const { url: s, ...i } = t
|
||||
this.got.post(s, i).then(
|
||||
(t) => {
|
||||
const { statusCode: s, statusCode: i, headers: r, body: o } = t
|
||||
e(null, { status: s, statusCode: i, headers: r, body: o }, o)
|
||||
},
|
||||
(t) => {
|
||||
const { message: s, response: i } = t
|
||||
e(s, i, i && i.body)
|
||||
}
|
||||
)
|
||||
}
|
||||
}
|
||||
|
||||
time(t, e = null) {
|
||||
const s = e ? new Date(e) : new Date()
|
||||
let i = {
|
||||
'M+': s.getMonth() + 1,
|
||||
'd+': s.getDate(),
|
||||
'H+': s.getHours(),
|
||||
'm+': s.getMinutes(),
|
||||
's+': s.getSeconds(),
|
||||
'q+': Math.floor((s.getMonth() + 3) / 3),
|
||||
S: s.getMilliseconds(),
|
||||
}
|
||||
;/(y+)/.test(t) &&
|
||||
(t = t.replace(
|
||||
RegExp.$1,
|
||||
(s.getFullYear() + '').substr(4 - RegExp.$1.length)
|
||||
))
|
||||
for (let e in i)
|
||||
new RegExp('(' + e + ')').test(t) &&
|
||||
(t = t.replace(
|
||||
RegExp.$1,
|
||||
1 == RegExp.$1.length
|
||||
? i[e]
|
||||
: ('00' + i[e]).substr(('' + i[e]).length)
|
||||
))
|
||||
return t
|
||||
}
|
||||
|
||||
msg(e = t, s = '', i = '', r) {
|
||||
const o = (t) => {
|
||||
if (!t) return t
|
||||
if ('string' == typeof t)
|
||||
return this.isLoon()
|
||||
? t
|
||||
: this.isQuanX()
|
||||
? { 'open-url': t }
|
||||
: this.isSurge()
|
||||
? { url: t }
|
||||
: void 0
|
||||
if ('object' == typeof t) {
|
||||
if (this.isLoon()) {
|
||||
let e = t.openUrl || t.url || t['open-url'],
|
||||
s = t.mediaUrl || t['media-url']
|
||||
return { openUrl: e, mediaUrl: s }
|
||||
}
|
||||
if (this.isQuanX()) {
|
||||
let e = t['open-url'] || t.url || t.openUrl,
|
||||
s = t['media-url'] || t.mediaUrl
|
||||
return { 'open-url': e, 'media-url': s }
|
||||
}
|
||||
if (this.isSurge()) {
|
||||
let e = t.url || t.openUrl || t['open-url']
|
||||
return { url: e }
|
||||
}
|
||||
}
|
||||
}
|
||||
if (
|
||||
(this.isMute ||
|
||||
(this.isSurge() || this.isLoon()
|
||||
? $notification.post(e, s, i, o(r))
|
||||
: this.isQuanX() && $notify(e, s, i, o(r))),
|
||||
!this.isMuteLog)
|
||||
) {
|
||||
let t = ['', '==============📣系统通知📣==============']
|
||||
t.push(e),
|
||||
s && t.push(s),
|
||||
i && t.push(i),
|
||||
console.log(t.join('\n')),
|
||||
(this.logs = this.logs.concat(t))
|
||||
}
|
||||
}
|
||||
|
||||
log(...t) {
|
||||
t.length > 0 && (this.logs = [...this.logs, ...t]),
|
||||
console.log(t.join(this.logSeparator))
|
||||
}
|
||||
|
||||
logErr(t, e) {
|
||||
const s = !this.isSurge() && !this.isQuanX() && !this.isLoon()
|
||||
s
|
||||
? this.log('', `❗️${this.name}, 错误!`, t.stack)
|
||||
: this.log('', `❗️${this.name}, 错误!`, t)
|
||||
}
|
||||
|
||||
wait(t) {
|
||||
return new Promise((e) => setTimeout(e, t))
|
||||
}
|
||||
|
||||
done(t = {}) {
|
||||
const e = new Date().getTime(),
|
||||
s = (e - this.startTime) / 1e3
|
||||
this.log('', `🔔${this.name}, 结束! 🕛 ${s} 秒`),
|
||||
this.log(),
|
||||
(this.isSurge() || this.isQuanX() || this.isLoon()) && $done(t)
|
||||
}
|
||||
})(t, e)
|
||||
}
|
49
jd.sh
49
jd.sh
@ -51,6 +51,7 @@ file_sharecode_sample=$dir_sample/sharecode.sh.sample
|
||||
file_sharecode_user_sample=$dir_config/sharecode.sh.sample
|
||||
file_config_user=$dir_config/config.sh
|
||||
file_config_sys=$dir_AutoConfig/config.sh
|
||||
file_env_sys=$dir_AutoConfig/Env.js
|
||||
file_auth_sample=$dir_sample/auth.json.sample
|
||||
file_auth_user=$dir_config/auth.json
|
||||
file_diy_shell=$dir_config/diy.sh
|
||||
@ -337,6 +338,7 @@ fix_config() {
|
||||
done
|
||||
}
|
||||
|
||||
#提权
|
||||
chmod -R +x $dir_root
|
||||
}
|
||||
|
||||
@ -353,6 +355,7 @@ fix_files() {
|
||||
}
|
||||
|
||||
AutoConfig() {
|
||||
#加密面板shell
|
||||
local RandomNum j RandomCode
|
||||
for ((j = 0; j <= 20; j++)); do
|
||||
RandomNum=$(gen_random_num 35)
|
||||
@ -372,10 +375,26 @@ AutoConfig() {
|
||||
[[ -n $(grep -w DefaultRandom $file_config_sys) ]] && perl -i -pe "s|DefaultRandom|$RandomCode|g" $file_config_sys && PanelReboot=1
|
||||
. $file_config_sys
|
||||
|
||||
#git配置
|
||||
git config --global user.email "lan-tianxiang@@users.noreply.github.com"
|
||||
git config --global user.name "lan-tianxiang"
|
||||
git config --global pull.rebase true
|
||||
}
|
||||
|
||||
##感谢Huansheng1提供的限制脚本请求域名,提升安全性 来源atzcl/as@84ccb59
|
||||
SecureJs() {
|
||||
local file startLine endLine
|
||||
file=$1
|
||||
|
||||
if [[ -z $(grep -w "该请求url不合法" $file) ]]; then
|
||||
startLine=$(sed -n '/function Env(t,e)/=' $file)
|
||||
endLine=$(sed -n 'done(t)}}(t,e)}' $file)
|
||||
|
||||
sed -i $startLine','$endLine'd' $file
|
||||
cat $file_env_sys >> $file
|
||||
fi
|
||||
}
|
||||
|
||||
## =================================================2. 日记区 =================================================
|
||||
|
||||
## 删除运行js脚本的旧日志
|
||||
@ -1658,7 +1677,32 @@ run_normal() {
|
||||
log_path="$dir_log/$file_name/$log_time.log"
|
||||
make_dir "$dir_log/$file_name"
|
||||
cd $which_path
|
||||
echo "执行${which_program}"
|
||||
echo "执行${which_program},路径$file_name_all"
|
||||
[ ${TasksTerminateTime} = 0 ] && $which_program $file_name_all 2>&1 | tee $log_path
|
||||
[ ${TasksTerminateTime} -ne 0 ] && timeout ${TasksTerminateTime} $which_program $file_name_all 2>&1 | tee $log_path
|
||||
run_task_finish "$file_name" 2>&1 | tee -a $log_path
|
||||
else
|
||||
echo -e "\n $p 脚本不存在,请确认...\n"
|
||||
usage
|
||||
fi
|
||||
}
|
||||
|
||||
run_normaltest() {
|
||||
local p=$1
|
||||
define_program "$p"
|
||||
#ps -ef | grep $p | awk '{print $1}' | xargs kill -9 >/dev/null 2>&1
|
||||
find_file_and_path $p
|
||||
if [[ $file_name ]] && [[ $which_path ]]; then
|
||||
import_config_and_check "$file_name"
|
||||
count_user_sum
|
||||
export_all_env all
|
||||
[[ $# -eq 1 ]] && random_delay
|
||||
log_time=$(date "+%Y-%m-%d-%H-%M-%S")
|
||||
log_path="$dir_log/$file_name/$log_time.log"
|
||||
make_dir "$dir_log/$file_name"
|
||||
cd $which_path
|
||||
echo "执行${which_program},路径$file_name_all"
|
||||
SecureJs $file_name_all
|
||||
[ ${TasksTerminateTime} = 0 ] && $which_program $file_name_all 2>&1 | tee $log_path
|
||||
[ ${TasksTerminateTime} -ne 0 ] && timeout ${TasksTerminateTime} $which_program $file_name_all 2>&1 | tee $log_path
|
||||
run_task_finish "$file_name" 2>&1 | tee -a $log_path
|
||||
@ -1871,6 +1915,9 @@ case $# in
|
||||
[1-9] | [1-9][0-9] | [1-9][0-9][0-9])
|
||||
run_specify $1 $2
|
||||
;;
|
||||
test715)
|
||||
run_normaltest $1 $2
|
||||
;;
|
||||
*)
|
||||
echo -e "\n命令输入错误...\n"
|
||||
usage
|
||||
|
Reference in New Issue
Block a user