更新基于1panel的多吉云证书同步

This commit is contained in:
Akatsuki-Misaki 2025-01-24 17:24:07 +08:00
parent 70f8ad025a
commit a2a586063e
3 changed files with 181 additions and 2 deletions

View File

@ -0,0 +1,11 @@
<div align="center">
<img height="100px" alt="logo" src="https://img-bohe.lolicon.team/i/img/svg/logo.ico"/>
<p><em>🗂OVOFISH STUDIO</em></p>
# 说明
这是一个自动化脚本更新
```
pip install requests
```

View File

@ -0,0 +1,168 @@
# 该脚本适合使用通配符进行证书绑定
# 作者Akatsuki-Misaki
# 引入模块
import re
from hashlib import sha1
import hmac
import requests
import json
import urllib
import datetime
# 引入模块结束
# 默认数值填写
# 需要匹配的域名
defCDNdomain = 'example.com'
# 是否使用二级域名 *.example.com
UseSubDomain = True
# 是否使用三级域名 *.*.example.com
UseThirdDomain = False
# 单域名绑定
UseONEDomain = False
# 证书文件路径 绝对路径
SSLFilePath = '/1panel/SSL_Save/full_example_com/'
# 证书文件名
SSL_fullchainName = 'fullchain.pem'
# 证书密钥文件名
SSL_privName = 'privkey.pem'
#默认数值填写结束
# 获取当前日期
nowtime = datetime.datetime.now().strftime('%Y-%m-%d')
# 引入函数模块
def dogecloud_api(api_path, data={}, json_mode=False):
# 这里替换为你的多吉云永久 AccessKey 和 SecretKey可在用户中心 - 密钥管理中查看
# 请勿在客户端暴露 AccessKey 和 SecretKey否则恶意用户将获得账号完全控制权
access_key = 'aaaaaaaaaaaaaaaaa'
secret_key = 'aaaaaaaaaaaaaaaaa'
body = ''
mime = ''
if json_mode:
body = json.dumps(data)
mime = 'application/json'
else:
body = urllib.parse.urlencode(data) # Python 2 可以直接用 urllib.urlencode
mime = 'application/x-www-form-urlencoded'
sign_str = api_path + "\n" + body
signed_data = hmac.new(secret_key.encode('utf-8'), sign_str.encode('utf-8'), sha1)
sign = signed_data.digest().hex()
authorization = 'TOKEN ' + access_key + ':' + sign
response = requests.post('https://api.dogecloud.com' + api_path, data=body, headers = {
'Authorization': authorization,
'Content-Type': mime
})
return response.json()
def SSL_OLD_NEW_JSON():
# 从old_id.json中读取id并删除证书 并且确认是否删除成功
with open('old_id.json') as f:
old_id = json.load(f)['id']
api = dogecloud_api('/cdn/cert/delete.json', {'id': old_id})
if api['code'] == 200:
print("脚本:删除证书成功"+"(证书ID: " + str(old_id)+")")
else:
print("脚本:删除证书失败"+"(证书ID: " + str(old_id)+")")
# 删除旧ID证书后将新证书ID保存到old_id.json中 用于下次删除
with open('old_id.json', 'w') as f:
json.dump({'id': ssl_id}, f)
print("证书已保存到old_id.json中")
print("证书ID: " + str(ssl_id))
# 证书绑定域名
def SSL_BIND_DOMAIN(defCDNdomain,ssl_id):
print("域名进行证书绑定")
api = dogecloud_api('/cdn/domain/list.json')
print("传递参数:"+ defCDNdomain)
print("传递参数:"+ str(ssl_id))
# 将defCDNdomain拆分为前后
parts = defCDNdomain.split('.')
if len(parts) == 2: # 确保域名只包含一个点号
defCDNprefix, defCDNsuffix = parts
# 如果使用二级域名
if UseSubDomain:
print("使用二级域名匹配规则")
pattern = r'^([^.]+\.)?' + re.escape(defCDNprefix) + '\.' + re.escape(defCDNsuffix) + '$'
print("正则表达式1"+pattern)
elif UseThirdDomain:
print("使用三级域名匹配规则")
pattern = r'^([^.]+\.){1}' + re.escape(defCDNprefix) + '\.' + re.escape(defCDNsuffix) + '$'
print("正则表达式1"+pattern)
elif UseONEDomain:
print("使用单域名精准匹配规则")
pattern = r'^' + re.escape(defCDNdomain) + '$'
print("正则表达式1"+pattern)
else:
print("未启用任何域名匹配规则")
else:
print("域名格式不正确,创建正则表达式失败")
try:
for domain in api['data']['domains']:
# 仅此匹配*.example.com不匹配*.*.example.com
if re.match (pattern,domain['name']):
print("正则表达式2"+pattern)
print("找到匹配的域名:"+ domain['name'])
cdndomain = domain['name']
print("证书ID:"+ str(ssl_id))
# api = dogecloud_api('/cdn/domain/config.json?domain=' + cdndomain, {'cert_id': ssl_id})
api = dogecloud_api('/cdn/domain/config.json?domain='+ cdndomain, {'cert_id': ssl_id}, True)
print(api)
if api['code'] == 200:
print("脚本:证书绑定成功("+ domain['name']+")")
else:
print("脚本:证书绑定失败("+ domain['name']+")")
else:
print("未匹配的域名:"+ domain['name'])
except Exception as e:
print("域名正则表达式创建失败")
# 引入函数模块结束
# 主程序
__name__ == '__main__'
print("开始执行证书更新")
# 下面两个函数用于读取证书文件 若要修改请到上面的默认数值修改
with open(SSLFilePath+SSL_fullchainName) as fullchain:
full = fullchain.read()
with open(SSLFilePath+SSL_privName) as privkey:
priv = privkey.read()
api = dogecloud_api('/cdn/cert/upload.json', {
"note": f"自动证书"+nowtime,
"cert": full,
"private": priv
})
if api['code'] == 200:
ssl_id = api['data']['id']
print("api success: " + api['msg'])
print("证书ID: " + str(ssl_id))
# 域名绑定证书
SSL_BIND_DOMAIN(defCDNdomain,ssl_id)
else:
print("api failed: " + api['msg']) # 失敗
# 退出脚本
print("因为域名证书上传失败,脚本已退出")
exit()
# 查询是否具有old_id.json
# 如果有则运行SSL_OLD_NEW_JSON
try:
with open('old_id.json') as f:
SSL_OLD_NEW_JSON()
print("已执行删除操作")
except FileNotFoundError:
print("没有找到old_id.json文件无法执行删除操作")
# 新增old_id.json文件
with open('old_id.json', 'w') as f:
json.dump({'id': ssl_id}, f)
print("已创建新的old_id.json文件")
exit()
print("证书更新已完成")
print("主程序已结束")

View File

@ -25,11 +25,11 @@ def continuous_ping(ip_addresses):
# print(f'Ping delay to {location} ({ip_address}): {delay * 1000:.2f} ms')
delay = int(delay * 1000)
else:
print(f'{time.strftime("%Y-%m-%d %H:%M:%S")}Ping to {location} ({ip_address}) failed.')
print(f'{time.strftime("%Y-%m-%d %H:%M:%S")} Ping to {location} ({ip_address}) failed.')
delay = 0 # 或者设定其他默认值
if delay is not None and delay > threshold_ms:
log_message = f'High latency detected for {location} ({ip_address})! Delay: {delay}ms'
print(f'{time.strftime("%Y-%m-%d %H:%M:%S")} Ping delay to {location} ({ip_address}): {delay * 1000:.2f} ms')
if log_method == "file":
try:
with open(f'{location}_ping_log.txt', 'a', encoding="utf-8") as log_file: