add filter author and time #6

Merged
luuvansinh merged 1 commits from add-filter-author-and-time into master 2022-07-06 02:08:16 +00:00
1 changed files with 39 additions and 7 deletions
Showing only changes of commit b938f505cf - Show all commits

View File

@ -3,6 +3,7 @@ package audit
import ( import (
"context" "context"
"sync" "sync"
"time"
"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"
@ -12,6 +13,13 @@ import (
type AllQuery struct { type AllQuery struct {
Target string Target string
TargetID string TargetID string
// Additional filter
Author string
CreateTimeFrom time.Time
CreateTimeTo time.Time
// Pagination
Page int64 Page int64
Limit int64 Limit int64
Sort interface{} Sort interface{}
@ -25,10 +33,7 @@ func (s Service) All(query AllQuery) (result []Audit, total int64) {
skip = query.Page * query.Limit skip = query.Page * query.Limit
wg sync.WaitGroup wg sync.WaitGroup
) )
cond := bson.D{ cond := s.getQueryCondition(query)
{"target", query.Target},
{"targetId", query.TargetID},
}
wg.Add(1) wg.Add(1)
go func() { go func() {
defer wg.Done() defer wg.Done()
@ -54,3 +59,30 @@ func (s Service) All(query AllQuery) (result []Audit, total int64) {
wg.Wait() wg.Wait()
return result, total return result, total
} }
func (s Service) getQueryCondition(query AllQuery) bson.D {
cond := bson.D{
{"target", query.Target},
{"targetId", query.TargetID},
}
if query.Author != "" {
cond = append(cond, bson.E{
Key: "author.id",
Value: query.Author,
})
}
if !query.CreateTimeFrom.IsZero() || !query.CreateTimeTo.IsZero() {
v := bson.M{}
if !query.CreateTimeFrom.IsZero() {
v["$gte"] = query.CreateTimeFrom
}
if !query.CreateTimeTo.IsZero() {
v["$lt"] = query.CreateTimeTo
}
cond = append(cond, bson.E{
Key: "createdAt",
Value: v,
})
}
return cond
}