2023-02-22 15:22:50 +03:00
|
|
|
|
package main
|
|
|
|
|
|
|
|
|
|
import (
|
2023-08-30 08:42:27 +03:00
|
|
|
|
"io"
|
2023-02-22 15:22:50 +03:00
|
|
|
|
"log"
|
|
|
|
|
"os"
|
2023-08-10 11:01:47 +03:00
|
|
|
|
"strconv"
|
2023-08-06 12:40:23 +03:00
|
|
|
|
"time"
|
2023-02-22 15:22:50 +03:00
|
|
|
|
|
|
|
|
|
"git.l9labs.ru/anufriev.g.a/l9_stud_bot/modules/database"
|
2023-08-10 21:59:58 +03:00
|
|
|
|
"git.l9labs.ru/anufriev.g.a/l9_stud_bot/modules/notify"
|
2023-08-03 20:52:18 +03:00
|
|
|
|
"git.l9labs.ru/anufriev.g.a/l9_stud_bot/modules/ssau_parser"
|
2023-02-22 16:23:38 +03:00
|
|
|
|
"git.l9labs.ru/anufriev.g.a/l9_stud_bot/modules/tg"
|
2023-02-22 15:22:50 +03:00
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func main() {
|
2023-08-30 08:42:27 +03:00
|
|
|
|
ssau_parser.HeadURL = "https://ssau.ru"
|
2023-08-06 11:26:48 +03:00
|
|
|
|
if err := tg.CheckEnv(); err != nil {
|
|
|
|
|
log.Fatal(err)
|
|
|
|
|
}
|
2023-08-05 12:40:24 +03:00
|
|
|
|
logs := database.OpenLogs()
|
|
|
|
|
defer logs.CloseAll()
|
2023-08-30 08:42:27 +03:00
|
|
|
|
log.SetOutput(io.MultiWriter(os.Stderr, logs.ErrorFile))
|
|
|
|
|
help, err := os.ReadFile("help.txt")
|
|
|
|
|
if err != nil {
|
|
|
|
|
log.Fatal(err)
|
|
|
|
|
}
|
|
|
|
|
|
2023-08-02 20:11:58 +03:00
|
|
|
|
// bot.Debug = log.New(io.MultiWriter(os.Stderr, database.CreateLog("messages")), "", log.LstdFlags)
|
|
|
|
|
bot, err := tg.InitBot(
|
2023-08-05 12:40:24 +03:00
|
|
|
|
logs,
|
2023-08-02 21:22:36 +03:00
|
|
|
|
database.DB{
|
|
|
|
|
User: os.Getenv("MYSQL_USER"),
|
|
|
|
|
Pass: os.Getenv("MYSQL_PASS"),
|
|
|
|
|
Schema: os.Getenv("MYSQL_DB"),
|
|
|
|
|
},
|
2023-08-02 20:11:58 +03:00
|
|
|
|
os.Getenv("TELEGRAM_APITOKEN"),
|
|
|
|
|
)
|
2023-03-08 13:03:27 +03:00
|
|
|
|
if err != nil {
|
|
|
|
|
log.Fatal(err)
|
|
|
|
|
}
|
2023-08-10 11:01:47 +03:00
|
|
|
|
bot.Week, err = strconv.Atoi(os.Getenv("START_WEEK"))
|
|
|
|
|
if err != nil {
|
|
|
|
|
log.Fatal(err)
|
|
|
|
|
}
|
2023-08-30 08:42:27 +03:00
|
|
|
|
bot.TestUser, err = strconv.ParseInt(os.Getenv("TELEGRAM_TEST_USER"), 0, 64)
|
|
|
|
|
if err != nil {
|
|
|
|
|
log.Fatal(err)
|
|
|
|
|
}
|
2023-08-08 18:36:33 +03:00
|
|
|
|
bot.WkPath = os.Getenv("WK_PATH")
|
2023-08-30 08:42:27 +03:00
|
|
|
|
bot.HelpTxt = string(help)
|
2023-08-12 17:15:19 +03:00
|
|
|
|
//now, _ := time.Parse("2006-01-02 15:04 -07", "2023-02-07 07:00 +04")
|
|
|
|
|
now := time.Now()
|
|
|
|
|
next := time.Date(now.Year(), now.Month(), now.Day(), now.Hour(), (now.Minute() + 1), 0, 0, now.Location())
|
2023-08-13 15:13:58 +03:00
|
|
|
|
// TODO: что-то придумать с этим выжиданием
|
2023-08-12 17:15:19 +03:00
|
|
|
|
log.Println("Waiting...")
|
|
|
|
|
time.Sleep(next.Sub(now))
|
|
|
|
|
mailTicker := time.NewTicker(1 * time.Minute)
|
2023-08-30 08:42:27 +03:00
|
|
|
|
sheduleTicker := time.NewTicker(30 * time.Minute)
|
2023-08-12 17:15:19 +03:00
|
|
|
|
log.Println("Started")
|
|
|
|
|
defer mailTicker.Stop()
|
|
|
|
|
defer sheduleTicker.Stop()
|
2023-08-10 21:59:58 +03:00
|
|
|
|
for {
|
|
|
|
|
select {
|
|
|
|
|
case update := <-*bot.Updates:
|
2023-08-30 08:42:27 +03:00
|
|
|
|
now = time.Now()
|
2023-08-10 21:59:58 +03:00
|
|
|
|
_, err := bot.HandleUpdate(update, now)
|
|
|
|
|
if err != nil {
|
|
|
|
|
log.Println(err)
|
|
|
|
|
}
|
2023-08-12 17:15:19 +03:00
|
|
|
|
case <-mailTicker.C:
|
2023-08-30 08:42:27 +03:00
|
|
|
|
now = time.Now()
|
2023-08-11 16:17:22 +03:00
|
|
|
|
log.Println(now)
|
2023-08-10 21:59:58 +03:00
|
|
|
|
notes, err := notify.CheckNext(bot.DB, now)
|
|
|
|
|
if err != nil {
|
|
|
|
|
log.Println(err)
|
|
|
|
|
}
|
2023-08-12 10:28:35 +03:00
|
|
|
|
notify.FirstMailing(bot, now)
|
2023-08-11 16:17:22 +03:00
|
|
|
|
notify.Mailing(bot, notes, now)
|
|
|
|
|
notify.ClearTemp(bot, now)
|
2023-08-12 17:15:19 +03:00
|
|
|
|
case <-sheduleTicker.C:
|
2023-08-30 08:42:27 +03:00
|
|
|
|
now = time.Now()
|
2023-08-13 14:00:51 +03:00
|
|
|
|
if now.Hour() > 8 && now.Hour() < 20 {
|
|
|
|
|
log.Println("check changes")
|
|
|
|
|
notify.CheckShedules(bot, now)
|
|
|
|
|
log.Println("check end")
|
|
|
|
|
}
|
2023-08-02 21:22:36 +03:00
|
|
|
|
}
|
2023-08-02 20:11:58 +03:00
|
|
|
|
}
|
|
|
|
|
}
|