mirror of
https://github.com/tgdrive/teldrive.git
synced 2025-01-10 17:19:56 +08:00
112 lines
2.4 KiB
Go
112 lines
2.4 KiB
Go
package tgc
|
|
|
|
import (
|
|
"context"
|
|
"sync"
|
|
|
|
"github.com/gotd/contrib/bg"
|
|
"github.com/gotd/td/telegram"
|
|
)
|
|
|
|
type BotWorkers struct {
|
|
mu sync.Mutex
|
|
bots map[int64][]string
|
|
currIdx map[int64]int
|
|
}
|
|
|
|
func (w *BotWorkers) Set(bots []string, channelId int64) {
|
|
w.mu.Lock()
|
|
defer w.mu.Unlock()
|
|
_, ok := w.bots[channelId]
|
|
if !ok {
|
|
w.bots = make(map[int64][]string)
|
|
w.currIdx = make(map[int64]int)
|
|
w.bots[channelId] = bots
|
|
w.currIdx[channelId] = 0
|
|
}
|
|
}
|
|
|
|
func (w *BotWorkers) Next(channelId int64) string {
|
|
w.mu.Lock()
|
|
defer w.mu.Unlock()
|
|
index := w.currIdx[channelId]
|
|
w.currIdx[channelId] = (index + 1) % len(w.bots[channelId])
|
|
return w.bots[channelId][index]
|
|
}
|
|
|
|
var Workers = &BotWorkers{}
|
|
|
|
type Client struct {
|
|
Tg *telegram.Client
|
|
Stop bg.StopFunc
|
|
Status string
|
|
}
|
|
|
|
type streamWorkers struct {
|
|
mu sync.Mutex
|
|
bots map[int64][]string
|
|
clients map[int64][]*Client
|
|
currIdx map[int64]int
|
|
}
|
|
|
|
func (w *streamWorkers) Set(bots []string, channelId int64) {
|
|
w.mu.Lock()
|
|
defer w.mu.Unlock()
|
|
_, ok := w.bots[channelId]
|
|
if !ok {
|
|
w.bots = make(map[int64][]string)
|
|
w.clients = make(map[int64][]*Client)
|
|
w.currIdx = make(map[int64]int)
|
|
w.bots[channelId] = bots
|
|
for _, token := range bots {
|
|
client, _ := BotLogin(context.TODO(), token)
|
|
w.clients[channelId] = append(w.clients[channelId], &Client{Tg: client, Status: "idle"})
|
|
}
|
|
w.currIdx[channelId] = 0
|
|
}
|
|
|
|
}
|
|
|
|
func (w *streamWorkers) Next(channelId int64) (*Client, int, error) {
|
|
w.mu.Lock()
|
|
defer w.mu.Unlock()
|
|
index := w.currIdx[channelId]
|
|
nextClient := w.clients[channelId][index]
|
|
w.currIdx[channelId] = (index + 1) % len(w.clients[channelId])
|
|
if nextClient.Status == "idle" {
|
|
stop, err := bg.Connect(nextClient.Tg)
|
|
if err != nil {
|
|
return nil, 0, err
|
|
}
|
|
nextClient.Stop = stop
|
|
nextClient.Status = "running"
|
|
}
|
|
return nextClient, index, nil
|
|
}
|
|
|
|
func (w *streamWorkers) UserWorker(client *telegram.Client) (*Client, error) {
|
|
w.mu.Lock()
|
|
defer w.mu.Unlock()
|
|
|
|
//for user login channelId not needed so we use 1 here
|
|
channelId := int64(1)
|
|
|
|
_, ok := w.clients[channelId]
|
|
|
|
if !ok {
|
|
w.clients = make(map[int64][]*Client)
|
|
w.clients[channelId] = append(w.clients[channelId], &Client{Tg: client, Status: "idle"})
|
|
}
|
|
nextClient := w.clients[channelId][0]
|
|
if nextClient.Status == "idle" {
|
|
stop, err := bg.Connect(nextClient.Tg)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
nextClient.Stop = stop
|
|
nextClient.Status = "running"
|
|
}
|
|
return nextClient, nil
|
|
}
|
|
|
|
var StreamWorkers = &streamWorkers{}
|