2020-01-15 23:49:09 +01:00
|
|
|
package persistence
|
|
|
|
|
|
|
|
import (
|
2020-01-28 14:22:17 +01:00
|
|
|
"context"
|
2020-01-15 23:49:09 +01:00
|
|
|
|
2021-07-16 01:53:40 +02:00
|
|
|
"github.com/deluan/rest"
|
|
|
|
|
2020-01-28 14:22:17 +01:00
|
|
|
. "github.com/Masterminds/squirrel"
|
2020-01-15 23:49:09 +01:00
|
|
|
"github.com/astaxie/beego/orm"
|
2020-01-24 01:44:08 +01:00
|
|
|
"github.com/navidrome/navidrome/model"
|
2020-01-15 23:49:09 +01:00
|
|
|
)
|
|
|
|
|
2020-01-19 21:37:41 +01:00
|
|
|
type genreRepository struct {
|
2020-01-28 14:22:17 +01:00
|
|
|
sqlRepository
|
2021-07-16 01:53:40 +02:00
|
|
|
sqlRestful
|
2020-01-19 21:37:41 +01:00
|
|
|
}
|
2020-01-15 23:49:09 +01:00
|
|
|
|
2020-01-28 14:22:17 +01:00
|
|
|
func NewGenreRepository(ctx context.Context, o orm.Ormer) model.GenreRepository {
|
|
|
|
r := &genreRepository{}
|
|
|
|
r.ctx = ctx
|
|
|
|
r.ormer = o
|
2021-07-16 01:53:40 +02:00
|
|
|
r.tableName = "genre"
|
2020-01-28 14:22:17 +01:00
|
|
|
return r
|
2020-01-15 23:49:09 +01:00
|
|
|
}
|
|
|
|
|
2021-07-16 01:53:40 +02:00
|
|
|
func (r *genreRepository) GetAll() (model.Genres, error) {
|
2021-07-16 17:03:28 +02:00
|
|
|
sq := Select("*",
|
2021-07-16 23:15:34 +02:00
|
|
|
"count(distinct a.album_id) as album_count",
|
2021-07-16 17:03:28 +02:00
|
|
|
"count(distinct f.media_file_id) as song_count").
|
|
|
|
From(r.tableName).
|
2021-07-16 23:15:34 +02:00
|
|
|
LeftJoin("album_genres a on a.genre_id = genre.id").
|
2021-07-16 17:03:28 +02:00
|
|
|
LeftJoin("media_file_genres f on f.genre_id = genre.id").
|
|
|
|
GroupBy("genre.id")
|
2020-01-31 22:47:13 +01:00
|
|
|
res := model.Genres{}
|
2020-02-01 20:48:22 +01:00
|
|
|
err := r.queryAll(sq, &res)
|
2020-01-28 14:22:17 +01:00
|
|
|
return res, err
|
2020-01-15 23:49:09 +01:00
|
|
|
}
|
2021-07-16 01:53:40 +02:00
|
|
|
|
|
|
|
func (r *genreRepository) Put(m *model.Genre) error {
|
2021-07-16 17:03:28 +02:00
|
|
|
id, err := r.put(m.ID, m)
|
|
|
|
m.ID = id
|
2021-07-16 01:53:40 +02:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *genreRepository) Count(options ...rest.QueryOptions) (int64, error) {
|
|
|
|
return r.count(Select(), r.parseRestOptions(options...))
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *genreRepository) Read(id string) (interface{}, error) {
|
|
|
|
sel := r.newSelect().Columns("*").Where(Eq{"id": id})
|
|
|
|
var res model.Genre
|
|
|
|
err := r.queryOne(sel, &res)
|
|
|
|
return &res, err
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *genreRepository) ReadAll(options ...rest.QueryOptions) (interface{}, error) {
|
|
|
|
sel := r.newSelect(r.parseRestOptions(options...)).Columns("*")
|
|
|
|
res := model.Genres{}
|
|
|
|
err := r.queryAll(sel, &res)
|
|
|
|
return res, err
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *genreRepository) EntityName() string {
|
|
|
|
return r.tableName
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *genreRepository) NewInstance() interface{} {
|
|
|
|
return &model.Genre{}
|
|
|
|
}
|
|
|
|
|
|
|
|
var _ model.GenreRepository = (*genreRepository)(nil)
|
|
|
|
var _ model.ResourceRepository = (*genreRepository)(nil)
|