mirror of
https://github.com/navidrome/navidrome.git
synced 2025-04-05 05:27:37 +03:00
Refactoring to a cleaner architecture
This commit is contained in:
parent
74478ce6f9
commit
272a499c7e
27 changed files with 120 additions and 120 deletions
|
@ -2,18 +2,18 @@ package api
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/astaxie/beego"
|
"github.com/astaxie/beego"
|
||||||
"github.com/deluan/gosonic/repositories"
|
|
||||||
"github.com/deluan/gosonic/utils"
|
"github.com/deluan/gosonic/utils"
|
||||||
"github.com/karlkfi/inject"
|
"github.com/karlkfi/inject"
|
||||||
"github.com/deluan/gosonic/api/responses"
|
"github.com/deluan/gosonic/api/responses"
|
||||||
"github.com/deluan/gosonic/consts"
|
"github.com/deluan/gosonic/consts"
|
||||||
"strconv"
|
"strconv"
|
||||||
|
"github.com/deluan/gosonic/domain"
|
||||||
)
|
)
|
||||||
|
|
||||||
type GetIndexesController struct {
|
type GetIndexesController struct {
|
||||||
beego.Controller
|
beego.Controller
|
||||||
repo repositories.ArtistIndex
|
repo domain.ArtistIndexRepository
|
||||||
properties repositories.Property
|
properties domain.PropertyRepository
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *GetIndexesController) Prepare() {
|
func (c *GetIndexesController) Prepare() {
|
||||||
|
|
|
@ -6,11 +6,11 @@ import (
|
||||||
"github.com/deluan/gosonic/utils"
|
"github.com/deluan/gosonic/utils"
|
||||||
. "github.com/smartystreets/goconvey/convey"
|
. "github.com/smartystreets/goconvey/convey"
|
||||||
"github.com/deluan/gosonic/tests"
|
"github.com/deluan/gosonic/tests"
|
||||||
"github.com/deluan/gosonic/repositories"
|
|
||||||
"encoding/xml"
|
"encoding/xml"
|
||||||
"github.com/deluan/gosonic/api/responses"
|
"github.com/deluan/gosonic/api/responses"
|
||||||
"github.com/deluan/gosonic/consts"
|
"github.com/deluan/gosonic/consts"
|
||||||
"github.com/deluan/gosonic/tests/mocks"
|
"github.com/deluan/gosonic/tests/mocks"
|
||||||
|
"github.com/deluan/gosonic/domain"
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
|
@ -20,11 +20,11 @@ const (
|
||||||
func TestGetIndexes(t *testing.T) {
|
func TestGetIndexes(t *testing.T) {
|
||||||
tests.Init(t, false)
|
tests.Init(t, false)
|
||||||
mockRepo := mocks.CreateMockArtistIndexRepo()
|
mockRepo := mocks.CreateMockArtistIndexRepo()
|
||||||
utils.DefineSingleton(new(repositories.ArtistIndex), func() repositories.ArtistIndex {
|
utils.DefineSingleton(new(domain.ArtistIndexRepository), func() domain.ArtistIndexRepository {
|
||||||
return mockRepo
|
return mockRepo
|
||||||
})
|
})
|
||||||
propRepo := mocks.CreateMockPropertyRepo()
|
propRepo := mocks.CreateMockPropertyRepo()
|
||||||
utils.DefineSingleton(new(repositories.Property), func() repositories.Property {
|
utils.DefineSingleton(new(domain.PropertyRepository), func() domain.PropertyRepository {
|
||||||
return propRepo
|
return propRepo
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
|
@ -3,13 +3,13 @@ package api
|
||||||
import (
|
import (
|
||||||
"github.com/astaxie/beego"
|
"github.com/astaxie/beego"
|
||||||
"github.com/deluan/gosonic/api/responses"
|
"github.com/deluan/gosonic/api/responses"
|
||||||
"github.com/deluan/gosonic/repositories"
|
"github.com/deluan/gosonic/persistence"
|
||||||
)
|
)
|
||||||
|
|
||||||
type GetMusicFoldersController struct{ beego.Controller }
|
type GetMusicFoldersController struct{ beego.Controller }
|
||||||
|
|
||||||
func (c *GetMusicFoldersController) Get() {
|
func (c *GetMusicFoldersController) Get() {
|
||||||
repository := repositories.NewMediaFolderRepository()
|
repository := persistence.NewMediaFolderRepository()
|
||||||
mediaFolderList, _ := repository.GetAll()
|
mediaFolderList, _ := repository.GetAll()
|
||||||
folders := make([]responses.MusicFolder, len(mediaFolderList))
|
folders := make([]responses.MusicFolder, len(mediaFolderList))
|
||||||
for i, f := range mediaFolderList {
|
for i, f := range mediaFolderList {
|
||||||
|
|
|
@ -2,10 +2,11 @@ package conf
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/deluan/gosonic/utils"
|
"github.com/deluan/gosonic/utils"
|
||||||
"github.com/deluan/gosonic/repositories"
|
"github.com/deluan/gosonic/persistence"
|
||||||
|
"github.com/deluan/gosonic/domain"
|
||||||
)
|
)
|
||||||
|
|
||||||
func init () {
|
func init () {
|
||||||
utils.DefineSingleton(new(repositories.ArtistIndex), repositories.NewArtistIndexRepository)
|
utils.DefineSingleton(new(domain.ArtistIndexRepository), persistence.NewArtistIndexRepository)
|
||||||
utils.DefineSingleton(new(repositories.Property), repositories.NewPropertyRepository)
|
utils.DefineSingleton(new(domain.PropertyRepository), persistence.NewPropertyRepository)
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
package models
|
package domain
|
||||||
|
|
||||||
type Album struct {
|
type Album struct {
|
||||||
Id string
|
Id string
|
|
@ -1,4 +1,4 @@
|
||||||
package models
|
package domain
|
||||||
|
|
||||||
type Artist struct {
|
type Artist struct {
|
||||||
Id string
|
Id string
|
18
domain/index.go
Normal file
18
domain/index.go
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
package domain
|
||||||
|
|
||||||
|
type ArtistInfo struct {
|
||||||
|
ArtistId string
|
||||||
|
Artist string
|
||||||
|
}
|
||||||
|
|
||||||
|
type ArtistIndex struct {
|
||||||
|
Id string
|
||||||
|
Artists []ArtistInfo
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
type ArtistIndexRepository interface {
|
||||||
|
Put(m *ArtistIndex) error
|
||||||
|
Get(id string) (*ArtistIndex, error)
|
||||||
|
GetAll() ([]ArtistIndex, error)
|
||||||
|
}
|
|
@ -1,4 +1,4 @@
|
||||||
package models
|
package domain
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"time"
|
"time"
|
|
@ -1,4 +1,4 @@
|
||||||
package models
|
package domain
|
||||||
|
|
||||||
type MediaFolder struct {
|
type MediaFolder struct {
|
||||||
Id string
|
Id string
|
13
domain/property.go
Normal file
13
domain/property.go
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
package domain
|
||||||
|
|
||||||
|
type Property struct {
|
||||||
|
Id string
|
||||||
|
Value string
|
||||||
|
}
|
||||||
|
|
||||||
|
type PropertyRepository interface {
|
||||||
|
Put(id string, value string) error
|
||||||
|
Get(id string) (string, error)
|
||||||
|
DefaultGet(id string, defaultValue string) (string, error)
|
||||||
|
}
|
||||||
|
|
|
@ -1,13 +0,0 @@
|
||||||
package models
|
|
||||||
|
|
||||||
type ArtistInfo struct {
|
|
||||||
ArtistId string
|
|
||||||
Artist string
|
|
||||||
}
|
|
||||||
|
|
||||||
type ArtistIndex struct {
|
|
||||||
Id string
|
|
||||||
Artists []ArtistInfo
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
|
@ -1,6 +0,0 @@
|
||||||
package models
|
|
||||||
|
|
||||||
type Property struct {
|
|
||||||
Id string
|
|
||||||
Value string
|
|
||||||
}
|
|
|
@ -1,7 +1,7 @@
|
||||||
package repositories
|
package persistence
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/deluan/gosonic/models"
|
"github.com/deluan/gosonic/domain"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Album struct {
|
type Album struct {
|
||||||
|
@ -10,19 +10,19 @@ type Album struct {
|
||||||
|
|
||||||
func NewAlbumRepository() *Album {
|
func NewAlbumRepository() *Album {
|
||||||
r := &Album{}
|
r := &Album{}
|
||||||
r.init("album", &models.Album{})
|
r.init("album", &domain.Album{})
|
||||||
return r
|
return r
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *Album) Put(m *models.Album) error {
|
func (r *Album) Put(m *domain.Album) error {
|
||||||
if m.Id == "" {
|
if m.Id == "" {
|
||||||
m.Id = r.NewId(m.ArtistId, m.Name)
|
m.Id = r.NewId(m.ArtistId, m.Name)
|
||||||
}
|
}
|
||||||
return r.saveOrUpdate(m.Id, m)
|
return r.saveOrUpdate(m.Id, m)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *Album) Get(id string) (*models.Album, error) {
|
func (r *Album) Get(id string) (*domain.Album, error) {
|
||||||
var rec interface{}
|
var rec interface{}
|
||||||
rec, err := r.readEntity(id)
|
rec, err := r.readEntity(id)
|
||||||
return rec.(*models.Album), err
|
return rec.(*domain.Album), err
|
||||||
}
|
}
|
|
@ -1,7 +1,7 @@
|
||||||
package repositories
|
package persistence
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/deluan/gosonic/models"
|
"github.com/deluan/gosonic/domain"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Artist struct {
|
type Artist struct {
|
||||||
|
@ -10,24 +10,24 @@ type Artist struct {
|
||||||
|
|
||||||
func NewArtistRepository() *Artist {
|
func NewArtistRepository() *Artist {
|
||||||
r := &Artist{}
|
r := &Artist{}
|
||||||
r.init("artist", &models.Artist{})
|
r.init("artist", &domain.Artist{})
|
||||||
return r
|
return r
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *Artist) Put(m *models.Artist) error {
|
func (r *Artist) Put(m *domain.Artist) error {
|
||||||
if m.Id == "" {
|
if m.Id == "" {
|
||||||
m.Id = r.NewId(m.Name)
|
m.Id = r.NewId(m.Name)
|
||||||
}
|
}
|
||||||
return r.saveOrUpdate(m.Id, m)
|
return r.saveOrUpdate(m.Id, m)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *Artist) Get(id string) (*models.Artist, error) {
|
func (r *Artist) Get(id string) (*domain.Artist, error) {
|
||||||
var rec interface{}
|
var rec interface{}
|
||||||
rec, err := r.readEntity(id)
|
rec, err := r.readEntity(id)
|
||||||
return rec.(*models.Artist), err
|
return rec.(*domain.Artist), err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *Artist) GetByName(name string) (*models.Artist, error) {
|
func (r *Artist) GetByName(name string) (*domain.Artist, error) {
|
||||||
id := r.NewId(name)
|
id := r.NewId(name)
|
||||||
return r.Get(id)
|
return r.Get(id)
|
||||||
}
|
}
|
|
@ -1,4 +1,4 @@
|
||||||
package repositories
|
package persistence
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
|
@ -1,4 +1,4 @@
|
||||||
package repositories
|
package persistence
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"testing"
|
"testing"
|
|
@ -1,29 +1,23 @@
|
||||||
package repositories
|
package persistence
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/deluan/gosonic/models"
|
"github.com/deluan/gosonic/domain"
|
||||||
"errors"
|
"errors"
|
||||||
"sort"
|
"sort"
|
||||||
"github.com/deluan/gosonic/utils"
|
"github.com/deluan/gosonic/utils"
|
||||||
)
|
)
|
||||||
|
|
||||||
type ArtistIndex interface {
|
|
||||||
Put(m *models.ArtistIndex) error
|
|
||||||
Get(id string) (*models.ArtistIndex, error)
|
|
||||||
GetAll() ([]models.ArtistIndex, error)
|
|
||||||
}
|
|
||||||
|
|
||||||
type artistIndex struct {
|
type artistIndex struct {
|
||||||
BaseRepository
|
BaseRepository
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewArtistIndexRepository() ArtistIndex {
|
func NewArtistIndexRepository() domain.ArtistIndexRepository {
|
||||||
r := &artistIndex{}
|
r := &artistIndex{}
|
||||||
r.init("index", &models.ArtistIndex{})
|
r.init("index", &domain.ArtistIndex{})
|
||||||
return r
|
return r
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *artistIndex) Put(m *models.ArtistIndex) error {
|
func (r *artistIndex) Put(m *domain.ArtistIndex) error {
|
||||||
if m.Id == "" {
|
if m.Id == "" {
|
||||||
return errors.New("Id is not set")
|
return errors.New("Id is not set")
|
||||||
}
|
}
|
||||||
|
@ -31,19 +25,19 @@ func (r *artistIndex) Put(m *models.ArtistIndex) error {
|
||||||
return r.saveOrUpdate(m.Id, m)
|
return r.saveOrUpdate(m.Id, m)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *artistIndex) Get(id string) (*models.ArtistIndex, error) {
|
func (r *artistIndex) Get(id string) (*domain.ArtistIndex, error) {
|
||||||
var rec interface{}
|
var rec interface{}
|
||||||
rec, err := r.readEntity(id)
|
rec, err := r.readEntity(id)
|
||||||
return rec.(*models.ArtistIndex), err
|
return rec.(*domain.ArtistIndex), err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *artistIndex) GetAll() ([]models.ArtistIndex, error) {
|
func (r *artistIndex) GetAll() ([]domain.ArtistIndex, error) {
|
||||||
var indices = make([]models.ArtistIndex, 0)
|
var indices = make([]domain.ArtistIndex, 0)
|
||||||
err := r.loadAll(&indices, "")
|
err := r.loadAll(&indices, "")
|
||||||
return indices, err
|
return indices, err
|
||||||
}
|
}
|
||||||
|
|
||||||
type byArtistName []models.ArtistInfo
|
type byArtistName []domain.ArtistInfo
|
||||||
|
|
||||||
func (a byArtistName) Len() int {
|
func (a byArtistName) Len() int {
|
||||||
return len(a)
|
return len(a)
|
|
@ -1,10 +1,10 @@
|
||||||
package repositories
|
package persistence
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"testing"
|
"testing"
|
||||||
. "github.com/smartystreets/goconvey/convey"
|
. "github.com/smartystreets/goconvey/convey"
|
||||||
"github.com/deluan/gosonic/tests"
|
"github.com/deluan/gosonic/tests"
|
||||||
"github.com/deluan/gosonic/models"
|
"github.com/deluan/gosonic/domain"
|
||||||
"strconv"
|
"strconv"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -16,7 +16,7 @@ func TestIndexRepository(t *testing.T) {
|
||||||
repo := NewArtistIndexRepository()
|
repo := NewArtistIndexRepository()
|
||||||
|
|
||||||
Convey("It should be able to read and write to the database", func() {
|
Convey("It should be able to read and write to the database", func() {
|
||||||
i := &models.ArtistIndex{Id: "123"}
|
i := &domain.ArtistIndex{Id: "123"}
|
||||||
|
|
||||||
repo.Put(i)
|
repo.Put(i)
|
||||||
s,_ := repo.Get("123")
|
s,_ := repo.Get("123")
|
||||||
|
@ -24,7 +24,7 @@ func TestIndexRepository(t *testing.T) {
|
||||||
So(s, shouldBeEqual, i)
|
So(s, shouldBeEqual, i)
|
||||||
})
|
})
|
||||||
Convey("Method Put() should return error if Id is not set", func() {
|
Convey("Method Put() should return error if Id is not set", func() {
|
||||||
i := &models.ArtistIndex{}
|
i := &domain.ArtistIndex{}
|
||||||
|
|
||||||
err := repo.Put(i)
|
err := repo.Put(i)
|
||||||
|
|
||||||
|
@ -32,7 +32,7 @@ func TestIndexRepository(t *testing.T) {
|
||||||
})
|
})
|
||||||
Convey("Given that I have 4 records", func() {
|
Convey("Given that I have 4 records", func() {
|
||||||
for i := 1; i <= 4; i++ {
|
for i := 1; i <= 4; i++ {
|
||||||
e := &models.ArtistIndex{Id: strconv.Itoa(i)}
|
e := &domain.ArtistIndex{Id: strconv.Itoa(i)}
|
||||||
repo.Put(e)
|
repo.Put(e)
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
package repositories
|
package persistence
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"sync"
|
"sync"
|
|
@ -1,7 +1,7 @@
|
||||||
package repositories
|
package persistence
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/deluan/gosonic/models"
|
"github.com/deluan/gosonic/domain"
|
||||||
)
|
)
|
||||||
|
|
||||||
type MediaFile struct {
|
type MediaFile struct {
|
||||||
|
@ -10,10 +10,10 @@ type MediaFile struct {
|
||||||
|
|
||||||
func NewMediaFileRepository() *MediaFile {
|
func NewMediaFileRepository() *MediaFile {
|
||||||
r := &MediaFile{}
|
r := &MediaFile{}
|
||||||
r.init("mediafile", &models.MediaFile{})
|
r.init("mediafile", &domain.MediaFile{})
|
||||||
return r
|
return r
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *MediaFile) Put(m *models.MediaFile) error {
|
func (r *MediaFile) Put(m *domain.MediaFile) error {
|
||||||
return r.saveOrUpdate(m.Id, m)
|
return r.saveOrUpdate(m.Id, m)
|
||||||
}
|
}
|
|
@ -1,7 +1,7 @@
|
||||||
package repositories
|
package persistence
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/deluan/gosonic/models"
|
"github.com/deluan/gosonic/domain"
|
||||||
"github.com/astaxie/beego"
|
"github.com/astaxie/beego"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -12,9 +12,9 @@ func NewMediaFolderRepository() *MediaFolder {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
func (*MediaFolder) GetAll() ([]*models.MediaFolder, error) {
|
func (*MediaFolder) GetAll() ([]*domain.MediaFolder, error) {
|
||||||
mediaFolder := models.MediaFolder{Id: "0", Name: "iTunes Library", Path: beego.AppConfig.String("musicFolder")}
|
mediaFolder := domain.MediaFolder{Id: "0", Name: "iTunes Library", Path: beego.AppConfig.String("musicFolder")}
|
||||||
result := make([]*models.MediaFolder, 1)
|
result := make([]*domain.MediaFolder, 1)
|
||||||
result[0] = &mediaFolder
|
result[0] = &mediaFolder
|
||||||
return result, nil
|
return result, nil
|
||||||
}
|
}
|
|
@ -1,28 +1,22 @@
|
||||||
package repositories
|
package persistence
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/deluan/gosonic/models"
|
"github.com/deluan/gosonic/domain"
|
||||||
"errors"
|
"errors"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Property interface {
|
|
||||||
Put(id string, value string) error
|
|
||||||
Get(id string) (string, error)
|
|
||||||
DefaultGet(id string, defaultValue string) (string, error)
|
|
||||||
}
|
|
||||||
|
|
||||||
type property struct {
|
type property struct {
|
||||||
BaseRepository
|
BaseRepository
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewPropertyRepository() *property {
|
func NewPropertyRepository() *property {
|
||||||
r := &property{}
|
r := &property{}
|
||||||
r.init("property", &models.Property{})
|
r.init("property", &domain.Property{})
|
||||||
return r
|
return r
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *property) Put(id string, value string) error {
|
func (r *property) Put(id string, value string) error {
|
||||||
m := &models.Property{Id: id, Value: value}
|
m := &domain.Property{Id: id, Value: value}
|
||||||
if m.Id == "" {
|
if m.Id == "" {
|
||||||
return errors.New("Id is required")
|
return errors.New("Id is required")
|
||||||
}
|
}
|
||||||
|
@ -32,7 +26,7 @@ func (r *property) Put(id string, value string) error {
|
||||||
func (r *property) Get(id string) (string, error) {
|
func (r *property) Get(id string) (string, error) {
|
||||||
var rec interface{}
|
var rec interface{}
|
||||||
rec, err := r.readEntity(id)
|
rec, err := r.readEntity(id)
|
||||||
return rec.(*models.Property).Value, err
|
return rec.(*domain.Property).Value, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r*property) DefaultGet(id string, defaultValue string) (string, error) {
|
func (r*property) DefaultGet(id string, defaultValue string) (string, error) {
|
|
@ -2,8 +2,8 @@ package scanner
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/astaxie/beego"
|
"github.com/astaxie/beego"
|
||||||
"github.com/deluan/gosonic/repositories"
|
"github.com/deluan/gosonic/persistence"
|
||||||
"github.com/deluan/gosonic/models"
|
"github.com/deluan/gosonic/domain"
|
||||||
"strings"
|
"strings"
|
||||||
"github.com/deluan/gosonic/utils"
|
"github.com/deluan/gosonic/utils"
|
||||||
"github.com/deluan/gosonic/consts"
|
"github.com/deluan/gosonic/consts"
|
||||||
|
@ -15,7 +15,7 @@ type Scanner interface {
|
||||||
LoadFolder(path string) []Track
|
LoadFolder(path string) []Track
|
||||||
}
|
}
|
||||||
|
|
||||||
type tempIndex map[string]models.ArtistInfo
|
type tempIndex map[string]domain.ArtistInfo
|
||||||
|
|
||||||
// TODO Implement a flag 'isScanning'.
|
// TODO Implement a flag 'isScanning'.
|
||||||
func StartImport() {
|
func StartImport() {
|
||||||
|
@ -31,9 +31,9 @@ func doImport(mediaFolder string, scanner Scanner) {
|
||||||
|
|
||||||
func importLibrary(files []Track) (err error){
|
func importLibrary(files []Track) (err error){
|
||||||
indexGroups := utils.ParseIndexGroups(beego.AppConfig.String("indexGroups"))
|
indexGroups := utils.ParseIndexGroups(beego.AppConfig.String("indexGroups"))
|
||||||
mfRepo := repositories.NewMediaFileRepository()
|
mfRepo := persistence.NewMediaFileRepository()
|
||||||
albumRepo := repositories.NewAlbumRepository()
|
albumRepo := persistence.NewAlbumRepository()
|
||||||
artistRepo := repositories.NewArtistRepository()
|
artistRepo := persistence.NewArtistRepository()
|
||||||
var artistIndex = make(map[string]tempIndex)
|
var artistIndex = make(map[string]tempIndex)
|
||||||
|
|
||||||
for _, t := range files {
|
for _, t := range files {
|
||||||
|
@ -54,7 +54,7 @@ func importLibrary(files []Track) (err error){
|
||||||
beego.Info("Total MediaFiles in database:", c)
|
beego.Info("Total MediaFiles in database:", c)
|
||||||
|
|
||||||
if err == nil {
|
if err == nil {
|
||||||
propertyRepo := repositories.NewPropertyRepository()
|
propertyRepo := persistence.NewPropertyRepository()
|
||||||
millis := time.Now().UnixNano() / 1000000
|
millis := time.Now().UnixNano() / 1000000
|
||||||
propertyRepo.Put(consts.LastScan, fmt.Sprint(millis))
|
propertyRepo.Put(consts.LastScan, fmt.Sprint(millis))
|
||||||
beego.Info("LastScan timestamp:", millis)
|
beego.Info("LastScan timestamp:", millis)
|
||||||
|
@ -63,8 +63,8 @@ func importLibrary(files []Track) (err error){
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
func parseTrack(t *Track) (*models.MediaFile, *models.Album, *models.Artist) {
|
func parseTrack(t *Track) (*domain.MediaFile, *domain.Album, *domain.Artist) {
|
||||||
mf := &models.MediaFile{
|
mf := &domain.MediaFile{
|
||||||
Id: t.Id,
|
Id: t.Id,
|
||||||
Album: t.Album,
|
Album: t.Album,
|
||||||
Artist: t.Artist,
|
Artist: t.Artist,
|
||||||
|
@ -76,20 +76,20 @@ func parseTrack(t *Track) (*models.MediaFile, *models.Album, *models.Artist) {
|
||||||
UpdatedAt: t.UpdatedAt,
|
UpdatedAt: t.UpdatedAt,
|
||||||
}
|
}
|
||||||
|
|
||||||
album := &models.Album{
|
album := &domain.Album{
|
||||||
Name: t.Album,
|
Name: t.Album,
|
||||||
Year: t.Year,
|
Year: t.Year,
|
||||||
Compilation: t.Compilation,
|
Compilation: t.Compilation,
|
||||||
}
|
}
|
||||||
|
|
||||||
artist := &models.Artist{
|
artist := &domain.Artist{
|
||||||
Name: t.RealArtist(),
|
Name: t.RealArtist(),
|
||||||
}
|
}
|
||||||
|
|
||||||
return mf, album, artist
|
return mf, album, artist
|
||||||
}
|
}
|
||||||
|
|
||||||
func persist(mfRepo *repositories.MediaFile, mf *models.MediaFile, albumRepo *repositories.Album, album *models.Album, artistRepo *repositories.Artist, artist *models.Artist) {
|
func persist(mfRepo *persistence.MediaFile, mf *domain.MediaFile, albumRepo *persistence.Album, album *domain.Album, artistRepo *persistence.Artist, artist *domain.Artist) {
|
||||||
if err := artistRepo.Put(artist); err != nil {
|
if err := artistRepo.Put(artist); err != nil {
|
||||||
beego.Error(err)
|
beego.Error(err)
|
||||||
}
|
}
|
||||||
|
@ -105,7 +105,7 @@ func persist(mfRepo *repositories.MediaFile, mf *models.MediaFile, albumRepo *re
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func collectIndex(ig utils.IndexGroups, a *models.Artist, artistIndex map[string]tempIndex) {
|
func collectIndex(ig utils.IndexGroups, a *domain.Artist, artistIndex map[string]tempIndex) {
|
||||||
name := a.Name
|
name := a.Name
|
||||||
indexName := strings.ToLower(utils.NoArticle(name))
|
indexName := strings.ToLower(utils.NoArticle(name))
|
||||||
if indexName == "" {
|
if indexName == "" {
|
||||||
|
@ -117,7 +117,7 @@ func collectIndex(ig utils.IndexGroups, a *models.Artist, artistIndex map[string
|
||||||
artists = make(tempIndex)
|
artists = make(tempIndex)
|
||||||
artistIndex[group] = artists
|
artistIndex[group] = artists
|
||||||
}
|
}
|
||||||
artists[indexName] = models.ArtistInfo{ArtistId: a.Id, Artist: a.Name}
|
artists[indexName] = domain.ArtistInfo{ArtistId: a.Id, Artist: a.Name}
|
||||||
}
|
}
|
||||||
|
|
||||||
func findGroup(ig utils.IndexGroups, name string) string {
|
func findGroup(ig utils.IndexGroups, name string) string {
|
||||||
|
@ -131,10 +131,10 @@ func findGroup(ig utils.IndexGroups, name string) string {
|
||||||
}
|
}
|
||||||
|
|
||||||
func saveIndex(artistIndex map[string]tempIndex) error {
|
func saveIndex(artistIndex map[string]tempIndex) error {
|
||||||
idxRepo := repositories.NewArtistIndexRepository()
|
idxRepo := persistence.NewArtistIndexRepository()
|
||||||
|
|
||||||
for k, temp := range artistIndex {
|
for k, temp := range artistIndex {
|
||||||
idx := &models.ArtistIndex{Id: k}
|
idx := &domain.ArtistIndex{Id: k}
|
||||||
for _, v := range temp {
|
for _, v := range temp {
|
||||||
idx.Artists = append(idx.Artists, v)
|
idx.Artists = append(idx.Artists, v)
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,7 +4,7 @@ import (
|
||||||
"testing"
|
"testing"
|
||||||
. "github.com/smartystreets/goconvey/convey"
|
. "github.com/smartystreets/goconvey/convey"
|
||||||
"github.com/deluan/gosonic/utils"
|
"github.com/deluan/gosonic/utils"
|
||||||
"github.com/deluan/gosonic/models"
|
"github.com/deluan/gosonic/domain"
|
||||||
"github.com/deluan/gosonic/tests"
|
"github.com/deluan/gosonic/tests"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -14,7 +14,7 @@ func TestCollectIndex(t *testing.T) {
|
||||||
ig := utils.IndexGroups{"A":"A", "B":"B", "Tom":"Tom", "X":"X-Z"}
|
ig := utils.IndexGroups{"A":"A", "B":"B", "Tom":"Tom", "X":"X-Z"}
|
||||||
|
|
||||||
Convey("Simple Name", t, func() {
|
Convey("Simple Name", t, func() {
|
||||||
a := &models.Artist{Name: "Björk"}
|
a := &domain.Artist{Name: "Björk"}
|
||||||
artistIndex := make(map[string]tempIndex)
|
artistIndex := make(map[string]tempIndex)
|
||||||
|
|
||||||
collectIndex(ig, a, artistIndex)
|
collectIndex(ig, a, artistIndex)
|
||||||
|
@ -28,7 +28,7 @@ func TestCollectIndex(t *testing.T) {
|
||||||
})
|
})
|
||||||
|
|
||||||
Convey("Name not in the index", t, func() {
|
Convey("Name not in the index", t, func() {
|
||||||
a := &models.Artist{Name: "Kraftwerk"}
|
a := &domain.Artist{Name: "Kraftwerk"}
|
||||||
artistIndex := make(map[string]tempIndex)
|
artistIndex := make(map[string]tempIndex)
|
||||||
|
|
||||||
collectIndex(ig, a, artistIndex)
|
collectIndex(ig, a, artistIndex)
|
||||||
|
@ -42,7 +42,7 @@ func TestCollectIndex(t *testing.T) {
|
||||||
})
|
})
|
||||||
|
|
||||||
Convey("Name starts with an article", t, func() {
|
Convey("Name starts with an article", t, func() {
|
||||||
a := &models.Artist{Name: "The The"}
|
a := &domain.Artist{Name: "The The"}
|
||||||
artistIndex := make(map[string]tempIndex)
|
artistIndex := make(map[string]tempIndex)
|
||||||
|
|
||||||
collectIndex(ig, a, artistIndex)
|
collectIndex(ig, a, artistIndex)
|
||||||
|
@ -56,7 +56,7 @@ func TestCollectIndex(t *testing.T) {
|
||||||
})
|
})
|
||||||
|
|
||||||
Convey("Name match a multichar entry", t, func() {
|
Convey("Name match a multichar entry", t, func() {
|
||||||
a := &models.Artist{Name: "Tom Waits"}
|
a := &domain.Artist{Name: "Tom Waits"}
|
||||||
artistIndex := make(map[string]tempIndex)
|
artistIndex := make(map[string]tempIndex)
|
||||||
|
|
||||||
collectIndex(ig, a, artistIndex)
|
collectIndex(ig, a, artistIndex)
|
||||||
|
|
|
@ -1,10 +1,9 @@
|
||||||
package mocks
|
package mocks
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/deluan/gosonic/models"
|
"github.com/deluan/gosonic/domain"
|
||||||
"fmt"
|
"fmt"
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"github.com/deluan/gosonic/repositories"
|
|
||||||
"errors"
|
"errors"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -13,8 +12,8 @@ func CreateMockArtistIndexRepo() *MockArtistIndex {
|
||||||
}
|
}
|
||||||
|
|
||||||
type MockArtistIndex struct {
|
type MockArtistIndex struct {
|
||||||
repositories.ArtistIndex
|
domain.ArtistIndexRepository
|
||||||
data []models.ArtistIndex
|
data []domain.ArtistIndex
|
||||||
err bool
|
err bool
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -23,14 +22,14 @@ func (m *MockArtistIndex) SetError(err bool) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *MockArtistIndex) SetData(j string, length int) {
|
func (m *MockArtistIndex) SetData(j string, length int) {
|
||||||
m.data = make([]models.ArtistIndex, length)
|
m.data = make([]domain.ArtistIndex, length)
|
||||||
err := json.Unmarshal([]byte(j), &m.data)
|
err := json.Unmarshal([]byte(j), &m.data)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Println("ERROR: ", err)
|
fmt.Println("ERROR: ", err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *MockArtistIndex) GetAll() ([]models.ArtistIndex, error) {
|
func (m *MockArtistIndex) GetAll() ([]domain.ArtistIndex, error) {
|
||||||
if m.err {
|
if m.err {
|
||||||
return nil, errors.New("Error!")
|
return nil, errors.New("Error!")
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
package mocks
|
package mocks
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/deluan/gosonic/repositories"
|
|
||||||
"errors"
|
"errors"
|
||||||
|
"github.com/deluan/gosonic/domain"
|
||||||
)
|
)
|
||||||
|
|
||||||
func CreateMockPropertyRepo() *MockProperty {
|
func CreateMockPropertyRepo() *MockProperty {
|
||||||
|
@ -10,7 +10,7 @@ func CreateMockPropertyRepo() *MockProperty {
|
||||||
}
|
}
|
||||||
|
|
||||||
type MockProperty struct {
|
type MockProperty struct {
|
||||||
repositories.Property
|
domain.PropertyRepository
|
||||||
data map[string]string
|
data map[string]string
|
||||||
err bool
|
err bool
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue