Updated MAL sync

This commit is contained in:
Eduard Urbach 2018-11-01 08:23:41 +09:00
parent 3ccf470cf0
commit 9d57aaf12a
5 changed files with 169 additions and 124 deletions

72
jobs/mal-parse/anime.go Normal file
View File

@ -0,0 +1,72 @@
package main
import (
"compress/gzip"
"errors"
"os"
"github.com/animenotifier/arn"
"github.com/animenotifier/mal"
"github.com/animenotifier/mal/parser"
"github.com/fatih/color"
)
// Read anime file
func readAnimeFile(name string) error {
file, err := os.Open(name)
if err != nil {
color.Red(err.Error())
return err
}
defer file.Close()
reader, err := gzip.NewReader(file)
if err != nil {
color.Red(err.Error())
return err
}
anime, characters, err := malparser.ParseAnime(reader)
if err != nil {
color.Red(err.Error())
return err
}
if anime.ID == "" {
return errors.New("Empty ID")
}
for _, character := range characters {
obj, err := arn.MAL.Get("Character", character.ID)
if err != nil {
arn.MAL.Set("Character", character.ID, character)
continue
}
existing := obj.(*mal.Character)
modified := false
if existing.Name != character.Name {
existing.Name = character.Name
modified = true
}
if existing.Image != character.Image {
existing.Image = character.Image
modified = true
}
if modified {
arn.MAL.Set("Character", existing.ID, existing)
}
}
// fmt.Println(anime.ID, anime.Title)
arn.MAL.Set("Anime", anime.ID, anime)
return nil
}

View File

@ -0,0 +1,45 @@
package main
import (
"compress/gzip"
"errors"
"os"
"github.com/animenotifier/arn"
"github.com/animenotifier/mal/parser"
"github.com/fatih/color"
)
// Read character file
func readCharacterFile(name string) error {
file, err := os.Open(name)
if err != nil {
color.Red(err.Error())
return err
}
defer file.Close()
reader, err := gzip.NewReader(file)
if err != nil {
color.Red(err.Error())
return err
}
character, err := malparser.ParseCharacter(reader)
if err != nil {
color.Red(err.Error())
return err
}
if character.ID == "" {
return errors.New("Empty ID")
}
// fmt.Println(character.ID, character.Name)
arn.MAL.Set("Character", character.ID, character)
return nil
}

View File

