Compare commits
	
		
			2 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| afcc89bf9e | |||
| 1672e8f8fd | 
| @@ -1,5 +1,5 @@ | |||||||
| package goext | package goext | ||||||
|  |  | ||||||
| const GoextVersion = "0.0.305" | const GoextVersion = "0.0.307" | ||||||
|  |  | ||||||
| const GoextVersionTimestamp = "2023-11-09T09:35:56+0100" | const GoextVersionTimestamp = "2023-11-09T10:00:01+0100" | ||||||
|   | |||||||
| @@ -1,29 +1,28 @@ | |||||||
| package pagination | package pagination | ||||||
|  |  | ||||||
| import ( | import ( | ||||||
|  | 	"go.mongodb.org/mongo-driver/bson" | ||||||
| 	"go.mongodb.org/mongo-driver/mongo" | 	"go.mongodb.org/mongo-driver/mongo" | ||||||
| 	ct "gogs.mikescher.com/BlackForestBytes/goext/cursortoken" |  | ||||||
| ) | ) | ||||||
|  |  | ||||||
| type Filter interface { | type Filter interface { | ||||||
| 	FilterQuery() mongo.Pipeline | 	FilterQuery() mongo.Pipeline | ||||||
| 	Pagination() (string, ct.SortDirection) | 	Sort() bson.D | ||||||
| } | } | ||||||
|  |  | ||||||
| type dynamicFilter struct { | type dynamicFilter struct { | ||||||
| 	pipeline mongo.Pipeline | 	pipeline mongo.Pipeline | ||||||
| 	sortField string | 	sort     bson.D | ||||||
| 	sortDir   ct.SortDirection |  | ||||||
| } | } | ||||||
|  |  | ||||||
| func (d dynamicFilter) FilterQuery() mongo.Pipeline { | func (d dynamicFilter) FilterQuery() mongo.Pipeline { | ||||||
| 	return d.pipeline | 	return d.pipeline | ||||||
| } | } | ||||||
|  |  | ||||||
| func (d dynamicFilter) Pagination() (string, ct.SortDirection) { | func (d dynamicFilter) Sort() bson.D { | ||||||
| 	return d.sortField, d.sortDir | 	return d.sort | ||||||
| } | } | ||||||
|  |  | ||||||
| func CreateFilter(pipeline mongo.Pipeline, sortField string, sortdir ct.SortDirection) Filter { | func CreateFilter(pipeline mongo.Pipeline, sort bson.D) Filter { | ||||||
| 	return dynamicFilter{pipeline: pipeline, sortField: sortField, sortDir: sortdir} | 	return dynamicFilter{pipeline: pipeline, sort: sort} | ||||||
| } | } | ||||||
|   | |||||||
| @@ -43,3 +43,13 @@ func (c *Coll[TData]) InsertMany(ctx context.Context, valueIn []TData) (*mongo.I | |||||||
|  |  | ||||||
| 	return insRes, nil | 	return insRes, nil | ||||||
| } | } | ||||||
|  |  | ||||||
|  | // InsertManyUnchecked behaves the same as InsertOne, but allows arbitrary data to be inserted (valueIn is []any instead of []TData) | ||||||
|  | func (c *Coll[TData]) InsertManyUnchecked(ctx context.Context, valueIn []any) (*mongo.InsertManyResult, error) { | ||||||
|  | 	insRes, err := c.coll.InsertMany(ctx, langext.ArrayToInterface(valueIn)) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return nil, exerr.Wrap(err, "mongo-query[insert-many] failed").Int("len(valueIn)", len(valueIn)).Str("collection", c.Name()).Build() | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	return insRes, nil | ||||||
|  | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user