Skip to content

Commit 0ff76b2

Browse files
committed
修正 RUN_AT 参数检测 bug
1 parent ecef84c commit 0ff76b2

File tree

3 files changed

+36
-29
lines changed

3 files changed

+36
-29
lines changed

app/Console/Cron.php

+5-1
Original file line numberDiff line numberDiff line change
@@ -41,6 +41,10 @@ public function verify()
4141
{
4242
$cronExp = get_argv('cron_exp');
4343

44-
echo preg_match('/^(?:\*(?:\/\d+)?|[0-5]?\d(?:,[0-5]?\d)*|[0-5]?\d-[0-5]?\d(?:\/\d+)?) (?:\*(?:\/\d+)?|(?:\d|0\d|1\d|2[0-3])(?:,(?:\d|0\d|1\d|2[0-3]))*|(?:\d|0\d|1\d|2[0-3])-(?:\d|0\d|1\d|2[0-3])(?:\/\d+)?) (?:\*(?:\/\d+)?|(?:0?[1-9]|1\d|2\d|3[0-1])(?:,(?:0?[1-9]|1\d|2\d|3[0-1]))*|(?:0?[1-9]|1\d|2\d|3[0-1])-(?:0?[1-9]|1\d|2\d|3[0-1])(?:\/\d+)?) (?:\*(?:\/\d+)?|(?:0?[1-9]|1[0-2])(?:,(?:0?[1-9]|1[0-2]))*|(?:0?[1-9]|1[0-2])-(?:0?[1-9]|1[0-2])(?:\/\d+)?|JAN|FEB|MAR|APR|MAY|JUN|JUL|AUG|SEP|OCT|NOV|DEC) (?:\*(?:\/\d+)?|0?[0-6](?:,0?[0-6])*|0?[0-6]-0?[0-6](?:\/\d+)?|SUN|MON|TUE|WED|THU|FRI|SAT)$/i', $cronExp);
44+
if (preg_match('/^(?:\*(?:\/\d+)?|[0-5]?\d(?:,[0-5]?\d)*|[0-5]?\d-[0-5]?\d(?:\/\d+)?) (?:\*(?:\/\d+)?|(?:\d|0\d|1\d|2[0-3])(?:,(?:\d|0\d|1\d|2[0-3]))*|(?:\d|0\d|1\d|2[0-3])-(?:\d|0\d|1\d|2[0-3])(?:\/\d+)?) (?:\*(?:\/\d+)?|(?:0?[1-9]|1\d|2\d|3[0-1])(?:,(?:0?[1-9]|1\d|2\d|3[0-1]))*|(?:0?[1-9]|1\d|2\d|3[0-1])-(?:0?[1-9]|1\d|2\d|3[0-1])(?:\/\d+)?) (?:\*(?:\/\d+)?|(?:0?[1-9]|1[0-2])(?:,(?:0?[1-9]|1[0-2]))*|(?:0?[1-9]|1[0-2])-(?:0?[1-9]|1[0-2])(?:\/\d+)?|JAN|FEB|MAR|APR|MAY|JUN|JUL|AUG|SEP|OCT|NOV|DEC) (?:\*(?:\/\d+)?|0?[0-6](?:,0?[0-6])*|0?[0-6]-0?[0-6](?:\/\d+)?|SUN|MON|TUE|WED|THU|FRI|SAT)$/i', $cronExp)) {
45+
exit(0);
46+
} else {
47+
exit(1);
48+
}
4549
}
4650
}

docker-entrypoint.sh

+15-14
Original file line numberDiff line numberDiff line change
@@ -5,8 +5,6 @@
55
# Intro: https://github.com/luolongfei/freenom #
66
#===================================================================#
77

8-
set -e
9-
108
# 自定义颜色变量
119
red='\033[0;31m'
1210
green='\033[0;32m'
@@ -26,33 +24,36 @@ PHP_COMMAND='/usr/local/bin/php /app/run > /app/logs/freenom_cron.log 2>&1'
2624

