mirror of
https://github.com/mainnika/mongox-go-driver.git
synced 2026-05-22 15:53:36 +00:00
Add callback mechanism and implement on-decode callback
This commit is contained in:
@@ -0,0 +1,19 @@
|
||||
package database
|
||||
|
||||
import (
|
||||
"context"
|
||||
|
||||
"github.com/mainnika/mongox-go-driver/v2/mongox/query"
|
||||
)
|
||||
|
||||
func onDecode(ctx context.Context, iter interface{}, callbacks ...query.OnDecode) (err error) {
|
||||
|
||||
for _, cb := range callbacks {
|
||||
err = cb(ctx, iter)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
}
|
||||
|
||||
return
|
||||
}
|
||||
@@ -49,14 +49,18 @@ func (d *Database) LoadArray(target interface{}, filters ...interface{}) (err er
|
||||
}
|
||||
|
||||
for i = 0; result.Next(d.Context()); {
|
||||
|
||||
var elem interface{}
|
||||
|
||||
if targetSliceV.Len() == i {
|
||||
elem := reflect.New(targetSliceElemT.Elem())
|
||||
err = result.Decode(elem.Interface())
|
||||
value := reflect.New(targetSliceElemT.Elem())
|
||||
err = result.Decode(value.Interface())
|
||||
elem = value.Interface()
|
||||
if err == nil {
|
||||
targetSliceV = reflect.Append(targetSliceV, elem)
|
||||
targetSliceV = reflect.Append(targetSliceV, value)
|
||||
}
|
||||
} else {
|
||||
elem := targetSliceV.Index(i).Interface()
|
||||
elem = targetSliceV.Index(i).Interface()
|
||||
base.Reset(elem)
|
||||
err = result.Decode(elem)
|
||||
}
|
||||
@@ -65,6 +69,12 @@ func (d *Database) LoadArray(target interface{}, filters ...interface{}) (err er
|
||||
return
|
||||
}
|
||||
|
||||
err = onDecode(d.ctx, elem, composed.OnDecode()...)
|
||||
if err != nil {
|
||||
_ = result.Close(d.Context())
|
||||
return
|
||||
}
|
||||
|
||||
i++
|
||||
}
|
||||
|
||||
|
||||
@@ -35,5 +35,15 @@ func (d *Database) LoadOne(target interface{}, filters ...interface{}) (err erro
|
||||
|
||||
base.Reset(target)
|
||||
|
||||
return result.Decode(target)
|
||||
err = result.Decode(target)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
|
||||
err = onDecode(d.ctx, target, composed.OnDecode()...)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
@@ -25,7 +25,7 @@ func (d *Database) LoadStream(target interface{}, filters ...interface{}) (loade
|
||||
return
|
||||
}
|
||||
|
||||
loader = &StreamLoader{cur: cursor, ctx: d.Context(), target: target}
|
||||
loader = &StreamLoader{cur: cursor, ctx: d.Context(), target: target, query: composed}
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
@@ -5,11 +5,13 @@ import (
|
||||
|
||||
"github.com/mainnika/mongox-go-driver/v2/mongox"
|
||||
"github.com/mainnika/mongox-go-driver/v2/mongox/base"
|
||||
"github.com/mainnika/mongox-go-driver/v2/mongox/query"
|
||||
)
|
||||
|
||||
// StreamLoader is a controller for a database cursor
|
||||
type StreamLoader struct {
|
||||
cur *mongox.Cursor
|
||||
query *query.Query
|
||||
ctx context.Context
|
||||
target interface{}
|
||||
}
|
||||
@@ -36,6 +38,14 @@ func (l *StreamLoader) Decode() (err error) {
|
||||
base.Reset(l.target)
|
||||
|
||||
err = l.cur.Decode(l.target)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
|
||||
err = onDecode(l.ctx, l.target, l.query.OnDecode()...)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user