JamesFlare1212
32dee6b161
fix(cache): resolve scanning stop issue and add cache TTL management
...
- Fix Redis SCAN cursor type conversion (Buffer to String) to prevent early termination
- Add progress logging in initializeClubCache (every 100 activities with summary)
- Add Redis memory limits (512MB with LRU eviction policy)
- Implement cache TTL: 24h for normal data, 1h for error states (allows retry)
- Fix Docker permission issue by running app container as root
- Add TTL configuration to .env and example.env
Root cause: SCAN cursor comparison failed due to type mismatch (Buffer vs String)
Impact: Scanning now processes all 5000+ IDs instead of stopping at ~300
2026-04-06 21:03:30 -04:00
JamesFlare1212
ee8cccc755
chore(docker): limit app container log size to 15MB with 3 file rotation
2026-04-06 18:47:31 -04:00
JamesFlare1212
02e0e6cafe
chore(docker): limit app container log size to 15MB with 3 file rotation
2026-04-06 18:45:20 -04:00
JamesFlare1212
0b9a42c7f3
fix(auth): add login lock to prevent concurrent Playwright login attempts
2026-04-06 18:25:52 -04:00
JamesFlare1212
480ba14688
fix(warp-proxy): host.docker.internal
2026-04-06 18:19:48 -04:00
JamesFlare1212
352e32d38b
test: 验证代理功能并完善文档
...
测试结果:
- ✅ Warp proxy 服务启动成功
- ✅ SOCKS5 代理工作正常 (warp=on)
- ✅ HTTP 代理工作正常
- ✅ Playwright + Proxy 集成成功
- ⚠️ 发现 DNS 解析问题,建议用 IP 地址
文档更新:
- PROXY-TESTING.md: 完整的测试报告和故障排除
- 包含测试脚本和最佳实践
2026-04-06 17:06:43 -04:00
JamesFlare1212
d0a0abed68
update: warp-proxy docker-compose.yaml
2026-04-06 16:43:10 -04:00
JamesFlare1212
4a97057825
feat: 添加可选的代理功能支持
...
新增功能:
- 集成 Cloudflare WARP socks5 代理服务
- 通过环境变量 USE_PROXY 控制代理开关
- 支持自定义 HTTP/HTTPS/SOCKS5 代理服务器
- 使用 docker compose profile 管理 proxy 服务
配置方式:
- USE_PROXY=true 启用代理
- ALL_PROXY/HTTP_PROXY/HTTPS_PROXY 自定义代理
- docker compose --profile proxy up 启动 warp 服务
文件变更:
- docker-compose.yaml: 添加 warp-proxy 服务
- playwright-auth.ts: 添加代理配置逻辑
- example.env: 添加代理环境变量
- PROXY.md: 使用文档
2026-04-06 16:37:54 -04:00
JamesFlare1212
4e04063469
fix: 将 playwright 移到 production dependencies
...
问题:Docker 构建时使用 --production 标志,导致 playwright
无法找到
修复:将 @playwright/test 从 devDependencies 移到 dependencies
2026-04-06 16:18:27 -04:00
JamesFlare1212
a21806dfca
remove: playwright-report
2026-04-06 16:10:15 -04:00
JamesFlare1212
a8f468a497
feat: 使用 Playwright 实现自动化 cookie 获取和验证
...
主要变更:
- 新增 Playwright 登录认证服务 (services/playwright-auth.ts)
- 重构 get-activity.ts 使用 Playwright 替代 Axios 登录
- 实现自动 cookie 过期检测和重试机制
- 优化 Docker 配置支持 Playwright 浏览器运行
- 添加启动脚本自动验证和刷新 cookies
- 完善错误处理:区分 4xx(认证失败) 和 5xx(服务器错误)
技术细节:
- 删除旧版 login_template.txt 和 nkcs-engage.cookie.txt
- 添加 startup.sh 启动时自动验证 cookies
- 改进 cookie 验证逻辑,添加指数退避重试
- Dockerfile 安装 Playwright 系统依赖
- docker-compose.yaml 添加 volumes 和 health checks
测试:
- 添加 auth.spec.ts 自动化测试
- 添加 get-cookies.ts 和 test-cookies-validity.ts 工具脚本
- 验证 401/500/000 等错误场景处理正确
2026-04-06 16:05:38 -04:00
JamesFlare1212
b18b8a85e0
feat new s3 public url option
2026-03-15 19:40:59 -04:00
JamesFlare1212
cb7f99dc09
update engage login template
2025-12-09 19:31:32 +08:00
6ae25329e9
Update engage-api/login_template.txt
2025-08-29 09:48:08 +02:00
JamesFlare1212
bd11e5971c
improve: rank academicYear in descending order
2025-05-14 15:09:17 -04:00
JamesFlare1212
d81078c62d
feat: endpoint /v1/activity/list?isStudentLed={true/false}
2025-05-14 00:30:43 -04:00
JamesFlare1212
2db16d5e80
update: redis 8.0
2025-05-13 23:24:09 -04:00
JamesFlare1212
7ba5f8f00f
feat: skip duplicate image on remote
2025-05-12 23:46:25 -04:00
JamesFlare1212
8598571f72
improve: code structure
2025-05-12 21:45:57 -04:00
JamesFlare1212
2100bd04ca
improve: semesterCost and poorWeatherPlan format
2025-05-12 20:37:26 -04:00
JamesFlare1212
8136c76d46
feat: convert image into .avif
2025-05-12 18:41:15 -04:00
JamesFlare1212
1996b1e29c
feat: new filters on /v1/activity/list
2025-05-12 16:32:56 -04:00
JamesFlare1212
1d1d82fa60
feat: new api endpoint, /v1/activity/category and /v1/activity/academicYear
2025-05-12 01:38:25 -04:00
JamesFlare1212
2543e56ec4
init: port to typescript and bun
2025-05-10 23:39:39 -04:00