Przeglądaj źródła

Merge branch 'dev'

luolongfei 3 lat temu
rodzic
commit
0f29130713
5 zmienionych plików z 38 dodań i 31 usunięć
  1. 1 1
      README.md
  2. 1 1
      README_EN.md
  3. 5 1
      app/Console/Cron.php
  4. 15 14
      docker-entrypoint.sh
  5. 16 14
      koyeb/startup.sh

+ 1 - 1
README.md

@@ -61,7 +61,7 @@ Documentation: [English version](https://github.com/luolongfei/freenom/blob/main
 - 本次封禁导致的直接后果是以前的`issues`全部丢失,以及近`1.8k`的`star`数重新归零,在动力上面确实有受到影响,不过也不会有太大影响,本项目依然长期维护,如果项目有帮到你,欢迎 star。
 - 狡兔三窟,临时仓库 https://github.com/luolongfei/next-freenom 也是备用仓库,如若本仓库再次失联,可以移步到备用仓库获取最新消息,正常情况下以后的开发维护依然在本仓库进行。
 - 推荐 [🐳 通过 Docker 方式部署](#-通过-docker-部署)。如果你没有自己的服务器,可参考本文档 [📦 通过 Koyeb 部署](#-通过-Koyeb-部署) 。
-- 热心网友创建了`Freenom 续期事务局`群组,可供交流、测试、反馈,加入可直接访问 [https://t.me/freenom_auto_renew](https://t.me/freenom_auto_renew) ,或者扫码加入:
+- 热心网友创建了`Freenom 续期事务局`群组,可供交流、测试、反馈, **加入可直接访问 [https://t.me/freenom_auto_renew](https://t.me/freenom_auto_renew) ,或者扫码加入:**
 
 <a href="https://s1.ax1x.com/2022/08/29/vfEpi8.png"><img src="https://s1.ax1x.com/2022/08/29/vfEpi8.png" alt="freenom_tg_group.png" border="0" width="220px" height="280px" /></a>
 

+ 1 - 1
README_EN.md

@@ -56,7 +56,7 @@ Thanks for non-commercial open source development authorization by JetBrains.
 
 Whether the renewal is successful or unsuccessful or the script executes with an error, you will receive a notification from the script. In case of renewal success or failure related notifications, the notification will include the number of days to expiration for the unrenewed domain name, etc. *The content of the notification email is shown here.*
 
-<a href="https://s4.ax1x.com/2022/02/26/bZrtz9.png"><img src="https://s4.ax1x.com/2022/02/26/bZrtz9.png" alt="Example of notification email" border="0" width="670" height="540" /></a>
+<a href="https://s4.ax1x.com/2022/02/26/bZrtz9.png"><img src="https://s4.ax1x.com/2022/02/26/bZrtz9.png" alt="Example of notification email" border="0" width="95%" height="100%" /></a>
 
 ### 🎁 Preparation
 

+ 5 - 1
app/Console/Cron.php

@@ -41,6 +41,10 @@ class Cron extends Base
     {
         $cronExp = get_argv('cron_exp');
 
-        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);
+        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)) {
+            exit(0);
+        } else {
+            exit(1);
+        }
     }
 }

+ 15 - 14
docker-entrypoint.sh

@@ -5,8 +5,6 @@
 #   Intro: https://github.com/luolongfei/freenom                    #
 #===================================================================#
 
-set -e
-
 # 自定义颜色变量
 red='\033[0;31m'
 green='\033[0;32m'
@@ -26,33 +24,36 @@ PHP_COMMAND='/usr/local/bin/php /app/run > /app/logs/freenom_cron.log 2>&1'
 
 # 指定脚本执行时间
 if [ -z "${RUN_AT}" ]; then
-    minute=$( shuf -i 0-59 -n 1 )
-    hour=$( shuf -i 6-23 -n 1 )
+    minute=$(shuf -i 0-59 -n 1)
+    hour=$(shuf -i 6-23 -n 1)
     CRON_COMMAND="${minute} ${hour} * * * ${PHP_COMMAND}"
     echo -e "[${green}Info${plain}] 已自动指定执行时间,续期任务将在北京时间每天 「${hour}:${minute}」 执行"
     echo -e "[${green}Info${plain}] 在没有手动指定 RUN_AT 环境变量的情况下,每次重启容器,程序都会重新在 06 ~ 23 点全时段中自动随机指定一个执行时间,目的是防止很多人在同一个时间点执行任务导致 Freenom 无法稳定提供服务"
 else
     if [[ "${RUN_AT}" =~ ^([01][0-9]|2[0-3]|[0-9]):([0-5][0-9]|[0-9])$ ]]; then
-        minute=$( echo ${RUN_AT} | egrep -o '([0-5][0-9]|[0-9])$' )
-        hour=$( echo ${RUN_AT} | egrep -o '^([01][0-9]|2[0-3]|[0-9])' )
+        minute=$(echo ${RUN_AT} | egrep -o '([0-5][0-9]|[0-9])$')
+        hour=$(echo ${RUN_AT} | egrep -o '^([01][0-9]|2[0-3]|[0-9])')
         CRON_COMMAND="${minute} ${hour} * * * ${PHP_COMMAND}"
         echo -e "[${green}Info${plain}] 你已指定执行时间,续期任务将在北京时间每天 「${hour}:${minute}」 执行"
-    elif [ "$(php /app/run -c=Cron -m=verify --cron_exp="${RUN_AT}")" -eq 1 ]; then
-        CRON_COMMAND="${RUN_AT} ${PHP_COMMAND}"
-        echo -e "[${green}Info${plain}] 你自定义的 Cron 表达式为「${RUN_AT}」,已通过正则验证"
     else
-        echo -e "[${red}Error${plain}] RUN_AT 的值无效"
-        echo -e "${yellow}请输入一个有效的时间指令,其值可以为时分格式,如:11:24,也可以为 Cron 表达式,如:'24 11 * * *',甚至可以不输入,让程序自动生成,推荐采用自动生成的方式,不建议手动指定此环境变量"
-        exit 1
+        php /app/run -c=Cron -m=verify --cron_exp="${RUN_AT}"
+        if [ $? -eq 0 ]; then
+            CRON_COMMAND="${RUN_AT} ${PHP_COMMAND}"
+            echo -e "[${green}Info${plain}] 你自定义的 Cron 表达式为「${RUN_AT}」,已通过正则验证"
+        else
+            echo -e "[${red}Error${plain}] RUN_AT 的值无效,你的输入为 ${RUN_AT}"
+            echo -e "${yellow}请输入一个有效的时间指令,其值可以为时分格式,如:11:24,也可以为 Cron 表达式,如:'24 11 * * *',甚至可以不输入,让程序自动生成,推荐采用自动生成的方式,不建议手动指定此环境变量"
+            exit 1
+        fi
     fi
 fi
 
 # 添加计划任务
 sed -i '/freenom_cron/'d /etc/crontabs/root
-echo -e "${CRON_COMMAND}" >> /etc/crontabs/root
+echo -e "${CRON_COMMAND}" >>/etc/crontabs/root
 
 echo -e "[${green}Info${plain}] 计划任务:${CRON_COMMAND}"
 
-php run
+php /app/run
 
 exec "$@"

+ 16 - 14
koyeb/startup.sh

@@ -5,8 +5,6 @@
 #   Intro: https://github.com/luolongfei/freenom                    #
 #===================================================================#
 
-set -e
-
 # 自定义颜色变量
 red='\033[0;31m'
 green='\033[0;32m'
@@ -21,30 +19,33 @@ PHP_COMMAND='/usr/local/bin/php /app/run > /app/logs/freenom_cron.log 2>&1'
 
 # 指定脚本执行时间
 if [ -z "${RUN_AT}" ]; then
