2023-08-10 15:49:25 +03:00
|
|
|
package tx
|
2023-07-09 01:28:59 +03:00
|
|
|
|
|
|
|
import (
|
2023-08-10 15:49:25 +03:00
|
|
|
apix "github.com/go-telegram-bot-api/telegram-bot-api/v5"
|
|
|
|
//"log"
|
2023-07-09 01:28:59 +03:00
|
|
|
)
|
|
|
|
|
|
|
|
// The wrapper around Telegram API.
|
|
|
|
type Bot struct {
|
|
|
|
*apix.BotAPI
|
|
|
|
*Behaviour
|
|
|
|
sessions SessionMap
|
|
|
|
}
|
|
|
|
|
|
|
|
// Return the new bot for running the Behaviour.
|
|
|
|
func NewBot(token string, beh *Behaviour, sessions SessionMap) (*Bot, error) {
|
2023-08-10 15:49:25 +03:00
|
|
|
bot, err := apix.NewBotAPI(token)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
// Make new sessions if no current are provided.
|
|
|
|
if sessions == nil {
|
|
|
|
sessions = make(SessionMap)
|
|
|
|
}
|
|
|
|
|
|
|
|
return &Bot{
|
|
|
|
BotAPI: bot,
|
2023-07-09 01:28:59 +03:00
|
|
|
Behaviour: beh,
|
2023-08-10 15:49:25 +03:00
|
|
|
sessions: make(SessionMap),
|
|
|
|
}, nil
|
2023-07-09 01:28:59 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
// Run the bot with the Behaviour.
|
|
|
|
func (bot *Bot) Run() error {
|
|
|
|
bot.Debug = true
|
2023-08-10 15:49:25 +03:00
|
|
|
|
2023-07-12 00:33:51 +03:00
|
|
|
uc := apix.NewUpdate(0)
|
2023-07-09 01:28:59 +03:00
|
|
|
uc.Timeout = 60
|
2023-08-10 15:49:25 +03:00
|
|
|
|
2023-07-09 01:28:59 +03:00
|
|
|
updates := bot.GetUpdatesChan(uc)
|
2023-08-10 15:49:25 +03:00
|
|
|
|
|
|
|
chans := make(map[SessionId]chan *Update)
|
2023-07-09 01:28:59 +03:00
|
|
|
for u := range updates {
|
2023-07-12 14:20:52 +03:00
|
|
|
var sid SessionId
|
2023-08-10 15:49:25 +03:00
|
|
|
if u.Message != nil {
|
2023-07-12 14:06:05 +03:00
|
|
|
// Create new session if the one does not exist
|
|
|
|
// for this user.
|
2023-07-12 14:20:52 +03:00
|
|
|
sid = SessionId(u.Message.Chat.ID)
|
2023-08-10 15:49:25 +03:00
|
|
|
if _, ok := bot.sessions[sid]; !ok {
|
2023-07-12 14:06:05 +03:00
|
|
|
bot.sessions.Add(sid)
|
2023-08-10 15:49:25 +03:00
|
|
|
}
|
|
|
|
|
2023-07-12 14:06:05 +03:00
|
|
|
// The "start" command resets the bot
|
|
|
|
// by executing the Start Action.
|
|
|
|
if u.Message.IsCommand() {
|
|
|
|
cmd := u.Message.Command()
|
|
|
|
if cmd == "start" {
|
|
|
|
// Getting current session and context.
|
|
|
|
session := bot.sessions[sid]
|
|
|
|
ctx := &Context{
|
2023-08-10 15:49:25 +03:00
|
|
|
B: bot,
|
2023-07-12 14:06:05 +03:00
|
|
|
Session: session,
|
|
|
|
}
|
2023-08-10 15:49:25 +03:00
|
|
|
|
2023-07-12 14:06:05 +03:00
|
|
|
chn := make(chan *Update)
|
|
|
|
chans[sid] = chn
|
|
|
|
// Starting the goroutine for the user.
|
|
|
|
go ctx.handleUpdateChan(chn)
|
|
|
|
continue
|
|
|
|
}
|
2023-07-09 01:28:59 +03:00
|
|
|
}
|
2023-07-12 14:20:52 +03:00
|
|
|
} else if u.CallbackQuery != nil {
|
|
|
|
sid = SessionId(u.CallbackQuery.Message.Chat.ID)
|
|
|
|
}
|
|
|
|
chn, ok := chans[sid]
|
|
|
|
if ok {
|
2023-07-12 14:06:05 +03:00
|
|
|
chn <- &u
|
2023-07-12 14:20:52 +03:00
|
|
|
}
|
2023-07-09 01:28:59 +03:00
|
|
|
}
|
2023-08-10 15:49:25 +03:00
|
|
|
|
2023-07-09 01:28:59 +03:00
|
|
|
return nil
|
|
|
|
}
|