E5BotForSQLite/handle.go

234 lines
6.0 KiB
Go
Raw Normal View History

2020-03-27 11:36:29 +08:00
package main
2020-03-27 23:02:28 +08:00
import (
2020-04-07 10:56:45 +08:00
"fmt"
"github.com/fsnotify/fsnotify"
2020-03-27 23:02:28 +08:00
"github.com/spf13/viper"
tb "gopkg.in/tucnak/telebot.v2"
2020-04-07 10:56:45 +08:00
"path/filepath"
2020-03-27 23:02:28 +08:00
"strconv"
2020-03-30 22:18:09 +08:00
"strings"
2020-03-29 12:07:15 +08:00
"time"
2020-03-27 23:02:28 +08:00
)
2020-03-27 11:36:29 +08:00
2020-03-27 23:02:28 +08:00
const (
2020-04-07 10:56:45 +08:00
bLogBasePath string = "./log/"
bStartContent string = "欢迎使用E5SubBot!"
2020-03-29 12:51:39 +08:00
bHelpContent string = `
命令
/my 查看已绑定账户信息
/bind 绑定新账户
/unbind 解绑账户
/help 帮助
2020-04-02 09:43:42 +08:00
/task 手动执行一次任务(管理员)
2020-04-07 10:56:45 +08:00
/log 获取log文件(管理员)
源码及使用方法https://github.com/iyear/E5SubBot
2020-03-29 12:51:39 +08:00
`
2020-03-27 23:02:28 +08:00
)
var (
2020-03-30 22:18:09 +08:00
UserStatus map[int64]int
UserCid map[int64]string
UserCSecret map[int64]string
BindMaxNum int
notice string
2020-04-02 09:43:42 +08:00
admin []int64
2020-03-27 23:02:28 +08:00
)
const (
USNone = iota
2020-03-30 22:18:09 +08:00
USBind1
USBind2
2020-03-27 23:02:28 +08:00
)
func init() {
//read config
viper.SetConfigName("config")
viper.AddConfigPath(".")
err := viper.ReadInConfig()
CheckErr(err)
BindMaxNum = viper.GetInt("bindmax")
notice = viper.GetString("notice")
2020-04-02 09:43:42 +08:00
admin = GetAdmin()
viper.WatchConfig()
viper.OnConfigChange(func(e fsnotify.Event) {
BindMaxNum = viper.GetInt("bindmax")
notice = viper.GetString("notice")
2020-04-02 09:43:42 +08:00
admin = GetAdmin()
})
2020-03-27 23:02:28 +08:00
UserStatus = make(map[int64]int)
2020-03-30 22:18:09 +08:00
UserCid = make(map[int64]string)
UserCSecret = make(map[int64]string)
2020-03-27 23:02:28 +08:00
}
2020-04-04 13:05:41 +08:00
2020-03-27 11:36:29 +08:00
func bStart(m *tb.Message) {
2020-03-27 23:02:28 +08:00
bot.Send(m.Sender, bStartContent)
bHelp(m)
2020-03-27 23:02:28 +08:00
}
2020-04-07 10:56:45 +08:00
2020-03-27 23:02:28 +08:00
func bMy(m *tb.Message) {
2020-03-28 11:20:45 +08:00
data := QueryDataByTG(db, m.Chat.ID)
var inlineKeys [][]tb.InlineButton
2020-03-27 23:02:28 +08:00
for _, u := range data {
inlineBtn := tb.InlineButton{
Unique: "my" + u.msId,
2020-03-30 22:18:09 +08:00
Text: u.alias,
2020-03-28 11:20:45 +08:00
Data: u.msId,
2020-03-27 23:02:28 +08:00
}
2020-03-28 11:20:45 +08:00
bot.Handle(&inlineBtn, bMyInlineBtn)
2020-03-27 23:02:28 +08:00
inlineKeys = append(inlineKeys, []tb.InlineButton{inlineBtn})
}
2020-03-29 12:51:39 +08:00
bot.Send(m.Chat, "选择一个账户查看具体信息\n\n绑定数: "+strconv.Itoa(GetBindNum(m.Chat.ID))+"/"+strconv.Itoa(BindMaxNum), &tb.ReplyMarkup{InlineKeyboard: inlineKeys})
2020-03-27 23:02:28 +08:00
}
2020-03-28 11:20:45 +08:00
func bMyInlineBtn(c *tb.Callback) {
r := QueryDataByMS(db, c.Data)
u := r[0]
2020-03-30 22:18:09 +08:00
bot.Send(c.Message.Chat, "信息\n别名"+u.alias+"\nMS_ID(MD5): "+u.msId+"\nclient_id: "+u.clientId+"\n最近更新时间: "+time.Unix(u.uptime, 0).Format("2006-01-02 15:04:05"))
2020-03-27 23:02:28 +08:00
bot.Respond(c)
}
2020-04-07 10:56:45 +08:00
func bLog(m *tb.Message) {
flag := 0
for _, a := range admin {
if a == m.Chat.ID {
flag = 1
}
}
if flag == 0 {
bot.Send(m.Chat, "您没有权限执行此操作~")
return
}
logs := GetRecentLogs(bLogBasePath, 5)
var inlineKeys [][]tb.InlineButton
for _, log := range logs {
inlineBtn := tb.InlineButton{
Unique: "log" + strings.Replace(strings.TrimSuffix(filepath.Base(log), ".log"), "-", "", -1),
Text: filepath.Base(log),
Data: filepath.Base(log),
}
bot.Handle(&inlineBtn, bLogsInlineBtn)
inlineKeys = append(inlineKeys, []tb.InlineButton{inlineBtn})
}
_, err := bot.Send(m.Chat, "选择一个日志", &tb.ReplyMarkup{InlineKeyboard: inlineKeys})
fmt.Println(err)
}
func bLogsInlineBtn(c *tb.Callback) {
//fmt.Println(c.Data)
//logger.Println(bLogBasePath + c.Data + ".log")
logfile := &tb.Document{File: tb.FromDisk(bLogBasePath + c.Data), FileName: c.Data, MIME: "text/plain"}
_, err := bot.Send(c.Message.Chat, logfile)
if err != nil {
logger.Println(err)
return
}
bot.Respond(c)
}
2020-03-30 22:18:09 +08:00
func bBind1(m *tb.Message) {
2020-04-03 13:19:53 +08:00
logger.Println("ReApp: " + strconv.FormatInt(m.Chat.ID, 10))
2020-03-30 22:18:09 +08:00
bot.Send(m.Chat, "应用注册: [点击直达]("+MSGetReAppUrl()+")", tb.ModeMarkdown)
_, err := bot.Send(m.Chat, "请回复client_id+空格+client_secret", &tb.ReplyMarkup{ForceReply: true})
2020-03-27 23:02:28 +08:00
if err == nil {
2020-03-30 22:18:09 +08:00
UserStatus[m.Chat.ID] = USBind1
UserCid[m.Chat.ID] = m.Text
2020-03-27 23:02:28 +08:00
}
}
2020-03-30 22:18:09 +08:00
func bBind2(m *tb.Message) {
2020-04-03 13:19:53 +08:00
logger.Println("Auth: " + strconv.FormatInt(m.Chat.ID, 10))
2020-03-30 22:18:09 +08:00
tmp := strings.Split(m.Text, " ")
if len(tmp) != 2 {
2020-04-03 13:19:53 +08:00
logger.Printf("%d Bind error:Wrong Bind Format\n", m.Chat.ID)
2020-03-30 22:18:09 +08:00
bot.Send(m.Chat, "错误的格式")
return
}
2020-04-03 13:19:53 +08:00
logger.Println("client_id: " + tmp[0] + " client_secret: " + tmp[1])
2020-03-30 22:18:09 +08:00
cid := tmp[0]
cse := tmp[1]
bot.Send(m.Chat, "授权账户: [点击直达]("+MSGetAuthUrl(cid)+")", tb.ModeMarkdown)
_, err := bot.Send(m.Chat, "请回复http://localhost/…… + 空格 + 别名(用于管理)", &tb.ReplyMarkup{ForceReply: true})
if err == nil {
UserStatus[m.Chat.ID] = USBind2
UserCid[m.Chat.ID] = cid
UserCSecret[m.Chat.ID] = cse
}
}
2020-04-07 10:56:45 +08:00
2020-03-28 15:22:23 +08:00
func bUnBind(m *tb.Message) {
data := QueryDataByTG(db, m.Chat.ID)
var inlineKeys [][]tb.InlineButton
for _, u := range data {
inlineBtn := tb.InlineButton{
Unique: "unbind" + u.msId,
2020-03-30 22:18:09 +08:00
Text: u.alias,
2020-03-28 15:22:23 +08:00
Data: u.msId,
}
bot.Handle(&inlineBtn, bUnBindInlineBtn)
inlineKeys = append(inlineKeys, []tb.InlineButton{inlineBtn})
}
bot.Send(m.Chat, "选择一个账户将其解绑\n\n当前绑定数: "+strconv.Itoa(GetBindNum(m.Chat.ID))+"/"+strconv.Itoa(BindMaxNum), &tb.ReplyMarkup{InlineKeyboard: inlineKeys})
}
func bUnBindInlineBtn(c *tb.Callback) {
r := QueryDataByMS(db, c.Data)
u := r[0]
if ok, _ := DelData(db, u.msId); !ok {
2020-04-03 13:19:53 +08:00
logger.Println(u.msId + " UnBind ERROR")
2020-03-28 15:22:23 +08:00
bot.Send(c.Message.Chat, "解绑失败!")
return
}
2020-04-03 13:19:53 +08:00
logger.Println(u.msId + " UnBind Success")
2020-03-28 15:22:23 +08:00
bot.Send(c.Message.Chat, "解绑成功!")
bot.Respond(c)
}
2020-04-07 10:56:45 +08:00
2020-03-29 12:51:39 +08:00
func bHelp(m *tb.Message) {
bot.Send(m.Sender, bHelpContent+"\n"+notice, &tb.SendOptions{DisableWebPagePreview: false})
2020-03-27 23:02:28 +08:00
}
func bOnText(m *tb.Message) {
switch UserStatus[m.Chat.ID] {
case USNone:
{
2020-04-07 10:56:45 +08:00
bot.Send(m.Chat, "发送/help获取帮助嗷")
2020-03-27 23:02:28 +08:00
return
}
2020-03-30 22:18:09 +08:00
case USBind1:
{
if !m.IsReply() {
bot.Send(m.Chat, "请通过回复方式绑定")
return
}
bBind2(m)
}
case USBind2:
2020-03-27 23:02:28 +08:00
{
2020-03-29 17:31:35 +08:00
if !m.IsReply() {
bot.Send(m.Chat, "请通过回复方式绑定")
return
}
2020-03-27 23:02:28 +08:00
if GetBindNum(m.Chat.ID) == BindMaxNum {
bot.Send(m.Chat, "已经达到最大可绑定数")
return
}
bot.Send(m.Chat, "正在绑定中……")
2020-03-30 22:18:09 +08:00
info := BindUser(m, UserCid[m.Chat.ID], UserCSecret[m.Chat.ID])
2020-03-27 23:02:28 +08:00
if info == "" {
bot.Send(m.Chat, "绑定成功!")
} else {
bot.Send(m.Chat, info)
}
2020-03-28 15:22:23 +08:00
UserStatus[m.Chat.ID] = USNone
2020-03-27 23:02:28 +08:00
}
}
2020-03-27 11:36:29 +08:00
}
2020-04-02 09:43:42 +08:00
func bTask(m *tb.Message) {
for _, a := range admin {
if a == m.Chat.ID {
SignTask()
return
}
}
2020-04-07 10:56:45 +08:00
bot.Send(m.Chat, "您没有权限执行此操作~")
2020-04-02 09:43:42 +08:00
}