2725
# 指定脚本执行时间
2826
if [ -z "${RUN_AT}" ]; then
29-
minute=$( shuf -i 0-59 -n 1 )
30-
hour=$( shuf -i 6-23 -n 1 )
27+
minute=$(shuf -i 0-59 -n 1)
28+
hour=$(shuf -i 6-23 -n 1)
3129
CRON_COMMAND="${minute} ${hour} * * * ${PHP_COMMAND}"
3230
echo -e "[${green}Info${plain}] 已自动指定执行时间,续期任务将在北京时间每天 「${hour}:${minute}」 执行"
3331
echo -e "[${green}Info${plain}] 在没有手动指定 RUN_AT 环境变量的情况下,每次重启容器,程序都会重新在 06 ~ 23 点全时段中自动随机指定一个执行时间,目的是防止很多人在同一个时间点执行任务导致 Freenom 无法稳定提供服务"
3432
else
3533
if [[ "${RUN_AT}" =~ ^([01][0-9]|2[0-3]|[0-9]):([0-5][0-9]|[0-9])$ ]]; then
36-
minute=$( echo ${RUN_AT} | egrep -o '([0-5][0-9]|[0-9])$' )
37-
hour=$( echo ${RUN_AT} | egrep -o '^([01][0-9]|2[0-3]|[0-9])' )
34+
minute=$(echo ${RUN_AT} | egrep -o '([0-5][0-9]|[0-9])$')
35+
hour=$(echo ${RUN_AT} | egrep -o '^([01][0-9]|2[0-3]|[0-9])')
3836
CRON_COMMAND="${minute} ${hour} * * * ${PHP_COMMAND}"
3937
echo -e "[${green}Info${plain}] 你已指定执行时间,续期任务将在北京时间每天 「${hour}:${minute}」 执行"
40-
elif [ "$(php /app/run -c=Cron -m=verify --cron_exp="${RUN_AT}")" -eq 1 ]; then
41-
CRON_COMMAND="${RUN_AT} ${PHP_COMMAND}"
42-
echo -e "[${green}Info${plain}] 你自定义的 Cron 表达式为「${RUN_AT}」,已通过正则验证"
4338
else
44-
echo -e "[${red}Error${plain}] RUN_AT 的值无效"
45-
echo -e "${yellow}请输入一个有效的时间指令,其值可以为时分格式,如:11:24,也可以为 Cron 表达式,如:'24 11 * * *',甚至可以不输入,让程序自动生成,推荐采用自动生成的方式,不建议手动指定此环境变量"
46-
exit 1
39+
php /app/run -c=Cron -m=verify --cron_exp="${RUN_AT}"
40+
if [ $? -eq 0 ]; then
41+
CRON_COMMAND="${RUN_AT} ${PHP_COMMAND}"
42+
echo -e "[${green}Info${plain}] 你自定义的 Cron 表达式为「${RUN_AT}」,已通过正则验证"
43+
else
44+
echo -e "[${red}Error${plain}] RUN_AT 的值无效,你的输入为 ${RUN_AT}"
45+
echo -e "${yellow}请输入一个有效的时间指令,其值可以为时分格式,如:11:24,也可以为 Cron 表达式,如:'24 11 * * *',甚至可以不输入,让程序自动生成,推荐采用自动生成的方式,不建议手动指定此环境变量"
46+
exit 1
47+
fi
4748
fi
4849
fi
4950

5051
# 添加计划任务
5152
sed -i '/freenom_cron/'d /etc/crontabs/root
52-
echo -e "${CRON_COMMAND}" >> /etc/crontabs/root
53+
echo -e "${CRON_COMMAND}" >>/etc/crontabs/root
5354

5455
echo -e "[${green}Info${plain}] 计划任务:${CRON_COMMAND}"
5556

56-
php run
57+
php /app/run
5758

5859
exec "$@"

koyeb/startup.sh

+16-14
Original file line numberDiff line numberDiff line change
@@ -5,8 +5,6 @@
55
# Intro: https://github.com/luolongfei/freenom #
66
#===================================================================#
77

8-
set -e
9-
108
# 自定义颜色变量
119
red='\033[0;31m'
1210
green='\033[0;32m'
@@ -21,30 +19,33 @@ PHP_COMMAND='/usr/local/bin/php /app/run > /app/logs/freenom_cron.log 2>&1'
2119

2220
# 指定脚本执行时间
2321
if [ -z "${RUN_AT}" ]; then
24-
minute=$( shuf -i 0-59 -n 1 )
25-
hour=$( shuf -i 6-23 -n 1 )
22+
minute=$(shuf -i 0-59 -n 1)
23+
hour=$(shuf -i 6-23 -n 1)
2624
CRON_COMMAND="${minute} ${hour} * * * ${PHP_COMMAND}"
2725
echo -e "[${green}Info${plain}] 已自动指定执行时间,续期任务将在北京时间每天 「${hour}:${minute}」 执行"
2826
echo -e "[${green}Info${plain}] 在没有手动指定 RUN_AT 环境变量的情况下,每次重建容器,程序都会重新在 06 ~ 23 点全时段中自动随机指定一个执行时间,目的是防止很多人在同一个时间点执行任务导致 Freenom 无法稳定提供服务"
2927
else
3028
if [[ "${RUN_AT}" =~ ^([01][0-9]|2[0-3]|[0-9]):([0-5][0-9]|[0-9])$ ]]; then
31-
minute=$( echo ${RUN_AT} | egrep -o '([0-5][0-9]|[0-9])$' )
32-
hour=$( echo ${RUN_AT} | egrep -o '^([01][0-9]|2[0-3]|[0-9])' )
29+
minute=$(echo ${RUN_AT} | egrep -o '([0-5][0-9]|[0-9])$')
30+
hour=$(echo ${RUN_AT} | egrep -o '^([01][0-9]|2[0-3]|[0-9])')
3331
CRON_COMMAND="${minute} ${hour} * * * ${PHP_COMMAND}"
3432
echo -e "[${green}Info${plain}] 你已指定执行时间,续期任务将在北京时间每天 「${hour}:${minute}」 执行"
35-
elif [ "$(php /app/run -c=Cron -m=verify --cron_exp="${RUN_AT}")" -eq 1 ]; then
36-
CRON_COMMAND="${RUN_AT} ${PHP_COMMAND}"
37-
echo -e "[${green}Info${plain}] 你自定义的 Cron 表达式为「${RUN_AT}」,已通过正则验证"
3833
else
39-
echo -e "[${red}Error${plain}] RUN_AT 的值无效"
40-
echo -e "${yellow}请输入一个有效的时间指令,其值可以为时分格式,如:11:24,也可以为 Cron 表达式,如:'24 11 * * *',甚至可以不输入,让程序自动生成,推荐采用自动生成的方式,不建议手动指定此环境变量"
41-
exit 1
34+
php /app/run -c=Cron -m=verify --cron_exp="${RUN_AT}"
35+
if [ $? -eq 0 ]; then
36+
CRON_COMMAND="${RUN_AT} ${PHP_COMMAND}"
37+
echo -e "[${green}Info${plain}] 你自定义的 Cron 表达式为「${RUN_AT}」,已通过正则验证"
38+
else
39+
echo -e "[${red}Error${plain}] RUN_AT 的值无效,你的输入为 ${RUN_AT}"
40+
echo -e "${yellow}请输入一个有效的时间指令,其值可以为时分格式,如:11:24,也可以为 Cron 表达式,如:'24 11 * * *',甚至可以不输入,让程序自动生成,推荐采用自动生成的方式,不建议手动指定此环境变量"
41+
exit 1
42+
fi
4243
fi
4344
fi
4445

4546
# 添加计划任务
4647
sed -i '/freenom_cron/'d /etc/crontabs/root
47-
echo -e "${CRON_COMMAND}" >> /etc/crontabs/root
48+
echo -e "${CRON_COMMAND}" >>/etc/crontabs/root
4849
echo -e "[${green}Info${plain}] 计划任务:${CRON_COMMAND}"
4950

5051
# 启动 Cron
@@ -54,4 +55,5 @@ echo -e "[${green}Info${plain}] 计划任务:${CRON_COMMAND}"
5455
cp /app/nginx.template.conf /app/nginx.conf
5556

5657
# 启动 php-fpm 与 nginx
57-
php-fpm -D -R; nginx -c /app/nginx.conf -g 'daemon off;'
58+
php-fpm -D -R
59+
nginx -c /app/nginx.conf -g 'daemon off;'

0 commit comments

Comments
 (0)