2022-04-26 09:55:59 -04:00
|
|
|
package app
|
|
|
|
|
2022-04-28 19:24:21 -04:00
|
|
|
import "go.balki.me/tss/log"
|
|
|
|
|
2022-04-27 00:19:05 -04:00
|
|
|
func Run(configPath string) {
|
2022-04-28 19:24:21 -04:00
|
|
|
cfg, err := ParseConfig(configPath)
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
log.Panic("failed to parse config", "path", configPath, "err", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
scheduler, err := NewScheduler(cfg.LastSuccessPath)
|
|
|
|
|
|
|
|
defer func() {
|
|
|
|
if err := scheduler.Save(); err != nil {
|
|
|
|
log.Panic("failed to save last success info", "path", cfg.LastSuccessPath, "err", err)
|
2022-04-27 00:19:05 -04:00
|
|
|
}
|
2022-04-28 19:24:21 -04:00
|
|
|
}()
|
2022-04-26 09:55:59 -04:00
|
|
|
|
2022-04-28 19:24:21 -04:00
|
|
|
for _, feed := range cfg.Feeds {
|
|
|
|
log.Info("processing feed", "feed", feed.Name)
|
|
|
|
ProcessFeed(feed, scheduler)
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
2022-04-27 00:19:05 -04:00
|
|
|
for _, feed := range cfg.Feeds {
|
|
|
|
log.Println("Processing feed", feed.Name)
|
|
|
|
data, err := Download(feed.Url, feed.Proxy)
|
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
|
|
|
}
|
2022-04-26 09:55:59 -04:00
|
|
|
|
2022-04-27 00:19:05 -04:00
|
|
|
for _, feed := range c.Feeds {
|
|
|
|
log.Println("Processing feed", feed.Name)
|
|
|
|
|
|
|
|
links, err := parseFeed(data)
|
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
2022-04-26 09:55:59 -04:00
|
|
|
|
2022-04-27 00:19:05 -04:00
|
|
|
for _, link := range links {
|
|
|
|
if alreadySent(link) {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
err := sendTelegram(link, feed.Channel, feed.Rhash)
|
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
fmt.Println(configPath)
|
|
|
|
*/
|
2022-04-26 09:55:59 -04:00
|
|
|
}
|
2022-04-28 19:24:21 -04:00
|
|
|
|
|
|
|
func ProcessFeed(feed FeedCfg, scheduler *Scheduler) {
|
|
|
|
sd, err := scheduler.ShouldDownload(feed.Name, feed.Cron)
|
|
|
|
if err != nil {
|
|
|
|
log.Error("shouldDownload failed", "feed", feed.Name, "err", err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
if !sd {
|
|
|
|
log.Info("skipping feed due to schedule", "feed", feed.Name)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
_, err = Download(feed.Url, feed.Proxy)
|
|
|
|
if err != nil {
|
|
|
|
log.Error("download failed", "feed", feed.Name, "url", feed.Url, "proxy", feed.Proxy)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|