-    minute=$( shuf -i 0-59 -n 1 )
-    hour=$( shuf -i 6-23 -n 1 )
+    minute=$(shuf -i 0-59 -n 1)
+    hour=$(shuf -i 6-23 -n 1)
     CRON_COMMAND="${minute} ${hour} * * * ${PHP_COMMAND}"
     echo -e "[${green}Info${plain}] 已自动指定执行时间,续期任务将在北京时间每天 「${hour}:${minute}」 执行"
     echo -e "[${green}Info${plain}] 在没有手动指定 RUN_AT 环境变量的情况下,每次重建容器,程序都会重新在 06 ~ 23 点全时段中自动随机指定一个执行时间,目的是防止很多人在同一个时间点执行任务导致 Freenom 无法稳定提供服务"
 else
     if [[ "${RUN_AT}" =~ ^([01][0-9]|2[0-3]|[0-9]):([0-5][0-9]|[0-9])$ ]]; then
-        minute=$( echo ${RUN_AT} | egrep -o '([0-5][0-9]|[0-9])$' )
-        hour=$( echo ${RUN_AT} | egrep -o '^([01][0-9]|2[0-3]|[0-9])' )
+        minute=$(echo ${RUN_AT} | egrep -o '([0-5][0-9]|[0-9])$')
+        hour=$(echo ${RUN_AT} | egrep -o '^([01][0-9]|2[0-3]|[0-9])')
         CRON_COMMAND="${minute} ${hour} * * * ${PHP_COMMAND}"
         echo -e "[${green}Info${plain}] 你已指定执行时间,续期任务将在北京时间每天 「${hour}:${minute}」 执行"
-    elif [ "$(php /app/run -c=Cron -m=verify --cron_exp="${RUN_AT}")" -eq 1 ]; then
-        CRON_COMMAND="${RUN_AT} ${PHP_COMMAND}"
-        echo -e "[${green}Info${plain}] 你自定义的 Cron 表达式为「${RUN_AT}」,已通过正则验证"
     else
-        echo -e "[${red}Error${plain}] RUN_AT 的值无效"
-        echo -e "${yellow}请输入一个有效的时间指令,其值可以为时分格式,如:11:24,也可以为 Cron 表达式,如:'24 11 * * *',甚至可以不输入,让程序自动生成,推荐采用自动生成的方式,不建议手动指定此环境变量"
-        exit 1
+        php /app/run -c=Cron -m=verify --cron_exp="${RUN_AT}"
+        if [ $? -eq 0 ]; then
+            CRON_COMMAND="${RUN_AT} ${PHP_COMMAND}"
+            echo -e "[${green}Info${plain}] 你自定义的 Cron 表达式为「${RUN_AT}」,已通过正则验证"
+        else
+            echo -e "[${red}Error${plain}] RUN_AT 的值无效,你的输入为 ${RUN_AT}"
+            echo -e "${yellow}请输入一个有效的时间指令,其值可以为时分格式,如:11:24,也可以为 Cron 表达式,如:'24 11 * * *',甚至可以不输入,让程序自动生成,推荐采用自动生成的方式,不建议手动指定此环境变量"
+            exit 1
+        fi
     fi
 fi
 
 # 添加计划任务
 sed -i '/freenom_cron/'d /etc/crontabs/root
-echo -e "${CRON_COMMAND}" >> /etc/crontabs/root
+echo -e "${CRON_COMMAND}" >>/etc/crontabs/root
 echo -e "[${green}Info${plain}] 计划任务:${CRON_COMMAND}"
 
 # 启动 Cron
@@ -54,4 +55,5 @@ echo -e "[${green}Info${plain}] 计划任务:${CRON_COMMAND}"
 cp /app/nginx.template.conf /app/nginx.conf
 
 # 启动 php-fpm 与 nginx
-php-fpm -D -R; nginx -c /app/nginx.conf -g 'daemon off;'
+php-fpm -D -R
+nginx -c /app/nginx.conf -g 'daemon off;'