@ -1,17 +1,12 @@
package main package main
import ( import (
"compress/gzip"
"errors"
"os" "os"
"path" "path"
"path/filepath" "path/filepath"
"strings" "strings"
"github.com/animenotifier/mal"
"github.com/animenotifier/arn" "github.com/animenotifier/arn"
"github.com/animenotifier/mal/parser"
"github.com/fatih/color" "github.com/fatih/color"
) )
@ -35,6 +30,7 @@ func main() {
} }
} }
// Read files in a given directory and apply a function on them
func readFiles(root string, onFile func(string) error) { func readFiles(root string, onFile func(string) error) {
count := 0 count := 0
@ -65,95 +61,3 @@ func readFiles(root string, onFile func(string) error) {
color.Cyan("%d files found", count) color.Cyan("%d files found", count)
} }
func readAnimeFile(name string) error {
file, err := os.Open(name)
if err != nil {
color.Red(err.Error())
return err
}
defer file.Close()
reader, err := gzip.NewReader(file)
if err != nil {
color.Red(err.Error())
return err
}
anime, characters, err := malparser.ParseAnime(reader)
if err != nil {
color.Red(err.Error())
return err
}
if anime.ID == "" {
return errors.New("Empty ID")
}
for _, character := range characters {
obj, err := arn.MAL.Get("Character", character.ID)
if err != nil {
arn.MAL.Set("Character", character.ID, character)
continue
}
existing := obj.(*mal.Character)
modified := false
if existing.Name != character.Name {
existing.Name = character.Name
modified = true
}
if existing.Image != character.Image {
existing.Image = character.Image
modified = true
}
if modified {
arn.MAL.Set("Character", existing.ID, existing)
}
}
// fmt.Println(anime.ID, anime.Title)
arn.MAL.Set("Anime", anime.ID, anime)
return nil
}
func readCharacterFile(name string) error {
file, err := os.Open(name)
if err != nil {
color.Red(err.Error())
return err
}
defer file.Close()
reader, err := gzip.NewReader(file)
if err != nil {
color.Red(err.Error())
return err
}
character, err := malparser.ParseCharacter(reader)
if err != nil {
color.Red(err.Error())
return err
}
if character.ID == "" {
return errors.New("Empty ID")
}
// fmt.Println(character.ID, character.Name)
arn.MAL.Set("Character", character.ID, character)
return nil
}

View File

@ -26,28 +26,32 @@ func main() {
return return
} }
// Sync the most important ones first // Sync anime
allAnime := arn.FilterAnime(func(anime *arn.Anime) bool { if objectType == "all" || objectType == "anime" {
return anime.GetMapping("myanimelist/anime") != "" allAnime := arn.FilterAnime(func(anime *arn.Anime) bool {
}) return anime.GetMapping("myanimelist/anime") != ""
})
arn.SortAnimeByQuality(allAnime) arn.SortAnimeByQuality(allAnime)
color.Yellow("%d anime found", len(allAnime)) color.Yellow("%d anime found", len(allAnime))
for _, anime := range allAnime { for _, anime := range allAnime {
syncAnime(anime, anime.GetMapping("myanimelist/anime")) syncAnime(anime, anime.GetMapping("myanimelist/anime"))
}
} }
// Sync the most important ones first // Sync characters
allCharacters := arn.FilterCharacters(func(character *arn.Character) bool { if objectType == "all" || objectType == "character" {
return character.GetMapping("myanimelist/character") != "" allCharacters := arn.FilterCharacters(func(character *arn.Character) bool {
}) return character.GetMapping("myanimelist/character") != ""
})
arn.SortCharactersByLikes(allCharacters) arn.SortCharactersByLikes(allCharacters)
color.Yellow("%d characters found", len(allCharacters)) color.Yellow("%d characters found", len(allCharacters))
for _, character := range allCharacters { for _, character := range allCharacters {
syncCharacter(character, character.GetMapping("myanimelist/character")) syncCharacter(character, character.GetMapping("myanimelist/character"))
}
} }
} }
@ -99,6 +103,13 @@ func syncCharacter(character *arn.Character, malID string) {
description, attributes := parseCharacterDescription(malCharacter.Description) description, attributes := parseCharacterDescription(malCharacter.Description)
character.Description = description character.Description = description
character.Attributes = attributes character.Attributes = attributes
character.Spoilers = []arn.Spoiler{}
for _, spoilerText := range malCharacter.Spoilers {
character.Spoilers = append(character.Spoilers, arn.Spoiler{
Text: spoilerText,
})
}
if character.Name.Japanese == "" && malCharacter.JapaneseName != "" { if character.Name.Japanese == "" && malCharacter.JapaneseName != "" {
character.Name.Japanese = malCharacter.JapaneseName character.Name.Japanese = malCharacter.JapaneseName

View File

@ -7,28 +7,41 @@ import (
) )
// Shell parameters // Shell parameters
var animeID string var objectType string
var objectID string
// Shell flags // Shell flags
func init() { func init() {
flag.StringVar(&animeID, "id", "", "ID of the notify.moe anime you want to refresh") flag.StringVar(&objectType, "type", "all", "all | anime | character")
flag.StringVar(&objectID, "id", "", "ID of the notify.moe anime/character you want to refresh")
flag.Parse() flag.Parse()
} }
// InvokeShellArgs ... // InvokeShellArgs ...
func InvokeShellArgs() bool { func InvokeShellArgs() bool {
if animeID != "" { if objectID != "" {
anime, err := arn.GetAnime(animeID) switch objectType {
case "anime":
anime, err := arn.GetAnime(objectID)
arn.PanicOnError(err)
if err != nil { if anime.GetMapping("myanimelist/anime") == "" {
panic(err) panic("No MAL ID")
}
syncAnime(anime, anime.GetMapping("myanimelist/anime"))
case "character":
character, err := arn.GetCharacter(objectID)
arn.PanicOnError(err)
if character.GetMapping("myanimelist/character") == "" {
panic("No MAL ID")
}
syncCharacter(character, character.GetMapping("myanimelist/character"))
} }
if anime.GetMapping("myanimelist/anime") == "" {
panic("No MAL ID")
}
syncAnime(anime, anime.GetMapping("myanimelist/anime"))
return true return true
} }