Storm MediaFileRepository complete.
This commit is contained in:
+7
-7
@@ -28,7 +28,7 @@ func initBrowsingController() *BrowsingController {
|
|||||||
artistIndexRepository := ledis.NewArtistIndexRepository()
|
artistIndexRepository := ledis.NewArtistIndexRepository()
|
||||||
artistRepository := storm.NewArtistRepository()
|
artistRepository := storm.NewArtistRepository()
|
||||||
albumRepository := storm.NewAlbumRepository()
|
albumRepository := storm.NewAlbumRepository()
|
||||||
mediaFileRepository := ledis.NewMediaFileRepository()
|
mediaFileRepository := storm.NewMediaFileRepository()
|
||||||
browser := engine.NewBrowser(propertyRepository, mediaFolderRepository, artistIndexRepository, artistRepository, albumRepository, mediaFileRepository)
|
browser := engine.NewBrowser(propertyRepository, mediaFolderRepository, artistIndexRepository, artistRepository, albumRepository, mediaFileRepository)
|
||||||
browsingController := NewBrowsingController(browser)
|
browsingController := NewBrowsingController(browser)
|
||||||
return browsingController
|
return browsingController
|
||||||
@@ -36,7 +36,7 @@ func initBrowsingController() *BrowsingController {
|
|||||||
|
|
||||||
func initAlbumListController() *AlbumListController {
|
func initAlbumListController() *AlbumListController {
|
||||||
albumRepository := storm.NewAlbumRepository()
|
albumRepository := storm.NewAlbumRepository()
|
||||||
mediaFileRepository := ledis.NewMediaFileRepository()
|
mediaFileRepository := storm.NewMediaFileRepository()
|
||||||
nowPlayingRepository := ledis.NewNowPlayingRepository()
|
nowPlayingRepository := ledis.NewNowPlayingRepository()
|
||||||
listGenerator := engine.NewListGenerator(albumRepository, mediaFileRepository, nowPlayingRepository)
|
listGenerator := engine.NewListGenerator(albumRepository, mediaFileRepository, nowPlayingRepository)
|
||||||
albumListController := NewAlbumListController(listGenerator)
|
albumListController := NewAlbumListController(listGenerator)
|
||||||
@@ -45,7 +45,7 @@ func initAlbumListController() *AlbumListController {
|
|||||||
|
|
||||||
func initMediaAnnotationController() *MediaAnnotationController {
|
func initMediaAnnotationController() *MediaAnnotationController {
|
||||||
itunesControl := itunesbridge.NewItunesControl()
|
itunesControl := itunesbridge.NewItunesControl()
|
||||||
mediaFileRepository := ledis.NewMediaFileRepository()
|
mediaFileRepository := storm.NewMediaFileRepository()
|
||||||
nowPlayingRepository := ledis.NewNowPlayingRepository()
|
nowPlayingRepository := ledis.NewNowPlayingRepository()
|
||||||
scrobbler := engine.NewScrobbler(itunesControl, mediaFileRepository, nowPlayingRepository)
|
scrobbler := engine.NewScrobbler(itunesControl, mediaFileRepository, nowPlayingRepository)
|
||||||
albumRepository := storm.NewAlbumRepository()
|
albumRepository := storm.NewAlbumRepository()
|
||||||
@@ -58,7 +58,7 @@ func initMediaAnnotationController() *MediaAnnotationController {
|
|||||||
func initPlaylistsController() *PlaylistsController {
|
func initPlaylistsController() *PlaylistsController {
|
||||||
itunesControl := itunesbridge.NewItunesControl()
|
itunesControl := itunesbridge.NewItunesControl()
|
||||||
playlistRepository := ledis.NewPlaylistRepository()
|
playlistRepository := ledis.NewPlaylistRepository()
|
||||||
mediaFileRepository := ledis.NewMediaFileRepository()
|
mediaFileRepository := storm.NewMediaFileRepository()
|
||||||
playlists := engine.NewPlaylists(itunesControl, playlistRepository, mediaFileRepository)
|
playlists := engine.NewPlaylists(itunesControl, playlistRepository, mediaFileRepository)
|
||||||
playlistsController := NewPlaylistsController(playlists)
|
playlistsController := NewPlaylistsController(playlists)
|
||||||
return playlistsController
|
return playlistsController
|
||||||
@@ -67,7 +67,7 @@ func initPlaylistsController() *PlaylistsController {
|
|||||||
func initSearchingController() *SearchingController {
|
func initSearchingController() *SearchingController {
|
||||||
artistRepository := storm.NewArtistRepository()
|
artistRepository := storm.NewArtistRepository()
|
||||||
albumRepository := storm.NewAlbumRepository()
|
albumRepository := storm.NewAlbumRepository()
|
||||||
mediaFileRepository := ledis.NewMediaFileRepository()
|
mediaFileRepository := storm.NewMediaFileRepository()
|
||||||
db := newDB()
|
db := newDB()
|
||||||
search := engine.NewSearch(artistRepository, albumRepository, mediaFileRepository, db)
|
search := engine.NewSearch(artistRepository, albumRepository, mediaFileRepository, db)
|
||||||
searchingController := NewSearchingController(search)
|
searchingController := NewSearchingController(search)
|
||||||
@@ -80,7 +80,7 @@ func initUsersController() *UsersController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func initMediaRetrievalController() *MediaRetrievalController {
|
func initMediaRetrievalController() *MediaRetrievalController {
|
||||||
mediaFileRepository := ledis.NewMediaFileRepository()
|
mediaFileRepository := storm.NewMediaFileRepository()
|
||||||
albumRepository := storm.NewAlbumRepository()
|
albumRepository := storm.NewAlbumRepository()
|
||||||
cover := engine.NewCover(mediaFileRepository, albumRepository)
|
cover := engine.NewCover(mediaFileRepository, albumRepository)
|
||||||
mediaRetrievalController := NewMediaRetrievalController(cover)
|
mediaRetrievalController := NewMediaRetrievalController(cover)
|
||||||
@@ -88,7 +88,7 @@ func initMediaRetrievalController() *MediaRetrievalController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func initStreamController() *StreamController {
|
func initStreamController() *StreamController {
|
||||||
mediaFileRepository := ledis.NewMediaFileRepository()
|
mediaFileRepository := storm.NewMediaFileRepository()
|
||||||
streamController := NewStreamController(mediaFileRepository)
|
streamController := NewStreamController(mediaFileRepository)
|
||||||
return streamController
|
return streamController
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -5,7 +5,6 @@ import "github.com/google/wire"
|
|||||||
var Set = wire.NewSet(
|
var Set = wire.NewSet(
|
||||||
NewCheckSumRepository,
|
NewCheckSumRepository,
|
||||||
NewArtistIndexRepository,
|
NewArtistIndexRepository,
|
||||||
NewMediaFileRepository,
|
|
||||||
NewMediaFolderRepository,
|
NewMediaFolderRepository,
|
||||||
NewNowPlayingRepository,
|
NewNowPlayingRepository,
|
||||||
NewPlaylistRepository,
|
NewPlaylistRepository,
|
||||||
|
|||||||
@@ -60,18 +60,19 @@ func (r *albumRepository) FindByArtist(artistId string) (domain.Albums, error) {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
return r.toDomainList(albums)
|
return r.toAlbums(albums)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *albumRepository) GetAll(options domain.QueryOptions) (domain.Albums, error) {
|
func (r *albumRepository) GetAll(options domain.QueryOptions) (domain.Albums, error) {
|
||||||
all, err := r.getAll(&options)
|
var all []_Album
|
||||||
|
err := r.getAll(&all, &options)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
return r.toDomainList(all)
|
return r.toAlbums(all)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *albumRepository) toDomainList(all []_Album) (domain.Albums, error) {
|
func (r *albumRepository) toAlbums(all []_Album) (domain.Albums, error) {
|
||||||
result := make(domain.Albums, len(all))
|
result := make(domain.Albums, len(all))
|
||||||
for i, a := range all {
|
for i, a := range all {
|
||||||
result[i] = domain.Album(a)
|
result[i] = domain.Album(a)
|
||||||
@@ -80,7 +81,8 @@ func (r *albumRepository) toDomainList(all []_Album) (domain.Albums, error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (r *albumRepository) GetAllIds() ([]string, error) {
|
func (r *albumRepository) GetAllIds() ([]string, error) {
|
||||||
all, err := r.getAll(&domain.QueryOptions{})
|
var all []_Album
|
||||||
|
err := r.getAll(&all, &domain.QueryOptions{})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
@@ -91,15 +93,6 @@ func (r *albumRepository) GetAllIds() ([]string, error) {
|
|||||||
return result, nil
|
return result, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *albumRepository) getAll(options *domain.QueryOptions) (all []_Album, err error) {
|
|
||||||
if options.SortBy != "" {
|
|
||||||
err = Db().AllByIndex(options.SortBy, &all, stormOptions(options))
|
|
||||||
} else {
|
|
||||||
err = Db().All(&all, stormOptions(options))
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
func (r *albumRepository) PurgeInactive(active domain.Albums) ([]string, error) {
|
func (r *albumRepository) PurgeInactive(active domain.Albums) ([]string, error) {
|
||||||
activeIDs := make([]string, len(active))
|
activeIDs := make([]string, len(active))
|
||||||
for i, album := range active {
|
for i, album := range active {
|
||||||
@@ -115,7 +108,7 @@ func (r *albumRepository) GetStarred(options domain.QueryOptions) (domain.Albums
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
return r.toDomainList(starred)
|
return r.toAlbums(starred)
|
||||||
}
|
}
|
||||||
|
|
||||||
var _ domain.AlbumRepository = (*albumRepository)(nil)
|
var _ domain.AlbumRepository = (*albumRepository)(nil)
|
||||||
|
|||||||
@@ -0,0 +1,112 @@
|
|||||||
|
package storm
|
||||||
|
|
||||||
|
import (
|
||||||
|
"time"
|
||||||
|
|
||||||
|
"github.com/asdine/storm/q"
|
||||||
|
"github.com/cloudsonic/sonic-server/domain"
|
||||||
|
)
|
||||||
|
|
||||||
|
type _MediaFile struct {
|
||||||
|
ID string ``
|
||||||
|
Path string ``
|
||||||
|
Title string ``
|
||||||
|
Album string ``
|
||||||
|
Artist string ``
|
||||||
|
ArtistID string ``
|
||||||
|
AlbumArtist string ``
|
||||||
|
AlbumID string `storm:"index"`
|
||||||
|
HasCoverArt bool ``
|
||||||
|
TrackNumber int ``
|
||||||
|
DiscNumber int ``
|
||||||
|
Year int ``
|
||||||
|
Size string ``
|
||||||
|
Suffix string ``
|
||||||
|
Duration int ``
|
||||||
|
BitRate int ``
|
||||||
|
Genre string ``
|
||||||
|
Compilation bool ``
|
||||||
|
PlayCount int ``
|
||||||
|
PlayDate time.Time ``
|
||||||
|
Rating int ``
|
||||||
|
Starred bool `storm:"index"`
|
||||||
|
StarredAt time.Time ``
|
||||||
|
CreatedAt time.Time ``
|
||||||
|
UpdatedAt time.Time ``
|
||||||
|
}
|
||||||
|
|
||||||
|
type mediaFileRepository struct {
|
||||||
|
stormRepository
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewMediaFileRepository() domain.MediaFileRepository {
|
||||||
|
r := &mediaFileRepository{}
|
||||||
|
r.init(&_MediaFile{})
|
||||||
|
return r
|
||||||
|
}
|
||||||
|
|
||||||
|
func (r *mediaFileRepository) Put(m *domain.MediaFile) error {
|
||||||
|
tm := _MediaFile(*m)
|
||||||
|
return Db().Save(&tm)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (r *mediaFileRepository) Get(id string) (*domain.MediaFile, error) {
|
||||||
|
tm := &_MediaFile{}
|
||||||
|
err := r.getByID(id, tm)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
a := domain.MediaFile(*tm)
|
||||||
|
return &a, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (r *mediaFileRepository) toMediaFiles(all []_MediaFile) (domain.MediaFiles, error) {
|
||||||
|
result := make(domain.MediaFiles, len(all))
|
||||||
|
for i, m := range all {
|
||||||
|
result[i] = domain.MediaFile(m)
|
||||||
|
}
|
||||||
|
return result, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (r *mediaFileRepository) FindByAlbum(albumId string) (domain.MediaFiles, error) {
|
||||||
|
var mfs []_MediaFile
|
||||||
|
err := r.execute(q.Eq("AlbumID", albumId), &mfs)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return r.toMediaFiles(mfs)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (r *mediaFileRepository) GetStarred(options domain.QueryOptions) (domain.MediaFiles, error) {
|
||||||
|
var starred []_MediaFile
|
||||||
|
err := r.execute(q.Eq("Starred", true), &starred, &options)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return r.toMediaFiles(starred)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (r *mediaFileRepository) GetAllIds() ([]string, error) {
|
||||||
|
var all []_MediaFile
|
||||||
|
err := r.getAll(&all, &domain.QueryOptions{})
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
result := make([]string, len(all))
|
||||||
|
for i, m := range all {
|
||||||
|
result[i] = domain.MediaFile(m).ID
|
||||||
|
}
|
||||||
|
return result, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (r *mediaFileRepository) PurgeInactive(active domain.MediaFiles) ([]string, error) {
|
||||||
|
activeIDs := make([]string, len(active))
|
||||||
|
for i, mediaFile := range active {
|
||||||
|
activeIDs[i] = mediaFile.ID
|
||||||
|
}
|
||||||
|
|
||||||
|
return r.purgeInactive(activeIDs)
|
||||||
|
}
|
||||||
|
|
||||||
|
var _ domain.MediaFileRepository = (*mediaFileRepository)(nil)
|
||||||
|
var _ = domain.MediaFile(_MediaFile{})
|
||||||
@@ -74,7 +74,7 @@ func (r *stormRepository) purgeInactive(ids []string) (deleted []string, err err
|
|||||||
return deleted, nil
|
return deleted, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *stormRepository) execute(matcher q.Matcher, result *[]_Album, options ...*domain.QueryOptions) error {
|
func (r *stormRepository) execute(matcher q.Matcher, result interface{}, options ...*domain.QueryOptions) error {
|
||||||
query := Db().Select(matcher)
|
query := Db().Select(matcher)
|
||||||
if len(options) > 0 {
|
if len(options) > 0 {
|
||||||
query = addQueryOptions(query, options[0])
|
query = addQueryOptions(query, options[0])
|
||||||
@@ -86,6 +86,15 @@ func (r *stormRepository) execute(matcher q.Matcher, result *[]_Album, options .
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (r *stormRepository) getAll(all interface{}, options *domain.QueryOptions) (err error) {
|
||||||
|
if options.SortBy != "" {
|
||||||
|
err = Db().AllByIndex(options.SortBy, all, stormOptions(options))
|
||||||
|
} else {
|
||||||
|
err = Db().All(all, stormOptions(options))
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
func stormOptions(options *domain.QueryOptions) func(*index.Options) {
|
func stormOptions(options *domain.QueryOptions) func(*index.Options) {
|
||||||
return func(opts *index.Options) {
|
return func(opts *index.Options) {
|
||||||
opts.Reverse = options.Desc
|
opts.Reverse = options.Desc
|
||||||
|
|||||||
@@ -6,4 +6,5 @@ var Set = wire.NewSet(
|
|||||||
NewPropertyRepository,
|
NewPropertyRepository,
|
||||||
NewArtistRepository,
|
NewArtistRepository,
|
||||||
NewAlbumRepository,
|
NewAlbumRepository,
|
||||||
|
NewMediaFileRepository,
|
||||||
)
|
)
|
||||||
|
|||||||
+1
-1
@@ -21,7 +21,7 @@ import (
|
|||||||
func initImporter(musicFolder string) *scanner.Importer {
|
func initImporter(musicFolder string) *scanner.Importer {
|
||||||
checkSumRepository := ledis.NewCheckSumRepository()
|
checkSumRepository := ledis.NewCheckSumRepository()
|
||||||
itunesScanner := scanner.NewItunesScanner(checkSumRepository)
|
itunesScanner := scanner.NewItunesScanner(checkSumRepository)
|
||||||
mediaFileRepository := ledis.NewMediaFileRepository()
|
mediaFileRepository := storm.NewMediaFileRepository()
|
||||||
albumRepository := storm.NewAlbumRepository()
|
albumRepository := storm.NewAlbumRepository()
|
||||||
artistRepository := storm.NewArtistRepository()
|
artistRepository := storm.NewArtistRepository()
|
||||||
artistIndexRepository := ledis.NewArtistIndexRepository()
|
artistIndexRepository := ledis.NewArtistIndexRepository()
|
||||||
|
|||||||
Reference in New Issue
Block a user