navidrome/persistence/playlist_repository.go

141 lines
3.2 KiB
Go
Raw Normal View History

package persistence
2020-01-13 03:59:06 +01:00
import (
"context"
2020-01-13 03:59:06 +01:00
"strings"
"time"
2020-01-13 03:59:06 +01:00
. "github.com/Masterminds/squirrel"
2020-01-13 03:59:06 +01:00
"github.com/astaxie/beego/orm"
"github.com/deluan/navidrome/log"
2020-01-24 01:44:08 +01:00
"github.com/deluan/navidrome/model"
2020-01-13 03:59:06 +01:00
)
2020-01-18 03:03:54 +01:00
type playlist struct {
ID string `orm:"column(id)"`
Name string
Comment string
Duration float32
Owner string
Public bool
Tracks string
CreatedAt time.Time
UpdatedAt time.Time
2020-01-13 03:59:06 +01:00
}
type playlistRepository struct {
sqlRepository
}
func NewPlaylistRepository(ctx context.Context, o orm.Ormer) model.PlaylistRepository {
2020-01-13 03:59:06 +01:00
r := &playlistRepository{}
r.ctx = ctx
r.ormer = o
2020-01-13 06:04:11 +01:00
r.tableName = "playlist"
2020-01-13 03:59:06 +01:00
return r
}
func (r *playlistRepository) CountAll() (int64, error) {
return r.count(Select())
}
func (r *playlistRepository) Exists(id string) (bool, error) {
return r.exists(Select().Where(Eq{"id": id}))
}
func (r *playlistRepository) Delete(id string) error {
return r.delete(Eq{"id": id})
}
2020-01-15 04:22:34 +01:00
func (r *playlistRepository) Put(p *model.Playlist) error {
if p.ID == "" {
p.CreatedAt = time.Now()
}
p.UpdatedAt = time.Now()
pls := r.fromModel(p)
_, err := r.put(pls.ID, pls)
return err
2020-01-13 03:59:06 +01:00
}
2020-01-15 04:22:34 +01:00
func (r *playlistRepository) Get(id string) (*model.Playlist, error) {
sel := r.newSelect().Columns("*").Where(Eq{"id": id})
var res playlist
err := r.queryOne(sel, &res)
pls := r.toModel(&res)
return &pls, err
}
2020-01-15 04:22:34 +01:00
func (r *playlistRepository) GetAll(options ...model.QueryOptions) (model.Playlists, error) {
sel := r.newSelect(options...).Columns("*")
var res []playlist
err := r.queryAll(sel, &res)
return r.toModels(res), err
2020-01-13 03:59:06 +01:00
}
func (r *playlistRepository) toModels(all []playlist) model.Playlists {
2020-01-15 04:22:34 +01:00
result := make(model.Playlists, len(all))
2020-01-13 03:59:06 +01:00
for i, p := range all {
2020-01-21 23:50:56 +01:00
result[i] = r.toModel(&p)
2020-01-13 03:59:06 +01:00
}
return result
2020-01-13 03:59:06 +01:00
}
2020-01-21 23:50:56 +01:00
func (r *playlistRepository) toModel(p *playlist) model.Playlist {
pls := model.Playlist{
ID: p.ID,
Name: p.Name,
Comment: p.Comment,
Duration: p.Duration,
Owner: p.Owner,
Public: p.Public,
CreatedAt: p.CreatedAt,
UpdatedAt: p.UpdatedAt,
2020-01-13 03:59:06 +01:00
}
if strings.TrimSpace(p.Tracks) != "" {
tracks := strings.Split(p.Tracks, ",")
for _, t := range tracks {
pls.Tracks = append(pls.Tracks, model.MediaFile{ID: t})
}
}
pls.Tracks = r.loadTracks(&pls)
return pls
2020-01-13 03:59:06 +01:00
}
2020-01-21 23:50:56 +01:00
func (r *playlistRepository) fromModel(p *model.Playlist) playlist {
pls := playlist{
ID: p.ID,
Name: p.Name,
Comment: p.Comment,
Owner: p.Owner,
Public: p.Public,
CreatedAt: p.CreatedAt,
UpdatedAt: p.UpdatedAt,
2020-01-13 03:59:06 +01:00
}
p.Tracks = r.loadTracks(p)
var newTracks []string
for _, t := range p.Tracks {
newTracks = append(newTracks, t.ID)
pls.Duration += t.Duration
}
pls.Tracks = strings.Join(newTracks, ",")
return pls
2020-01-13 03:59:06 +01:00
}
func (r *playlistRepository) loadTracks(p *model.Playlist) model.MediaFiles {
mfRepo := NewMediaFileRepository(r.ctx, r.ormer)
var ids []string
for _, t := range p.Tracks {
ids = append(ids, t.ID)
}
idsFilter := Eq{"id": ids}
tracks, err := mfRepo.GetAll(model.QueryOptions{Filters: idsFilter})
if err == nil {
return tracks
} else {
log.Error(r.ctx, "Could not load playlist's tracks", "playlistName", p.Name, "playlistId", p.ID, err)
}
return nil
}
2020-01-15 04:22:34 +01:00
var _ model.PlaylistRepository = (*playlistRepository)(nil)