E5BotForSQLite/main.go

106 lines
2.3 KiB
Go
Raw Normal View History

2020-03-26 12:53:00 +08:00
package main
import (
2020-03-27 09:03:41 +08:00
"database/sql"
2020-03-26 12:53:00 +08:00
"fmt"
2020-03-28 15:22:23 +08:00
"github.com/robfig/cron/v3"
2020-03-26 12:53:00 +08:00
"github.com/spf13/viper"
2020-03-27 09:03:41 +08:00
"golang.org/x/net/proxy"
2020-03-26 12:53:00 +08:00
tb "gopkg.in/tucnak/telebot.v2"
2020-03-27 09:03:41 +08:00
"net/http"
2020-03-29 12:51:39 +08:00
"strconv"
2020-03-26 12:53:00 +08:00
"time"
)
var (
BotToken string
2020-03-27 09:03:41 +08:00
Socks5 string
2020-03-27 23:03:46 +08:00
bot *tb.Bot
db *sql.DB
2020-03-26 12:53:00 +08:00
)
2020-03-27 09:03:41 +08:00
const (
2020-03-29 12:07:15 +08:00
dbDriverName = "mysql"
2020-03-29 12:51:39 +08:00
logo = `
2020-03-29 16:42:46 +08:00
______ _____ _____ _ ____ _
| ____| ____/ ____| | | | _ \ | |
| |__ | |__| (___ _ _| |__ | |_) | ___ | |_
| __| |___ \\___ \| | | | '_ \| _ < / _ \| __|
| |____ ___) |___) | |_| | |_) | |_) | (_) | |_
|______|____/_____/ \__,_|_.__/|____/ \___/ \__|
2020-03-29 12:51:39 +08:00
`
2020-03-27 09:03:41 +08:00
)
func init() {
fmt.Println(logo)
2020-03-27 23:03:46 +08:00
//read config
2020-03-29 12:51:39 +08:00
fmt.Println("Read Config……")
2020-03-26 12:53:00 +08:00
viper.SetConfigName("config")
viper.AddConfigPath(".")
err := viper.ReadInConfig()
2020-03-27 09:03:41 +08:00
CheckErr(err)
2020-03-26 12:53:00 +08:00
BotToken = viper.GetString("bot_token")
2020-03-27 09:03:41 +08:00
Socks5 = viper.GetString("socks5")
2020-03-27 23:03:46 +08:00
//set bot
2020-03-29 12:51:39 +08:00
fmt.Println("Bot Settings……")
2020-03-29 17:31:35 +08:00
Poller := &tb.LongPoller{Timeout: 15 * time.Second}
spamProtected := tb.NewMiddlewarePoller(Poller, func(upd *tb.Update) bool {
if upd.Message == nil {
return true
}
if !upd.Message.Private() {
return false
}
return true
})
2020-03-27 09:03:41 +08:00
botsettings := tb.Settings{
2020-03-26 12:53:00 +08:00
Token: BotToken,
2020-03-29 17:31:35 +08:00
Poller: spamProtected,
2020-03-26 12:53:00 +08:00
}
2020-03-27 23:03:46 +08:00
//set socks5
2020-03-27 09:03:41 +08:00
if Socks5 != "" {
fmt.Println("Proxy:" + Socks5)
dialer, err := proxy.SOCKS5("tcp", Socks5, nil, proxy.Direct)
2020-03-27 23:03:46 +08:00
CheckErr(err)
2020-03-27 09:03:41 +08:00
httpTransport := &http.Transport{}
httpClient := &http.Client{Transport: httpTransport}
httpTransport.Dial = dialer.Dial
botsettings.Client = httpClient
}
2020-03-27 23:03:46 +08:00
//create bot
bot, err = tb.NewBot(botsettings)
2020-03-29 12:51:39 +08:00
if err != nil {
fmt.Println("Create Bot ERROR!")
return
}
fmt.Println("Bot: " + strconv.Itoa(bot.Me.ID) + " " + bot.Me.Username)
2020-03-27 23:03:46 +08:00
}
func main() {
BotStart()
2020-03-26 12:53:00 +08:00
}
2020-03-27 23:03:46 +08:00
func BotStart() {
2020-03-28 15:22:23 +08:00
MakeHandle()
TaskLaunch()
2020-03-29 17:31:35 +08:00
fmt.Println("Bot Start")
fmt.Println("------------")
2020-03-27 23:03:46 +08:00
bot.Start()
2020-03-27 09:03:41 +08:00
}
2020-03-28 15:22:23 +08:00
func MakeHandle() {
2020-03-29 12:51:39 +08:00
fmt.Println("Make Handle……")
2020-03-27 23:03:46 +08:00
bot.Handle("/start", bStart)
bot.Handle("/my", bMy)
2020-03-30 22:18:09 +08:00
bot.Handle("/bind", bBind1)
2020-03-28 15:22:23 +08:00
bot.Handle("/unbind", bUnBind)
2020-03-29 12:51:39 +08:00
bot.Handle("/help", bHelp)
2020-03-27 23:03:46 +08:00
bot.Handle(tb.OnText, bOnText)
2020-03-27 09:03:41 +08:00
}
2020-03-28 15:22:23 +08:00
func TaskLaunch() {
task := cron.New()
//每三小时执行一次
2020-04-01 15:57:14 +08:00
task.AddFunc("1 */3 * * *", SignTask)
// */1 * * * * 1 */3 * * *
2020-03-29 12:51:39 +08:00
fmt.Println("Cron Task Start……")
2020-03-28 15:22:23 +08:00
task.Start()
defer task.Stop()
2020-03-28 15:22:23 +08:00
}