fix: enum 写入 PG 用 value 而非 name

Source/SourceKind、UserRole、SubscriptionMatch 三个 enum 改用 values_callable
保证 PG 看到 'rss' / 'owner' / 'any' 等小写 value,而非 'RSS' 大写 name。
seed_sources 同步改为显式字符串。
This commit is contained in:
Mavis
2026-06-07 23:11:32 +08:00
parent 427e1f5cf2
commit 6635b8fea8
5 changed files with 37 additions and 23 deletions

View File

@@ -1,23 +1,24 @@
import os, paramiko
HOST, PORT, USER = "207.57.129.228", 19717, "root"
PW = os.environ["REMOTE_PASS"]
c = paramiko.SSHClient()
c.set_missing_host_key_policy(paramiko.AutoAddPolicy())
c.connect(HOST, port=PORT, username=USER, password=PW, timeout=15, allow_agent=False, look_for_keys=False)
c.connect("207.57.129.228", port=19717, username="root", password=PW, timeout=15, allow_agent=False, look_for_keys=False)
# 1) 推更新后的部署脚本
sftp = c.open_sftp()
sftp.put("D:/selftools/diary-news/scripts/deploy_remote.sh", "/root/deploy_news.sh")
sftp.chmod("/root/deploy_news.sh", 0o755)
sftp.close()
print("[ok] script pushed")
def run(cmd, t=30):
si, so, se = c.exec_command(cmd, timeout=t)
out = so.read().decode("utf-8", "replace")
err = se.read().decode("utf-8", "replace")
rc = so.channel.recv_exit_status()
print(f"$ {cmd}")
if out: print(out, end="")
if err: print("[err]", err, end="", file=__import__("sys").stderr)
print(f" rc={rc}")
# 2) 杀掉旧进程(若有)
si, so, se = c.exec_command("pkill -f deploy_news.sh 2>/dev/null; sleep 2; echo done")
print(so.read().decode().strip())
# 1) 服务器 git pull
run("cd /srv/news && sudo -u news git pull --rebase 2>&1 | tail -10")
# 3) 后台启动,设 SSHD_PORT=19717
# 2) 重跑部署脚本(直接重跑,前面的 docker 镜像已构建缓存)
run("pkill -f deploy_news.sh 2>/dev/null; sleep 2; rm -f /root/deploy_news.log; echo ===restart===")
si, so, se = c.exec_command("nohup env SSHD_PORT=19717 bash /root/deploy_news.sh > /root/deploy_news.log 2>&1 & echo $!", timeout=10)
pid = so.read().decode().strip()
print(f"[ok] deploy started, PID={pid}")
print(f"deploy started, PID={so.read().decode().strip()}")
c.close()