mirror of
https://github.com/navidrome/navidrome.git
synced 2025-04-05 13:37:38 +03:00
refactor: removed unused code, unnecessary typecasts and fixed small warnings
This commit is contained in:
parent
270b0ae74e
commit
f6e448c1ba
10 changed files with 8 additions and 162 deletions
|
@ -37,7 +37,7 @@ func (b *browser) MediaFolders(ctx context.Context) (model.MediaFolders, error)
|
||||||
|
|
||||||
func (b *browser) Indexes(ctx context.Context, mediaFolderId string, ifModifiedSince time.Time) (model.ArtistIndexes, time.Time, error) {
|
func (b *browser) Indexes(ctx context.Context, mediaFolderId string, ifModifiedSince time.Time) (model.ArtistIndexes, time.Time, error) {
|
||||||
// TODO Proper handling of mediaFolderId param
|
// TODO Proper handling of mediaFolderId param
|
||||||
folder, err := b.ds.MediaFolder(ctx).Get(mediaFolderId)
|
folder, _ := b.ds.MediaFolder(ctx).Get(mediaFolderId)
|
||||||
|
|
||||||
l, err := b.ds.Property(ctx).DefaultGet(model.PropLastScan+"-"+folder.Path, "-1")
|
l, err := b.ds.Property(ctx).DefaultGet(model.PropLastScan+"-"+folder.Path, "-1")
|
||||||
ms, _ := strconv.ParseInt(l, 10, 64)
|
ms, _ := strconv.ParseInt(l, 10, 64)
|
||||||
|
|
|
@ -1,86 +0,0 @@
|
||||||
package engine
|
|
||||||
|
|
||||||
import (
|
|
||||||
"errors"
|
|
||||||
"time"
|
|
||||||
)
|
|
||||||
|
|
||||||
func CreateMockNowPlayingRepo() *MockNowPlaying {
|
|
||||||
return &MockNowPlaying{}
|
|
||||||
}
|
|
||||||
|
|
||||||
type MockNowPlaying struct {
|
|
||||||
NowPlayingRepository
|
|
||||||
data []NowPlayingInfo
|
|
||||||
t time.Time
|
|
||||||
err bool
|
|
||||||
}
|
|
||||||
|
|
||||||
func (m *MockNowPlaying) SetError(err bool) {
|
|
||||||
m.err = err
|
|
||||||
}
|
|
||||||
|
|
||||||
func (m *MockNowPlaying) Enqueue(info *NowPlayingInfo) error {
|
|
||||||
if m.err {
|
|
||||||
return errors.New("Error!")
|
|
||||||
}
|
|
||||||
|
|
||||||
m.data = append(m.data, NowPlayingInfo{})
|
|
||||||
copy(m.data[1:], m.data[0:])
|
|
||||||
m.data[0] = *info
|
|
||||||
|
|
||||||
if !m.t.IsZero() {
|
|
||||||
m.data[0].Start = m.t
|
|
||||||
m.t = time.Time{}
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (m *MockNowPlaying) Dequeue(playerId int) (*NowPlayingInfo, error) {
|
|
||||||
if len(m.data) == 0 {
|
|
||||||
return nil, nil
|
|
||||||
}
|
|
||||||
l := len(m.data)
|
|
||||||
info := m.data[l-1]
|
|
||||||
m.data = m.data[:l-1]
|
|
||||||
|
|
||||||
return &info, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (m *MockNowPlaying) Count(playerId int) (int64, error) {
|
|
||||||
return int64(len(m.data)), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (m *MockNowPlaying) GetAll() ([]*NowPlayingInfo, error) {
|
|
||||||
np, err := m.Head(1)
|
|
||||||
if np == nil || err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return []*NowPlayingInfo{np}, err
|
|
||||||
}
|
|
||||||
|
|
||||||
func (m *MockNowPlaying) Head(playerId int) (*NowPlayingInfo, error) {
|
|
||||||
if len(m.data) == 0 {
|
|
||||||
return nil, nil
|
|
||||||
}
|
|
||||||
info := m.data[0]
|
|
||||||
return &info, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (m *MockNowPlaying) Tail(playerId int) (*NowPlayingInfo, error) {
|
|
||||||
if len(m.data) == 0 {
|
|
||||||
return nil, nil
|
|
||||||
}
|
|
||||||
info := m.data[len(m.data)-1]
|
|
||||||
return &info, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (m *MockNowPlaying) ClearAll() {
|
|
||||||
m.data = make([]NowPlayingInfo, 0)
|
|
||||||
m.err = false
|
|
||||||
}
|
|
||||||
|
|
||||||
func (m *MockNowPlaying) OverrideNow(t time.Time) {
|
|
||||||
m.t = t
|
|
||||||
}
|
|
|
@ -1,46 +0,0 @@
|
||||||
package engine
|
|
||||||
|
|
||||||
import (
|
|
||||||
"errors"
|
|
||||||
|
|
||||||
"github.com/deluan/navidrome/model"
|
|
||||||
)
|
|
||||||
|
|
||||||
func CreateMockPropertyRepo() *MockProperty {
|
|
||||||
return &MockProperty{data: make(map[string]string)}
|
|
||||||
}
|
|
||||||
|
|
||||||
type MockProperty struct {
|
|
||||||
model.PropertyRepository
|
|
||||||
data map[string]string
|
|
||||||
err bool
|
|
||||||
}
|
|
||||||
|
|
||||||
func (m *MockProperty) SetError(err bool) {
|
|
||||||
m.err = err
|
|
||||||
}
|
|
||||||
|
|
||||||
func (m *MockProperty) Put(id string, value string) error {
|
|
||||||
if m.err {
|
|
||||||
return errors.New("Error!")
|
|
||||||
}
|
|
||||||
m.data[id] = value
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (m *MockProperty) Get(id string) (string, error) {
|
|
||||||
if m.err {
|
|
||||||
return "", errors.New("Error!")
|
|
||||||
}
|
|
||||||
return m.data[id], nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (m *MockProperty) DefaultGet(id string, defaultValue string) (string, error) {
|
|
||||||
v, err := m.Get(id)
|
|
||||||
|
|
||||||
if v == "" {
|
|
||||||
v = defaultValue
|
|
||||||
}
|
|
||||||
|
|
||||||
return v, err
|
|
||||||
}
|
|
|
@ -73,15 +73,15 @@ func (p *playlists) Delete(ctx context.Context, playlistId string) error {
|
||||||
|
|
||||||
func (p *playlists) Update(ctx context.Context, playlistId string, name *string, idsToAdd []string, idxToRemove []int) error {
|
func (p *playlists) Update(ctx context.Context, playlistId string, name *string, idsToAdd []string, idxToRemove []int) error {
|
||||||
pls, err := p.ds.Playlist(ctx).Get(playlistId)
|
pls, err := p.ds.Playlist(ctx).Get(playlistId)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
owner := p.getUser(ctx)
|
owner := p.getUser(ctx)
|
||||||
if owner != pls.Owner {
|
if owner != pls.Owner {
|
||||||
return model.ErrNotAuthorized
|
return model.ErrNotAuthorized
|
||||||
}
|
}
|
||||||
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
if name != nil {
|
if name != nil {
|
||||||
pls.Name = *name
|
pls.Name = *name
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,7 +3,6 @@ package persistence
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"reflect"
|
"reflect"
|
||||||
"sync"
|
|
||||||
|
|
||||||
"github.com/astaxie/beego/orm"
|
"github.com/astaxie/beego/orm"
|
||||||
"github.com/deluan/navidrome/db"
|
"github.com/deluan/navidrome/db"
|
||||||
|
@ -11,10 +10,6 @@ import (
|
||||||
"github.com/deluan/navidrome/model"
|
"github.com/deluan/navidrome/model"
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
|
||||||
once sync.Once
|
|
||||||
)
|
|
||||||
|
|
||||||
type SQLStore struct {
|
type SQLStore struct {
|
||||||
orm orm.Ormer
|
orm orm.Ormer
|
||||||
}
|
}
|
||||||
|
|
|
@ -71,7 +71,7 @@ func (r *playlistRepository) GetWithTracks(id string) (*model.Playlist, error) {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
pls.Duration += mf.Duration
|
pls.Duration += mf.Duration
|
||||||
newTracks = append(newTracks, model.MediaFile(*mf))
|
newTracks = append(newTracks, *mf)
|
||||||
}
|
}
|
||||||
pls.Tracks = newTracks
|
pls.Tracks = newTracks
|
||||||
return pls, err
|
return pls, err
|
||||||
|
|
|
@ -8,11 +8,6 @@ import (
|
||||||
"github.com/deluan/navidrome/model"
|
"github.com/deluan/navidrome/model"
|
||||||
)
|
)
|
||||||
|
|
||||||
type property struct {
|
|
||||||
ID string `orm:"pk;column(id)"`
|
|
||||||
Value string
|
|
||||||
}
|
|
||||||
|
|
||||||
type propertyRepository struct {
|
type propertyRepository struct {
|
||||||
sqlRepository
|
sqlRepository
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,18 +10,6 @@ import (
|
||||||
"github.com/google/uuid"
|
"github.com/google/uuid"
|
||||||
)
|
)
|
||||||
|
|
||||||
type annotation struct {
|
|
||||||
AnnID string `json:"annID" orm:"pk;column(ann_id)"`
|
|
||||||
UserID string `json:"userID" orm:"pk;column(user_id)"`
|
|
||||||
ItemID string `json:"itemID" orm:"pk;column(item_id)"`
|
|
||||||
ItemType string `json:"itemType"`
|
|
||||||
PlayCount int `json:"playCount"`
|
|
||||||
PlayDate time.Time `json:"playDate"`
|
|
||||||
Rating int `json:"rating"`
|
|
||||||
Starred bool `json:"starred"`
|
|
||||||
StarredAt time.Time `json:"starredAt"`
|
|
||||||
}
|
|
||||||
|
|
||||||
const annotationTable = "annotation"
|
const annotationTable = "annotation"
|
||||||
|
|
||||||
func (r sqlRepository) newSelectWithAnnotation(idField string, options ...model.QueryOptions) SelectBuilder {
|
func (r sqlRepository) newSelectWithAnnotation(idField string, options ...model.QueryOptions) SelectBuilder {
|
||||||
|
|
|
@ -46,10 +46,10 @@ func (s *ChangeDetector) Scan(lastModifiedSince time.Time) (changed []string, de
|
||||||
|
|
||||||
func (s *ChangeDetector) loadDir(dirPath string) (children []string, lastUpdated time.Time, err error) {
|
func (s *ChangeDetector) loadDir(dirPath string) (children []string, lastUpdated time.Time, err error) {
|
||||||
dir, err := os.Open(dirPath)
|
dir, err := os.Open(dirPath)
|
||||||
defer dir.Close()
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
defer dir.Close()
|
||||||
dirInfo, err := os.Stat(dirPath)
|
dirInfo, err := os.Stat(dirPath)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return
|
return
|
||||||
|
|
|
@ -6,13 +6,13 @@ import (
|
||||||
|
|
||||||
func TestLongestCommonPrefix(t *testing.T) {
|
func TestLongestCommonPrefix(t *testing.T) {
|
||||||
expected := "/Music/iTunes 1/iTunes Media/Music/"
|
expected := "/Music/iTunes 1/iTunes Media/Music/"
|
||||||
actual := LongestCommonPrefix(test_strings)
|
actual := LongestCommonPrefix(testStrings)
|
||||||
if actual != expected {
|
if actual != expected {
|
||||||
t.Errorf("Couldn't find longest common prefix: want '%s', got '%s'", expected, actual)
|
t.Errorf("Couldn't find longest common prefix: want '%s', got '%s'", expected, actual)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
var test_strings = []string{
|
var testStrings = []string{
|
||||||
"/Music/iTunes 1/iTunes Media/Music/ABBA/Gold_ Greatest Hits/Dancing Queen.m4a",
|
"/Music/iTunes 1/iTunes Media/Music/ABBA/Gold_ Greatest Hits/Dancing Queen.m4a",
|
||||||
"/Music/iTunes 1/iTunes Media/Music/ABBA/Gold_ Greatest Hits/Mamma Mia.m4a",
|
"/Music/iTunes 1/iTunes Media/Music/ABBA/Gold_ Greatest Hits/Mamma Mia.m4a",
|
||||||
"/Music/iTunes 1/iTunes Media/Music/Art Blakey/A Night At Birdland, Vol. 1/01 Annoucement By Pee Wee Marquette.m4a",
|
"/Music/iTunes 1/iTunes Media/Music/Art Blakey/A Night At Birdland, Vol. 1/01 Annoucement By Pee Wee Marquette.m4a",
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue