renamed base_repository to ledis_repository

This commit is contained in:
Deluan 2016-03-03 20:16:09 -05:00
parent 4b70daf143
commit eae9f3168f
7 changed files with 21 additions and 21 deletions

View File

@ -5,7 +5,7 @@ import (
) )
type albumRepository struct { type albumRepository struct {
baseRepository ledisRepository
} }
func NewAlbumRepository() domain.AlbumRepository { func NewAlbumRepository() domain.AlbumRepository {

View File

@ -5,7 +5,7 @@ import (
) )
type artistRepository struct { type artistRepository struct {
baseRepository ledisRepository
} }
func NewArtistRepository() domain.ArtistRepository { func NewArtistRepository() domain.ArtistRepository {

View File

@ -8,7 +8,7 @@ import (
) )
type artistIndexRepository struct { type artistIndexRepository struct {
baseRepository ledisRepository
} }
func NewArtistIndexRepository() domain.ArtistIndexRepository { func NewArtistIndexRepository() domain.ArtistIndexRepository {

View File

@ -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 != "" {

View File

@ -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
} }

View File

@ -6,7 +6,7 @@ import (
) )
type mediaFileRepository struct { type mediaFileRepository struct {
baseRepository ledisRepository
} }
func NewMediaFileRepository() domain.MediaFileRepository { func NewMediaFileRepository() domain.MediaFileRepository {

View File

@ -6,7 +6,7 @@ import (
) )
type propertyRepository struct { type propertyRepository struct {
baseRepository ledisRepository
} }
func NewPropertyRepository() domain.PropertyRepository { func NewPropertyRepository() domain.PropertyRepository {