package main import ( "time" "github.com/animenotifier/arn" "github.com/animenotifier/shoboi" "github.com/fatih/color" ) func main() { color.Yellow("Syncing Shoboi Anime") defer color.Green("Finished.") defer arn.Node.Close() // Priority queues highPriority := []*arn.Anime{} mediumPriority := []*arn.Anime{} lowPriority := []*arn.Anime{} for anime := range arn.StreamAnime() { if anime.GetMapping("shoboi/anime") != "" { continue } switch anime.Status { case "current": highPriority = append(highPriority, anime) case "upcoming": mediumPriority = append(mediumPriority, anime) default: lowPriority = append(lowPriority, anime) } } color.Cyan("High priority queue (%d):", len(highPriority)) refreshQueue(highPriority) color.Cyan("Medium priority queue (%d):", len(mediumPriority)) refreshQueue(mediumPriority) color.Cyan("Low priority queue (%d):", len(lowPriority)) refreshQueue(lowPriority) // This is a lazy hack: Wait 5 minutes for goroutines to finish their remaining work. time.Sleep(5 * time.Minute) } func refreshQueue(queue []*arn.Anime) { count := 0 for _, anime := range queue { if sync(anime) { anime.Save() count++ } } color.Green("Added Shoboi IDs for %d anime", count) } func sync(anime *arn.Anime) bool { // If we already have the ID, nothing to do here if anime.GetMapping("shoboi/anime") != "" { return false } // Log ID and title print(anime.ID + " | [JP] " + anime.Title.Japanese + " | [EN] " + anime.Title.Canonical) // Search Japanese title if anime.GetMapping("shoboi/anime") == "" && anime.Title.Japanese != "" { search(anime, anime.Title.Japanese) } // Search English title if anime.GetMapping("shoboi/anime") == "" && anime.Title.English != "" { search(anime, anime.Title.English) } // Did we get the ID? if anime.GetMapping("shoboi/anime") != "" { println(color.GreenString("✔")) return true } println(color.RedString("✘")) return false } // Search for a specific title func search(anime *arn.Anime, title string) { shoboi, err := shoboi.SearchAnime(title) if err != nil { color.Red(err.Error()) return } if shoboi == nil { return } // Copy titles if shoboi.TitleJapanese != "" { anime.Title.Japanese = shoboi.TitleJapanese } if shoboi.TitleHiragana != "" { anime.Title.Hiragana = shoboi.TitleHiragana } if shoboi.FirstChannel != "" { anime.FirstChannel = shoboi.FirstChannel } // This will start a goroutine that saves the anime anime.SetMapping("shoboi/anime", shoboi.TID) }