4.8 KiB
4.8 KiB
E5SubBot
A Simple Telebot for E5 Renewal
Golang + MySQL
DEMO: https://t.me/E5Sub_bot
特性
- 自动续订E5订阅(可自定义的调用频率)
- 可管理的简易账户系统
- 完善的任务执行反馈
- 极为方便的授权方式
- 使用并发加快运行速度
原理
E5订阅为开发者订阅,只要调用相关API就有可能续期
调用 Outlook ReadMail API 实现玄学的续订方式,不保证续订效果。
使用方法
- 在机器人对话框输入 /bind
- 注册应用,使用E5主账号或同域账号登录,跳转页面获得client_secret。点击回到快速启动,获得client_id
- 复制client_secret和client_id,以
client_id client_secret格式回复 - 获得授权链接,使用E5主账号或同域账号登录
- 授权后会跳转至
http://localhost/e5sub……(会提示网页错误,复制链接即可) - 复制整个浏览框内容,在机器人对话框回复
链接+空格+别名(用于管理账户)例如:http://localhost/e5sub/?code=abcd MyE5,等待机器人绑定后即完成
自行部署
Bot创建教程:Google
Docker部署
感谢 @kzw200015 提供Dockerfile以及Docker方面的帮助
第一次启动不行,使用 docker-compose restart重启一次
mkdir ./e5bot && wget --no-check-certificate -O ./e5bot/config.yml https://raw.githubusercontent.com/iyear/E5SubBot/master/config.yml.example
vi ./e5bot/config.yml
wget --no-check-certificate https://raw.githubusercontent.com/iyear/E5SubBot/master/docker-compose.yml
docker-compose up -d
二进制文件
在Releases页面下载对应系统的二进制文件,上传至服务器
Windows: 启动 E5SubBot.exe
Linux:
screen -S e5sub
chmod +x E5SubBot
./E5SubBot
(Ctrl A+D)
编译
下载源码,安装GO环境
git clone https://github.com/iyear/E5SubBot.git && cd E5SubBot && go build
部署配置
在同目录下创建config.yml,编码为UTF-8
配置模板:
bot_token: YOUR_BOT_TOKEN
socks5: 127.0.0.1:1080
notice: "第一行\n第二行"
admin: 66666,77777,88888
goroutine: 10
errlimit: 5
cron: "1 */3 * * *"
bindmax: 3
mysql:
host: 127.0.0.1
port: 3306
user: e5sub
password: e5sub
database: e5sub
table: users
bindmax,notice,admin,goroutine,errlimit可热更新,直接更新config.yml保存即可
| 配置项 | 说明 | 默认值 |
|---|---|---|
| bot_token | 更换为自己的BotToken |
- |
| socks5 | Socks5代理,不需要删去即可.例如:127.0.0.1:1080 |
- |
| notice | 公告.合并至/help |
- |
| admin | 管理员tgid,前往 https://t.me/userinfobot 获取,用,隔开;管理员权限: 手动调用任务,获得任务总反馈 |
- |
| goroutine | 并发数,不要过大 | 10 |
| errlimit | 单账户最大出错次数,满后自动解绑单账户并发送通知,不限制错误次数将值改为负数(-1)即可;bot重启后会清零所有错误次数 |
5 |
| cron | API调用频率,使用cron表达式 | - |
| bindmax | 最大可绑定数 | 5 |
| mysql | mysql配置,请提前创建数据库(旧版本升级请设置table为users,否则读不到数据表) | - |
命令
/my 查看已绑定账户信息
/bind 绑定新账户
/unbind 解绑账户
/export 导出账户信息(JSON格式)
/help 帮助
/task 手动执行一次任务(Bot管理员)
/log 获取最近日志文件(Bot管理员)
注意事项
更新时间与北京时间不符
更改服务器时区为Asia/Shanghai,然后使用/task手动执行一次任务刷新时间
绑定格式错误
不要带"+"号
错误:Can't create more than max_prepared_stmt_count statements (current value: 16382)
没有关闭db导致触发mysql并发上限,请更新至v0.1.9
长时间运行崩溃
疑似内存泄露,尚未解决,请自行采用守护进程运行或定时重启Bot
无法通过Bot创建应用程序
更多功能
如果你还想支持新的特性,请发起issue.
做出贡献
- 提供其他语言的文档
- 为代码运行提供帮助
- 对用户交互提出建议
- ……
License
GPLv3