5 Commits
v2.0.11 ... v2

Author SHA1 Message Date
3a826ac216 fixed sort via pipeline 2022-12-07 15:16:09 +01:00
ede07bb49a extended interface 2022-02-21 15:26:23 +01:00
6834a79601 ValidateObject not in interface 2022-02-14 16:01:12 +01:00
336dea8147 ensure multiple index via db interface 2022-02-10 16:10:38 +01:00
f8f8cb2366 removed debug msg 2022-02-10 15:33:20 +01:00
5 changed files with 43 additions and 19 deletions

View File

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

27
mgo.go
View File

@@ -2,7 +2,6 @@ package mgocrud
import ( import (
"errors" "errors"
"fmt"
"runtime" "runtime"
mgo "gopkg.in/mgo.v2" mgo "gopkg.in/mgo.v2"
@@ -14,7 +13,6 @@ type MgoConnection struct {
} }
func NewMgoConnection(dial string) (Connection, error) { func NewMgoConnection(dial string) (Connection, error) {
fmt.Println("CONNECTION CREATE")
connection, err := mgo.Dial(dial) connection, err := mgo.Dial(dial)
if err != nil { if err != nil {
return nil, err return nil, err
@@ -22,7 +20,6 @@ func NewMgoConnection(dial string) (Connection, error) {
connection.SetMode(mgo.Monotonic, true) connection.SetMode(mgo.Monotonic, true)
c := &MgoConnection{connection: connection} c := &MgoConnection{connection: connection}
runtime.SetFinalizer(c, func(c *MgoConnection) { runtime.SetFinalizer(c, func(c *MgoConnection) {
fmt.Println("CONNECTION CLOSE FINALIZER")
if !c.closed { if !c.closed {
c.Close() c.Close()
} }
@@ -31,7 +28,6 @@ func NewMgoConnection(dial string) (Connection, error) {
} }
func (c *MgoConnection) Close() { func (c *MgoConnection) Close() {
fmt.Println("CONNECTION CLOSE MANUALLY")
if !c.closed { if !c.closed {
c.connection.Close() c.connection.Close()
c.closed = true c.closed = true
@@ -40,12 +36,16 @@ func (c *MgoConnection) Close() {
} }
type MgoSession struct { type MgoSession struct {
connection *MgoConnection
session *mgo.Session session *mgo.Session
closed bool closed bool
} }
func (s *MgoSession) Connection() Connection {
return s.connection
}
func (s *MgoSession) Close() { func (s *MgoSession) Close() {
fmt.Println("SESSION CLOSE MANUALLY")
if !s.closed { if !s.closed {
s.session.Close() s.session.Close()
s.closed = true s.closed = true
@@ -54,10 +54,11 @@ func (s *MgoSession) Close() {
} }
func (c *MgoConnection) NewSession() Session { func (c *MgoConnection) NewSession() Session {
fmt.Println("SESSION CREATE") s := &MgoSession{
s := &MgoSession{session: c.connection.Copy()} connection: c,
session: c.connection.Copy(),
}
runtime.SetFinalizer(s, func(s *MgoSession) { runtime.SetFinalizer(s, func(s *MgoSession) {
fmt.Println("SESSION CLOSE FINALIZER")
if !s.closed { if !s.closed {
s.Close() s.Close()
} }
@@ -75,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 {

View File

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

View File

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

View File

@@ -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",