mirror of
https://github.com/navidrome/navidrome.git
synced 2025-04-03 20:47:35 +03:00
Fix rollup of track genres to albums and artists.
See: https://github.com/navidrome/navidrome/pull/1251#issuecomment-882343022
This commit is contained in:
parent
254e5673e1
commit
95181d748d
2 changed files with 49 additions and 9 deletions
|
@ -132,7 +132,7 @@ func (r *albumRepository) GetAll(options ...model.QueryOptions) (model.Albums, e
|
|||
}
|
||||
|
||||
// Return a map of mediafiles that have embedded covers for the given album ids
|
||||
func (r *albumRepository) getEmbeddedCovers(ids []string) (map[string]model.MediaFile, error) {
|
||||
func (r *albumRepository) getEmbeddedCoversForAlbums(ids []string) (map[string]model.MediaFile, error) {
|
||||
var mfs model.MediaFiles
|
||||
coverSql := Select("album_id", "id", "path").Distinct().From("media_file").
|
||||
Where(And{Eq{"has_cover_art": true}, Eq{"album_id": ids}}).
|
||||
|
@ -149,6 +149,23 @@ func (r *albumRepository) getEmbeddedCovers(ids []string) (map[string]model.Medi
|
|||
return result, nil
|
||||
}
|
||||
|
||||
func (r *albumRepository) getGenresForAlbums(ids []string) (map[string]model.Genres, error) {
|
||||
sql := Select("mf.album_id", "group_concat(mfg.genre_id, ' ') as genre").From("media_file_genres mfg").
|
||||
LeftJoin("media_file mf on mf.id = mfg.media_file_id").
|
||||
Where(Eq{"mf.album_id": ids}).GroupBy("mf.album_id")
|
||||
var mfs model.MediaFiles
|
||||
err := r.queryAll(sql, &mfs)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
result := map[string]model.Genres{}
|
||||
for _, mf := range mfs {
|
||||
result[mf.AlbumID] = getGenres(mf.Genre)
|
||||
}
|
||||
return result, nil
|
||||
}
|
||||
|
||||
func (r *albumRepository) Refresh(ids ...string) error {
|
||||
chunks := utils.BreakUpStringSlice(ids, 100)
|
||||
for _, chunk := range chunks {
|
||||
|
@ -168,7 +185,6 @@ type refreshAlbum struct {
|
|||
SongArtists string
|
||||
SongArtistIds string
|
||||
AlbumArtistIds string
|
||||
GenreIds string
|
||||
Years string
|
||||
DiscSubtitles string
|
||||
Comments string
|
||||
|
@ -195,8 +211,7 @@ func (r *albumRepository) refresh(ids ...string) error {
|
|||
group_concat(f.artist, ' ') as song_artists,
|
||||
group_concat(f.artist_id, ' ') as song_artist_ids,
|
||||
group_concat(f.album_artist_id, ' ') as album_artist_ids,
|
||||
group_concat(f.year, ' ') as years,
|
||||
(select group_concat(genre_id, ' ') from media_file_genres where media_file_id = f.id) as genre_ids`).
|
||||
group_concat(f.year, ' ') as years`).
|
||||
From("media_file f").
|
||||
LeftJoin("album a on f.album_id = a.id").
|
||||
Where(Eq{"f.album_id": ids}).GroupBy("f.album_id")
|
||||
|
@ -205,7 +220,12 @@ func (r *albumRepository) refresh(ids ...string) error {
|
|||
return err
|
||||
}
|
||||
|
||||
covers, err := r.getEmbeddedCovers(ids)
|
||||
covers, err := r.getEmbeddedCoversForAlbums(ids)
|
||||
if err != nil {
|
||||
return nil
|
||||
}
|
||||
|
||||
allGenres, err := r.getGenresForAlbums(ids)
|
||||
if err != nil {
|
||||
return nil
|
||||
}
|
||||
|
@ -218,7 +238,6 @@ func (r *albumRepository) refresh(ids ...string) error {
|
|||
al.CoverArtId = embedded.ID
|
||||
al.CoverArtPath = embedded.Path
|
||||
}
|
||||
|
||||
if !hasCoverArt || !strings.HasPrefix(conf.Server.CoverArtPriority, "embedded") {
|
||||
if path := getCoverFromPath(al.Path, al.CoverArtPath); path != "" {
|
||||
al.CoverArtId = "al-" + al.ID
|
||||
|
@ -252,7 +271,7 @@ func (r *albumRepository) refresh(ids ...string) error {
|
|||
al.AllArtistIDs = utils.SanitizeStrings(al.SongArtistIds, al.AlbumArtistID, al.ArtistID)
|
||||
al.FullText = getFullText(al.Name, al.Artist, al.AlbumArtist, al.SongArtists,
|
||||
al.SortAlbumName, al.SortArtistName, al.SortAlbumArtistName, al.DiscSubtitles)
|
||||
al.Genres = getGenres(al.GenreIds)
|
||||
al.Genres = allGenres[al.ID]
|
||||
err := r.Put(&al.Album)
|
||||
if err != nil {
|
||||
return err
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue