Compare commits
4 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 3a826ac216 | |||
|
ede07bb49a
|
|||
|
6834a79601
|
|||
|
336dea8147
|
8
crud.go
8
crud.go
@@ -176,13 +176,15 @@ func (db *MgoDatabase) ReadCollection(results interface{}, filter bson.M, select
|
|||||||
}
|
}
|
||||||
|
|
||||||
if len(sort) > 0 {
|
if len(sort) > 0 {
|
||||||
sortM := bson.M{}
|
sortM := bson.D{}
|
||||||
for _, s := range sort {
|
for _, s := range sort {
|
||||||
if strings.HasPrefix(s, "-") {
|
if strings.HasPrefix(s, "-") {
|
||||||
s = s[1:]
|
s = s[1:]
|
||||||
sortM[s] = -1
|
sortM = append(sortM, bson.DocElem{Name: s, Value: -1})
|
||||||
|
// sortM[s] = -1
|
||||||
} else {
|
} else {
|
||||||
sortM[s] = 1
|
sortM = append(sortM, bson.DocElem{Name: s, Value: 1})
|
||||||
|
// sortM[s] = 1
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// spew.Dump(sortM)
|
// spew.Dump(sortM)
|
||||||
|
|||||||
24
mgo.go
24
mgo.go
@@ -36,8 +36,13 @@ func (c *MgoConnection) Close() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
type MgoSession struct {
|
type MgoSession struct {
|
||||||
session *mgo.Session
|
connection *MgoConnection
|
||||||
closed bool
|
session *mgo.Session
|
||||||
|
closed bool
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *MgoSession) Connection() Connection {
|
||||||
|
return s.connection
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *MgoSession) Close() {
|
func (s *MgoSession) Close() {
|
||||||
@@ -49,7 +54,10 @@ func (s *MgoSession) Close() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (c *MgoConnection) NewSession() Session {
|
func (c *MgoConnection) NewSession() Session {
|
||||||
s := &MgoSession{session: c.connection.Copy()}
|
s := &MgoSession{
|
||||||
|
connection: c,
|
||||||
|
session: c.connection.Copy(),
|
||||||
|
}
|
||||||
runtime.SetFinalizer(s, func(s *MgoSession) {
|
runtime.SetFinalizer(s, func(s *MgoSession) {
|
||||||
if !s.closed {
|
if !s.closed {
|
||||||
s.Close()
|
s.Close()
|
||||||
@@ -68,15 +76,23 @@ func (s *MgoSession) DB(name string) Database {
|
|||||||
}
|
}
|
||||||
|
|
||||||
type MgoCollection struct {
|
type MgoCollection struct {
|
||||||
|
database *MgoDatabase
|
||||||
collection *mgo.Collection
|
collection *mgo.Collection
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (c *MgoCollection) DB() Database {
|
||||||
|
return c.database
|
||||||
|
}
|
||||||
|
|
||||||
func (db *MgoDatabase) Session() Session {
|
func (db *MgoDatabase) Session() Session {
|
||||||
return db.session
|
return db.session
|
||||||
}
|
}
|
||||||
|
|
||||||
func (db *MgoDatabase) C(name string) Collection {
|
func (db *MgoDatabase) C(name string) Collection {
|
||||||
return &MgoCollection{collection: db.database.C(name)}
|
return &MgoCollection{
|
||||||
|
database: db,
|
||||||
|
collection: db.database.C(name),
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (db *MgoDatabase) Name() string {
|
func (db *MgoDatabase) Name() string {
|
||||||
|
|||||||
14
setup.go
14
setup.go
@@ -9,10 +9,22 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
// EnsureIndex ensured mongodb index reflecting model struct index tag
|
// EnsureIndex ensured mongodb index reflecting model struct index tag
|
||||||
func (db *MgoDatabase) EnsureIndex(m ModelInterface) error {
|
func (db *MgoDatabase) EnsureIndex(m ModelInterface, index ...Index) error {
|
||||||
colName := GetCollectionName(m)
|
colName := GetCollectionName(m)
|
||||||
col := db.C(colName)
|
col := db.C(colName)
|
||||||
|
|
||||||
|
if len(index) > 0 {
|
||||||
|
// only ensure given index
|
||||||
|
for _, i := range index {
|
||||||
|
err := col.EnsureIndex(i)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// ensure index by struct fields
|
||||||
mType := reflect.TypeOf(m)
|
mType := reflect.TypeOf(m)
|
||||||
|
|
||||||
textFields := []string{}
|
textFields := []string{}
|
||||||
|
|||||||
7
types.go
7
types.go
@@ -16,16 +16,16 @@ type Connection interface {
|
|||||||
}
|
}
|
||||||
|
|
||||||
type Session interface {
|
type Session interface {
|
||||||
|
Connection() Connection
|
||||||
Close()
|
Close()
|
||||||
DB(name string) Database
|
DB(name string) Database
|
||||||
}
|
}
|
||||||
|
|
||||||
type Database interface {
|
type Database interface {
|
||||||
Session() Session
|
Session() Session
|
||||||
C(name string) Collection
|
// C(name string) Collection
|
||||||
Name() string
|
Name() string
|
||||||
EnsureIndex(m ModelInterface) error
|
EnsureIndex(m ModelInterface, index ...Index) error
|
||||||
ValidateObject(m ModelInterface, changes bson.M) error
|
|
||||||
ReadDocument(m ModelInterface, selector bson.M) error
|
ReadDocument(m ModelInterface, selector bson.M) error
|
||||||
CreateDocument(m ModelInterface) error
|
CreateDocument(m ModelInterface) error
|
||||||
ReadCollection(results interface{}, filter bson.M, selector bson.M, offset int, limit int, sort []string, pipelineModifier PipelineModifierFunction) error
|
ReadCollection(results interface{}, filter bson.M, selector bson.M, offset int, limit int, sort []string, pipelineModifier PipelineModifierFunction) error
|
||||||
@@ -37,6 +37,7 @@ type Database interface {
|
|||||||
}
|
}
|
||||||
|
|
||||||
type Collection interface {
|
type Collection interface {
|
||||||
|
DB() Database
|
||||||
Insert(docs ...interface{}) error
|
Insert(docs ...interface{}) error
|
||||||
UpdateId(id interface{}, update interface{}) error
|
UpdateId(id interface{}, update interface{}) error
|
||||||
RemoveId(id interface{}) error
|
RemoveId(id interface{}) error
|
||||||
|
|||||||
@@ -6,7 +6,7 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
// ValidateObject validates object via validator tag and custom method
|
// ValidateObject validates object via validator tag and custom method
|
||||||
func (db *MgoDatabase) ValidateObject(m ModelInterface, changes bson.M) error {
|
func ValidateObject(db Database, m ModelInterface, changes bson.M) error {
|
||||||
// first validate via struct tag
|
// first validate via struct tag
|
||||||
validator := validator.New(&validator.Config{
|
validator := validator.New(&validator.Config{
|
||||||
TagName: "validator",
|
TagName: "validator",
|
||||||
|
|||||||
Reference in New Issue
Block a user