Merge pull request #5 from Selly-Modules/response-total-in-query-all
update query - response total to pagination
This commit is contained in:
commit
39e37bde08
|
@ -2,6 +2,7 @@ package audit
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
"sync"
|
||||||
|
|
||||||
"go.mongodb.org/mongo-driver/bson"
|
"go.mongodb.org/mongo-driver/bson"
|
||||||
"go.mongodb.org/mongo-driver/mongo/options"
|
"go.mongodb.org/mongo-driver/mongo/options"
|
||||||
|
@ -17,27 +18,39 @@ type AllQuery struct {
|
||||||
}
|
}
|
||||||
|
|
||||||
// All ...
|
// All ...
|
||||||
func (s Service) All(query AllQuery) []Audit {
|
func (s Service) All(query AllQuery) (result []Audit, total int64) {
|
||||||
var (
|
var (
|
||||||
ctx = context.Background()
|
ctx = context.Background()
|
||||||
colName = getColName(query.Target)
|
colName = getColName(query.Target)
|
||||||
skip = query.Page * query.Limit
|
skip = query.Page * query.Limit
|
||||||
result = make([]Audit, 0)
|
wg sync.WaitGroup
|
||||||
)
|
)
|
||||||
opts := options.Find().SetLimit(query.Limit).SetSkip(skip).SetSort(bson.M{"_id": -1})
|
cond := bson.D{
|
||||||
if query.Sort != nil {
|
|
||||||
opts.SetSort(query.Sort)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Find db
|
|
||||||
cursor, err := s.DB.Collection(colName).Find(ctx, bson.D{
|
|
||||||
{"target", query.Target},
|
{"target", query.Target},
|
||||||
{"targetId", query.TargetID},
|
{"targetId", query.TargetID},
|
||||||
}, opts)
|
|
||||||
if err != nil {
|
|
||||||
return result
|
|
||||||
}
|
}
|
||||||
defer cursor.Close(ctx)
|
wg.Add(1)
|
||||||
cursor.All(ctx, &result)
|
go func() {
|
||||||
return result
|
defer wg.Done()
|
||||||
|
opts := options.Find().SetLimit(query.Limit).SetSkip(skip).SetSort(bson.M{"_id": -1})
|
||||||
|
if query.Sort != nil {
|
||||||
|
opts.SetSort(query.Sort)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Find db
|
||||||
|
cursor, err := s.DB.Collection(colName).Find(ctx, cond, opts)
|
||||||
|
if err != nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
defer cursor.Close(ctx)
|
||||||
|
cursor.All(ctx, &result)
|
||||||
|
}()
|
||||||
|
|
||||||
|
wg.Add(1)
|
||||||
|
go func() {
|
||||||
|
defer wg.Done()
|
||||||
|
total, _ = s.DB.Collection(colName).CountDocuments(ctx, cond)
|
||||||
|
}()
|
||||||
|
wg.Wait()
|
||||||
|
return result, total
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue