www.byjp.me/tools/syndicate/main.go
2023-11-12 09:47:58 +00:00

63 lines
1.6 KiB
Go

package main
import (
"fmt"
"os"
"strings"
"github.com/by-jp/www.byjp.me/tools/syndicate/backfeeder"
"github.com/by-jp/www.byjp.me/tools/syndicate/poster"
)
func check(err error) {
if err != nil {
fmt.Fprintf(os.Stderr, "🛑 %+v\n", err)
// TODO: Remove panic
panic(err)
os.Exit(1)
}
}
func main() {
check(os.Chdir("../../"))
cfg, err := parseConfig(".syndicate")
check(err)
pstr := poster.New(cfg.services)
bkfd := backfeeder.New(cfg.services)
for _, feed := range cfg.feeds {
f, err := os.Open(feed)
check(err)
defer f.Close()
services, toPost, toBackfeed, err := parseFeed(cfg.urlToPath, f, cfg.tagMatcher, cfg.syndicationMatchers)
check(err)
if len(services) > 0 {
fmt.Fprintf(os.Stderr, "Connecting to %s to syndicate & backfeed…\n", strings.Join(services, ", "))
for _, sname := range services {
if err := cfg.services.Init(sname); err != nil {
check(fmt.Errorf("couldn't connect to %s: %w", sname, err))
}
}
}
fmt.Fprintf(os.Stderr, "Found %d new syndications to post in %s\n", len(toPost), feed)
for k, p := range toPost {
if err := pstr.Post(k, p); err == nil {
fmt.Printf("Posted '%s' to %s: %s\n", p.Title, k.Source, pstr.PostedURL(k))
} else {
fmt.Fprintf(os.Stderr, "Couldn't post %s to %s: %v\n", p.URL, k.Source, err)
}
}
for _, fname := range cfg.content {
if err := pstr.ReplaceReferences(fname, cfg.tagMatcher); err != nil {
fmt.Fprintf(os.Stderr, "Couldn't replace syndication references: %v\n", err)
}
}
fmt.Fprintf(os.Stderr, "Found %d existing syndications to backfeed from %s\n", len(toBackfeed), feed)
_ = bkfd
}
}