mirror of
https://github.com/whyour/qinglong.git
synced 2025-05-22 22:36:06 +08:00
增加git_diy脚本,支持自定义拉取仓库
This commit is contained in:
parent
6ad50be6fb
commit
602e2775f7
24
csv.sh
24
csv.sh
|
@ -1,24 +0,0 @@
|
|||
#!/usr/bin/env bash
|
||||
|
||||
## 判断环境
|
||||
ShellDir=${JD_DIR:-$(cd $(dirname $0); pwd)}
|
||||
LogDir=${ShellDir}/log
|
||||
Income=${LogDir}/bean_income.csv
|
||||
Outlay=${LogDir}/bean_outlay.csv
|
||||
|
||||
## 执行
|
||||
cd ${LogDir}/jd_bean_change
|
||||
for log in $(ls); do
|
||||
LogDate=$(echo ${log} | cut -c1-10)
|
||||
BeanDate=$(date "+%Y-%m-%d" -d "1 day ago ${LogDate}")
|
||||
|
||||
if [[ -z $(grep "${BeanDate}" ${Income}) ]]; then
|
||||
echo -n "${BeanDate}," >> ${Income}
|
||||
grep -E "昨日收入" ${log} | grep -oE "\d+" | perl -0777 -pe "s|\n(\d+)|,\1|g" >> ${Income}
|
||||
fi
|
||||
|
||||
if [[ -z $(grep "${BeanDate}" ${Outlay}) ]]; then
|
||||
echo -n "${BeanDate}," >> ${Outlay}
|
||||
grep -E "昨日支出" ${log} | grep -oE "\d+" | perl -0777 -pe "s|\n(\d+)|,\1|g" >> ${Outlay}
|
||||
fi
|
||||
done
|
|
@ -35,6 +35,12 @@ RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
|
|||
&& git clone -b ${JD_BASE_BRANCH} ${JD_BASE_URL} ${JD_DIR} \
|
||||
&& cd ${JD_DIR} \
|
||||
&& cp -f .env.example .env \
|
||||
&& ln -sf ${JD_DIR}/shell/jd.sh /usr/local/bin/jd \
|
||||
&& ln -sf ${JD_DIR}/shell/git_pull.sh /usr/local/bin/git_pull \
|
||||
&& ln -sf ${JD_DIR}/shell/rm_log.sh /usr/local/bin/rm_log \
|
||||
&& ln -sf ${JD_DIR}/shell/export_sharecodes.sh /usr/local/bin/export_sharecodes \
|
||||
&& ln -sf ${JD_DIR}/shell/git_diy.sh /usr/local/bin/diy \
|
||||
&& ln -sf ${JD_DIR}/shell/notify.sh /usr/local/bin/notify \
|
||||
&& yarn install \
|
||||
&& yarn build \
|
||||
&& yarn build-back \
|
||||
|
|
|
@ -34,13 +34,13 @@ nginx -c /etc/nginx/nginx.conf
|
|||
echo
|
||||
|
||||
echo -e "======================3. 更新源代码========================\n"
|
||||
bash ${JD_DIR}/git_pull.sh
|
||||
bash ${JD_DIR}/shell/git_pull.sh
|
||||
echo
|
||||
|
||||
echo -e "======================4. 启动挂机程序========================\n"
|
||||
. ${JD_DIR}/config/config.sh
|
||||
if [ -n "${Cookie1}" ]; then
|
||||
bash ${JD_DIR}/jd.sh hangup 2>/dev/null
|
||||
bash ${JD_DIR}/shell/jd.sh hangup 2>/dev/null
|
||||
echo -e "挂机程序启动成功...\n"
|
||||
else
|
||||
echo -e "config.sh中还未填入有效的Cookie,可能是首次部署容器,因此不启动挂机程序...\n"
|
||||
|
|
|
@ -272,7 +272,7 @@ ForOtherJoy6=""
|
|||
## 具体填法及要求详见本文件最下方“互助码填法示例”
|
||||
## 京喜农场助力码为 JSON 格式因此使用单引号,json 格式如下
|
||||
## {"smp":"22bdadsfaadsfadse8a","active":"jdnc_1_btorange210113_2","joinnum":"1"}
|
||||
## 助力码获取可以通过 bash jd.sh jd_get_share_code now 命令获取
|
||||
## 助力码获取可以通过 bash jd jd_get_share_code now 命令获取
|
||||
## 注意:京喜农场 种植种子发生变化的时候,互助码也会变!!
|
||||
MyJxnc1=''
|
||||
MyJxnc2=''
|
||||
|
|
|
@ -1,5 +1,6 @@
|
|||
# 更新lxk0301大佬的js脚本,添加随机cron,日志为log/git_pull.log,每天只更新两次
|
||||
# 更新你需要的仓库的代码
|
||||
55 2,13 * * * bash git_pull >> ${JD_DIR}/log/git_pull.log 2>&1
|
||||
30 * * * * bash diy i-chenzhe qx >> ${JD_DIR}/log/diy_pull.log 2>&1
|
||||
|
||||
# 删除 RmLogDaysAgo 指定天数以前的旧日志,本行为不记录日志
|
||||
57 13 * * * bash rm_log >/dev/null 2>&1
|
||||
|
|
89
shell/git_diy.sh
Normal file
89
shell/git_diy.sh
Normal file
|
@ -0,0 +1,89 @@
|
|||
#!/usr/bin/env bash
|
||||
#author:spark thanks to: https://github.com/sparkssssssss/scripts
|
||||
#需要docker环境,下载本文件到容器内任意位置,以下示例是放到了/jd/scripts
|
||||
#*/30 * * * * bash diy i-chenzhe qx
|
||||
|
||||
declare -A BlackListDict
|
||||
author=$1
|
||||
repo=$2
|
||||
#指定仓库屏蔽关键词,不添加计划任务,多个按照格式二
|
||||
BlackListDict['i-chenzhe']="_get"
|
||||
BlackListDict['sparkssssssss']="smzdm|tg|xxxxxxxx"
|
||||
|
||||
blackword=${BlackListDict["${author}"]}
|
||||
blackword=${blackword:-"wojiushigejimo"}
|
||||
|
||||
if [ $# != 2 ] ; then
|
||||
echo "USAGE: $0 author repo"
|
||||
exit 0;
|
||||
fi
|
||||
|
||||
diyscriptsdir=/jd/diyscripts
|
||||
mkdir -p ${diyscriptsdir}
|
||||
|
||||
if [ ! -d "$diyscriptsdir/${author}_${repo}" ]; then
|
||||
echo -e "${author}本地仓库不存在,从gayhub拉取ing..."
|
||||
cd ${diyscriptsdir} && git clone https://github.com/${author}/${repo}.git ${author}_${repo}
|
||||
gitpullstatus=$?
|
||||
[ $gitpullstatus -eq 0 ] && echo -e "${author}本地仓库拉取完毕"
|
||||
[ $gitpullstatus -ne 0 ] && echo -e "${author}本地仓库拉取失败,请检查!" && exit 0
|
||||
else
|
||||
cd ${diyscriptsdir}/${author}_${repo}
|
||||
branch=`git symbolic-ref --short -q HEAD`
|
||||
git fetch --all
|
||||
git reset --hard origin/$branch
|
||||
git pull
|
||||
gitpullstatus=$?
|
||||
fi
|
||||
|
||||
rand(){
|
||||
min=$1
|
||||
max=$(($2-$min+1))
|
||||
num=$(cat /proc/sys/kernel/random/uuid | cksum | awk -F ' ' '{print $1}')
|
||||
echo $(($num%$max+$min))
|
||||
}
|
||||
|
||||
function addnewcron {
|
||||
addname=""
|
||||
cd ${diyscriptsdir}/${author}_${repo}
|
||||
for js in `ls *.js|egrep -v $blackword`;
|
||||
do
|
||||
croname=`echo "${author}_$js"|awk -F\. '{print $1}'`
|
||||
script_date=`cat $js|grep ^[0-9]|awk '{print $1,$2,$3,$4,$5}'|egrep -v "[a-zA-Z]|:|\."|sort |uniq|head -n 1`
|
||||
[ -z "${script_date}" ] && script_date=`cat $js|grep -Eo "([0-9]+|\*|[0-9]+[,-].*) ([0-9]+|\*|[0-9]+[,-].*) ([0-9]+|\*|[0-9]+[,-].*) ([0-9]+|\*|[0-9]+[,-].*) ([0-9]+|\*|[0-9][,-].*)"|sort |uniq|head -n 1`
|
||||
[ -z "${script_date}" ] && cron_min=$(rand 1 59) && cron_hour=$(rand 7 9) && script_date="${cron_min} ${cron_hour} * * *"
|
||||
[ $(grep -c -w "$croname" /jd/config/crontab.list) -eq 0 ] && sed -i "/hangup/a${script_date} bash jd $croname" /jd/config/crontab.list && addname="${addname}\n${croname}" && echo -e "添加了新的脚本${croname}." && bash jd ${croname} now >/dev/null &
|
||||
if [ ! -f "/jd/scripts/${author}_$js" ];then
|
||||
\cp $js /jd/scripts/${author}_$js
|
||||
else
|
||||
change=$(diff $js /jd/scripts/${author}_$js)
|
||||
[ -n "${change}" ] && \cp $js /jd/scripts/${author}_$js && echo -e "${author}_$js 脚本更新了."
|
||||
fi
|
||||
done
|
||||
[ "$addname" != "" ] notify "新增 ${author} 自定义脚本" "${addname}"
|
||||
|
||||
}
|
||||
|
||||
function delcron {
|
||||
delname=""
|
||||
cronfiles=$(grep "$author" /jd/config/crontab.list|grep -v "^#"|awk '{print $8}'|awk -F"${author}_" '{print $2}')
|
||||
for filename in $cronfiles;
|
||||
do
|
||||
if [ ! -f "${diyscriptsdir}/${author}_${repo}/${filename}.js" ]; then
|
||||
sed -i "/\<bash jd ${author}_${filename}\>/d" /jd/config/crontab.list && echo -e "删除失效脚本${filename}."
|
||||
delname="${delname}\n${author}_${filename}"
|
||||
fi
|
||||
done
|
||||
[ "$delname" != "" ] && notify "删除 ${author} 失效脚本" "${delname}"
|
||||
}
|
||||
|
||||
if [[ ${gitpullstatus} -eq 0 ]]
|
||||
then
|
||||
addnewcron
|
||||
delcron
|
||||
else
|
||||
echo -e "$author 仓库更新失败了."
|
||||
notify "自定义仓库更新失败" "$author"
|
||||
fi
|
||||
|
||||
exit 0
|
|
@ -2,18 +2,16 @@
|
|||
|
||||
## 文件路径、脚本网址、文件版本以及各种环境的判断
|
||||
ShellDir=${JD_DIR:-$(cd $(dirname $0); pwd)}
|
||||
[[ ${JD_DIR} ]] && ShellJd=jd || ShellJd=${ShellDir}/jd.sh
|
||||
[[ ${JD_DIR} ]] && ShellJd=jd || ShellJd=${ShellDir}/shell/jd.sh
|
||||
LogDir=${ShellDir}/log
|
||||
[ ! -d ${LogDir} ] && mkdir -p ${LogDir}
|
||||
ScriptsDir=${ShellDir}/scripts
|
||||
Scripts2Dir=${ShellDir}/scripts2
|
||||
ConfigDir=${ShellDir}/config
|
||||
FileConf=${ConfigDir}/config.sh
|
||||
FileDiy=${ConfigDir}/diy.sh
|
||||
FileConfSample=${ShellDir}/sample/config.sh.sample
|
||||
ListCron=${ConfigDir}/crontab.list
|
||||
ListCronLxk=${ScriptsDir}/docker/crontab_list.sh
|
||||
ListCronShylocks=${Scripts2Dir}/docker/crontab_list.sh
|
||||
ListTask=${LogDir}/task.list
|
||||
ListJs=${LogDir}/js.list
|
||||
ListJsAdd=${LogDir}/js-add.list
|
||||
|
@ -23,8 +21,8 @@ ContentNewTask=${ShellDir}/new_task
|
|||
ContentDropTask=${ShellDir}/drop_task
|
||||
SendCount=${ShellDir}/send_count
|
||||
isTermux=${ANDROID_RUNTIME_ROOT}${ANDROID_ROOT}
|
||||
ShellURL=${JD_SHELL_URL:-git@gitee.com:evine/jd_shell.git}
|
||||
ScriptsURL=${JD_SCRIPTS_URL:-git@gitee.com:lxk0301/jd_scripts.git}
|
||||
ShellURL=https://github.com.cnpmjs.org/whyour/qinglong
|
||||
ScriptsURL=https://github.com.cnpmjs.org/RikudouPatrickstar/jd_scripts
|
||||
|
||||
## 导入配置文件
|
||||
function Import_Conf {
|
||||
|
@ -53,31 +51,16 @@ function Update_Cron {
|
|||
crontab ${ListCron}
|
||||
fi
|
||||
}
|
||||
|
||||
## 重置仓库remote url
|
||||
function Reset_RepoUrl {
|
||||
if [[ ${JD_DIR} ]] && [[ ${ENABLE_RESET_REPO_URL} == true ]]; then
|
||||
if [ -d ${ShellDir}/.git ]; then
|
||||
cd ${ShellDir}
|
||||
git remote set-url origin ${ShellURL}
|
||||
git reset --hard
|
||||
fi
|
||||
if [ -d ${ScriptsDir}/.git ]; then
|
||||
cd ${ScriptsDir}
|
||||
git remote set-url origin ${ScriptsURL}
|
||||
git reset --hard
|
||||
fi
|
||||
fi
|
||||
}
|
||||
|
||||
## 更新shell
|
||||
function Git_PullShell {
|
||||
echo -e "更新shell...\n"
|
||||
cd ${ShellDir}
|
||||
git fetch --all
|
||||
git stash
|
||||
git pull
|
||||
ExitStatusShell=$?
|
||||
git reset --hard origin/master
|
||||
echo
|
||||
git stash pop
|
||||
git reset --mixed
|
||||
}
|
||||
|
||||
## 更新shell成功后的操作
|
||||
|
@ -95,7 +78,6 @@ function Git_PullShellNext {
|
|||
|
||||
## 克隆scripts
|
||||
function Git_CloneScripts {
|
||||
echo -e "克隆scripts...\n"
|
||||
git clone -b master ${ScriptsURL} ${ScriptsDir}
|
||||
ExitStatusScripts=$?
|
||||
echo
|
||||
|
@ -106,9 +88,16 @@ function Git_PullScripts {
|
|||
echo -e "更新scripts...\n"
|
||||
cd ${ScriptsDir}
|
||||
git fetch --all
|
||||
git rm -f i-chenzhe*
|
||||
git rm -f moposmall*
|
||||
git rm -f qq34347476*
|
||||
git rm -f whyour*
|
||||
git stash
|
||||
git pull
|
||||
ExitStatusScripts=$?
|
||||
git reset --hard origin/master
|
||||
echo
|
||||
git stash pop
|
||||
git reset --mixed
|
||||
}
|
||||
|
||||
## 更新docker-entrypoint
|
||||
|
@ -274,8 +263,7 @@ function Del_Cron {
|
|||
crontab -l
|
||||
echo -e "\n--------------------------------------------------------------\n"
|
||||
if [ -d ${ScriptsDir}/node_modules ]; then
|
||||
echo -e "删除失效的定时任务:\n\n${JsDrop}" > ${ContentDropTask}
|
||||
Notify_DropTask
|
||||
notify "删除 lxk0301 失效脚本" "${JsDrop}"
|
||||
fi
|
||||
fi
|
||||
}
|
||||
|
@ -308,14 +296,12 @@ function Add_Cron {
|
|||
crontab -l
|
||||
echo -e "\n--------------------------------------------------------------\n"
|
||||
if [ -d ${ScriptsDir}/node_modules ]; then
|
||||
echo -e "成功添加新的定时任务:\n\n${JsAdd}" > ${ContentNewTask}
|
||||
Notify_NewTask
|
||||
notify "新增 lxk0301 自定义脚本" "${JsAdd}"
|
||||
fi
|
||||
else
|
||||
echo -e "添加新的定时任务出错,请手动添加...\n"
|
||||
if [ -d ${ScriptsDir}/node_modules ]; then
|
||||
echo -e "尝试自动添加以下新的定时任务出错,请手动添加:\n\n${JsAdd}" > ${ContentNewTask}
|
||||
Notify_NewTask
|
||||
notify "尝试自动添加 lxk0301 以下新的定时任务出错,请手动添加:" "${JsAdd}"
|
||||
fi
|
||||
fi
|
||||
fi
|
||||
|
@ -336,7 +322,6 @@ echo -e "--------------------------------------------------------------\n"
|
|||
## 导入配置,更新cron,设置url,更新shell,复制sample,复制entrypoint,发送新配置通知
|
||||
Import_Conf "git_pull"
|
||||
Update_Cron
|
||||
Reset_RepoUrl
|
||||
[ -f ${ShellDir}/panel/package.json ] && PanelDependOld=$(cat ${ShellDir}/panel/package.json)
|
||||
Git_PullShell
|
||||
[ -f ${ShellDir}/panel/package.json ] && PanelDependNew=$(cat ${ShellDir}/panel/package.json)
|
|
@ -3,7 +3,7 @@
|
|||
## 路径
|
||||
ShellDir=${JD_DIR:-$(cd $(dirname $0); pwd)}
|
||||
[[ ${JD_DIR} ]] && HelpJd=jd || HelpJd=jd.sh
|
||||
[[ ${JD_DIR} ]] && ShellJd=jd || ShellJd=${ShellDir}/jd.sh
|
||||
[[ ${JD_DIR} ]] && ShellJd=jd || ShellJd=${ShellDir}/shell/jd.sh
|
||||
ScriptsDir=${ShellDir}/scripts
|
||||
ConfigDir=${ShellDir}/config
|
||||
FileConf=${ConfigDir}/config.sh
|
5
shell/notify.js
Normal file
5
shell/notify.js
Normal file
|
@ -0,0 +1,5 @@
|
|||
const notify = require('../scripts/sendNotify');
|
||||
const title = process.argv[2];
|
||||
const content = process.argv[3];
|
||||
|
||||
notify.sendNotify(`${title}`, `${content}`);
|
8
shell/notify.sh
Normal file
8
shell/notify.sh
Normal file
|
@ -0,0 +1,8 @@
|
|||
#!/bin/bash
|
||||
#author:spark thanks to: https://github.com/sparkssssssss/scripts
|
||||
|
||||
. /jd/config/config.sh
|
||||
title=$(echo $1|sed 's/-/_/g')
|
||||
msg=$(echo -e $2)
|
||||
|
||||
node /jd/shell/sendinfo.js "$title" "$msg"
|
447
shell/update.js
Executable file
447
shell/update.js
Executable file
|
@ -0,0 +1,447 @@
|
|||
/*
|
||||
* @Author: lxk0301 https://github.com/lxk0301
|
||||
* @Date: 2020-12-20 13:50:34
|
||||
* @Last Modified by: lxk0301
|
||||
* @Last Modified time: 2020-12-20 13:51:02
|
||||
*/
|
||||
const $ = new Env('通知');
|
||||
const notify = require('./scripts/sendNotify');
|
||||
const fs = require('fs');
|
||||
!(async () => {
|
||||
await update();
|
||||
})()
|
||||
.catch((e) => $.logErr(e))
|
||||
.finally(() => $.done());
|
||||
|
||||
async function update() {
|
||||
try {
|
||||
if (fs.existsSync('new_task')) {
|
||||
const newTaskContent = await fs.readFileSync('./new_task', 'utf8');
|
||||
if (newTaskContent) {
|
||||
await notify.sendNotify('新增薅羊毛任务通知', newTaskContent);
|
||||
}
|
||||
}
|
||||
|
||||
if (fs.existsSync('drop_task')) {
|
||||
const dropTaskContent = await fs.readFileSync('./drop_task', 'utf8');
|
||||
if (dropTaskContent) {
|
||||
await notify.sendNotify('删除失效任务通知', dropTaskContent);
|
||||
}
|
||||
}
|
||||
|
||||
if (fs.existsSync('version')) {
|
||||
const versionContent = await fs.readFileSync('./version', 'utf8');
|
||||
if (versionContent) {
|
||||
await notify.sendNotify('配置文件更新通知', versionContent);
|
||||
}
|
||||
}
|
||||
} catch (err) {
|
||||
console.error(err);
|
||||
}
|
||||
}
|
||||
function Env(t, e) {
|
||||
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('', `\ud83d\udd14${this.name}, \u5f00\u59cb!`);
|
||||
}
|
||||
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('@'),
|
||||
a = {
|
||||
url: `http://${h}/v1/scripting/evaluate`,
|
||||
body: { script_text: t, mock_type: 'cron', timeout: r },
|
||||
headers: { 'X-Key': o, Accept: '*/*' },
|
||||
};
|
||||
this.post(a, (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 = () => {}) {
|
||||
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();
|
||||
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 = () => {}) {
|
||||
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) {
|
||||
let e = {
|
||||
'M+': new Date().getMonth() + 1,
|
||||
'd+': new Date().getDate(),
|
||||
'H+': new Date().getHours(),
|
||||
'm+': new Date().getMinutes(),
|
||||
's+': new Date().getSeconds(),
|
||||
'q+': Math.floor((new Date().getMonth() + 3) / 3),
|
||||
S: new Date().getMilliseconds(),
|
||||
};
|
||||
/(y+)/.test(t) &&
|
||||
(t = t.replace(
|
||||
RegExp.$1,
|
||||
(new Date().getFullYear() + '').substr(4 - RegExp.$1.length),
|
||||
));
|
||||
for (let s in e)
|
||||
new RegExp('(' + s + ')').test(t) &&
|
||||
(t = t.replace(
|
||||
RegExp.$1,
|
||||
1 == RegExp.$1.length
|
||||
? e[s]
|
||||
: ('00' + e[s]).substr(('' + e[s]).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 };
|
||||
}
|
||||
}
|
||||
};
|
||||
this.isMute ||
|
||||
(this.isSurge() || this.isLoon()
|
||||
? $notification.post(e, s, i, o(r))
|
||||
: this.isQuanX() && $notify(e, s, i, o(r)));
|
||||
let h = [
|
||||
'',
|
||||
'==============\ud83d\udce3\u7cfb\u7edf\u901a\u77e5\ud83d\udce3==============',
|
||||
];
|
||||
h.push(e),
|
||||
s && h.push(s),
|
||||
i && h.push(i),
|
||||
console.log(h.join('\n')),
|
||||
(this.logs = this.logs.concat(h));
|
||||
}
|
||||
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('', `\u2757\ufe0f${this.name}, \u9519\u8bef!`, t.stack)
|
||||
: this.log('', `\u2757\ufe0f${this.name}, \u9519\u8bef!`, t);
|
||||
}
|
||||
wait(t) {
|
||||
return new Promise((e) => setTimeout(e, t));
|
||||
}
|
||||
done(t = {}) {
|
||||
const e = new Date().getTime(),
|
||||
s = (e - this.startTime) / 1e3;
|
||||
this.log(
|
||||
'',
|
||||
`\ud83d\udd14${this.name}, \u7ed3\u675f! \ud83d\udd5b ${s} \u79d2`,
|
||||
),
|
||||
this.log(),
|
||||
(this.isSurge() || this.isQuanX() || this.isLoon()) && $done(t);
|
||||
}
|
||||
})(t, e);
|
||||
}
|
Loading…
Reference in New Issue
Block a user