mirror of
https://github.com/navidrome/navidrome.git
synced 2025-06-05 01:43:11 +03:00
renamed base_repository to ledis_repository
This commit is contained in:
parent
4b70daf143
commit
eae9f3168f
@ -5,7 +5,7 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
type albumRepository struct {
|
type albumRepository struct {
|
||||||
baseRepository
|
ledisRepository
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewAlbumRepository() domain.AlbumRepository {
|
func NewAlbumRepository() domain.AlbumRepository {
|
||||||
|
@ -5,7 +5,7 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
type artistRepository struct {
|
type artistRepository struct {
|
||||||
baseRepository
|
ledisRepository
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewArtistRepository() domain.ArtistRepository {
|
func NewArtistRepository() domain.ArtistRepository {
|
||||||
|
@ -8,7 +8,7 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
type artistIndexRepository struct {
|
type artistIndexRepository struct {
|
||||||
baseRepository
|
ledisRepository
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewArtistIndexRepository() domain.ArtistIndexRepository {
|
func NewArtistIndexRepository() domain.ArtistIndexRepository {
|
||||||
|
@ -9,13 +9,13 @@ import (
|
|||||||
"strings"
|
"strings"
|
||||||
)
|
)
|
||||||
|
|
||||||
type baseRepository struct {
|
type ledisRepository struct {
|
||||||
table string
|
table string
|
||||||
entityType reflect.Type
|
entityType reflect.Type
|
||||||
fieldNames []string
|
fieldNames []string
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *baseRepository) init(table string, entity interface{}) {
|
func (r *ledisRepository) init(table string, entity interface{}) {
|
||||||
r.table = table
|
r.table = table
|
||||||
r.entityType = reflect.TypeOf(entity).Elem()
|
r.entityType = reflect.TypeOf(entity).Elem()
|
||||||
|
|
||||||
@ -29,22 +29,22 @@ func (r *baseRepository) init(table string, entity interface{}) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// TODO Use annotations to specify fields to be used
|
// TODO Use annotations to specify fields to be used
|
||||||
func (r *baseRepository) NewId(fields ...string) string {
|
func (r *ledisRepository) NewId(fields ...string) string {
|
||||||
s := fmt.Sprintf("%s\\%s", strings.ToUpper(r.table), strings.Join(fields, ""))
|
s := fmt.Sprintf("%s\\%s", strings.ToUpper(r.table), strings.Join(fields, ""))
|
||||||
return fmt.Sprintf("%x", md5.Sum([]byte(s)))
|
return fmt.Sprintf("%x", md5.Sum([]byte(s)))
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *baseRepository) CountAll() (int, error) {
|
func (r *ledisRepository) CountAll() (int, error) {
|
||||||
ids, err := db().SMembers([]byte(r.table + "s:all"))
|
ids, err := db().SMembers([]byte(r.table + "s:all"))
|
||||||
return len(ids), err
|
return len(ids), err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *baseRepository) Exists(id string) (bool, error) {
|
func (r *ledisRepository) Exists(id string) (bool, error) {
|
||||||
res, err := db().SIsMember([]byte(r.table+"s:all"), []byte(id))
|
res, err := db().SIsMember([]byte(r.table+"s:all"), []byte(id))
|
||||||
return res != 0, err
|
return res != 0, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *baseRepository) saveOrUpdate(id string, entity interface{}) error {
|
func (r *ledisRepository) saveOrUpdate(id string, entity interface{}) error {
|
||||||
recordPrefix := fmt.Sprintf("%s:%s:", r.table, id)
|
recordPrefix := fmt.Sprintf("%s:%s:", r.table, id)
|
||||||
allKey := r.table + "s:all"
|
allKey := r.table + "s:all"
|
||||||
|
|
||||||
@ -73,7 +73,7 @@ func (r *baseRepository) saveOrUpdate(id string, entity interface{}) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// TODO Optimize
|
// TODO Optimize
|
||||||
func (r *baseRepository) getParent(entity interface{}) (table string, id string) {
|
func (r *ledisRepository) getParent(entity interface{}) (table string, id string) {
|
||||||
dt := reflect.TypeOf(entity).Elem()
|
dt := reflect.TypeOf(entity).Elem()
|
||||||
for i := 0; i < dt.NumField(); i++ {
|
for i := 0; i < dt.NumField(); i++ {
|
||||||
f := dt.Field(i)
|
f := dt.Field(i)
|
||||||
@ -86,7 +86,7 @@ func (r *baseRepository) getParent(entity interface{}) (table string, id string)
|
|||||||
return "", ""
|
return "", ""
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *baseRepository) getFieldKeys(id string) [][]byte {
|
func (r *ledisRepository) getFieldKeys(id string) [][]byte {
|
||||||
recordPrefix := fmt.Sprintf("%s:%s:", r.table, id)
|
recordPrefix := fmt.Sprintf("%s:%s:", r.table, id)
|
||||||
var fieldKeys = make([][]byte, len(r.fieldNames))
|
var fieldKeys = make([][]byte, len(r.fieldNames))
|
||||||
for i, n := range r.fieldNames {
|
for i, n := range r.fieldNames {
|
||||||
@ -95,11 +95,11 @@ func (r *baseRepository) getFieldKeys(id string) [][]byte {
|
|||||||
return fieldKeys
|
return fieldKeys
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *baseRepository) newInstance() interface{} {
|
func (r *ledisRepository) newInstance() interface{} {
|
||||||
return reflect.New(r.entityType).Interface()
|
return reflect.New(r.entityType).Interface()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *baseRepository) readEntity(id string) (interface{}, error) {
|
func (r *ledisRepository) readEntity(id string) (interface{}, error) {
|
||||||
entity := r.newInstance()
|
entity := r.newInstance()
|
||||||
|
|
||||||
fieldKeys := r.getFieldKeys(id)
|
fieldKeys := r.getFieldKeys(id)
|
||||||
@ -112,7 +112,7 @@ func (r *baseRepository) readEntity(id string) (interface{}, error) {
|
|||||||
return entity, err
|
return entity, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *baseRepository) toEntity(response [][]byte, entity interface{}) error {
|
func (r *ledisRepository) toEntity(response [][]byte, entity interface{}) error {
|
||||||
var record = make(map[string]interface{}, len(response))
|
var record = make(map[string]interface{}, len(response))
|
||||||
for i, v := range response {
|
for i, v := range response {
|
||||||
if len(v) > 0 {
|
if len(v) > 0 {
|
||||||
@ -127,18 +127,18 @@ func (r *baseRepository) toEntity(response [][]byte, entity interface{}) error {
|
|||||||
return utils.ToStruct(record, entity)
|
return utils.ToStruct(record, entity)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *baseRepository) loadAll(entities interface{}, sortBy string, alpha bool) error {
|
func (r *ledisRepository) loadAll(entities interface{}, sortBy string, alpha bool) error {
|
||||||
setName := r.table + "s:all"
|
setName := r.table + "s:all"
|
||||||
return r.loadFromSet(setName, entities, sortBy, alpha)
|
return r.loadFromSet(setName, entities, sortBy, alpha)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *baseRepository) loadChildren(parentTable string, parentId string, entities interface{}, sortBy string, alpha bool) error {
|
func (r *ledisRepository) loadChildren(parentTable string, parentId string, entities interface{}, sortBy string, alpha bool) error {
|
||||||
setName := fmt.Sprintf("%s:%s:%ss", parentTable, parentId, r.table)
|
setName := fmt.Sprintf("%s:%s:%ss", parentTable, parentId, r.table)
|
||||||
return r.loadFromSet(setName, entities, sortBy, alpha)
|
return r.loadFromSet(setName, entities, sortBy, alpha)
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO Optimize it! Probably very slow (and confusing!)
|
// TODO Optimize it! Probably very slow (and confusing!)
|
||||||
func (r *baseRepository) loadFromSet(setName string, entities interface{}, sortBy string, alpha bool) error {
|
func (r *ledisRepository) loadFromSet(setName string, entities interface{}, sortBy string, alpha bool) error {
|
||||||
reflected := reflect.ValueOf(entities).Elem()
|
reflected := reflect.ValueOf(entities).Elem()
|
||||||
var sortKey []byte = nil
|
var sortKey []byte = nil
|
||||||
if sortBy != "" {
|
if sortBy != "" {
|
@ -19,8 +19,8 @@ func shouldBeEqual(actualStruct interface{}, expectedStruct ...interface{}) stri
|
|||||||
return ShouldEqual(actual, expected)
|
return ShouldEqual(actual, expected)
|
||||||
}
|
}
|
||||||
|
|
||||||
func createRepo() *baseRepository {
|
func createRepo() *ledisRepository {
|
||||||
repo := &baseRepository{}
|
repo := &ledisRepository{}
|
||||||
repo.init("test", &TestEntity{})
|
repo.init("test", &TestEntity{})
|
||||||
return repo
|
return repo
|
||||||
}
|
}
|
@ -6,7 +6,7 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
type mediaFileRepository struct {
|
type mediaFileRepository struct {
|
||||||
baseRepository
|
ledisRepository
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewMediaFileRepository() domain.MediaFileRepository {
|
func NewMediaFileRepository() domain.MediaFileRepository {
|
||||||
|
@ -6,7 +6,7 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
type propertyRepository struct {
|
type propertyRepository struct {
|
||||||
baseRepository
|
ledisRepository
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewPropertyRepository() domain.PropertyRepository {
|
func NewPropertyRepository() domain.PropertyRepository {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user