Skip to content

Commit

Permalink
feat(paging): add support for after id parameter in find options
Browse files Browse the repository at this point in the history
  • Loading branch information
GeorgeMac committed Aug 5, 2020
1 parent b484bfc commit 0bbf40e
Show file tree
Hide file tree
Showing 6 changed files with 99 additions and 8 deletions.
22 changes: 19 additions & 3 deletions kv/bucket.go
Original file line number Diff line number Diff line change
Expand Up @@ -402,18 +402,34 @@ func (s *Service) findBuckets(ctx context.Context, tx Tx, filter influxdb.Bucket
filter.OrganizationID = &o.ID
}

var offset, limit, count int
var descending bool
var (
offset, limit, count int
descending bool
)

after := func(*influxdb.Bucket) bool {
return true
}

if len(opts) > 0 {
offset = opts[0].Offset
limit = opts[0].Limit
descending = opts[0].Descending
if opts[0].After != nil {
after = func(b *influxdb.Bucket) bool {
if descending {
return b.ID < *opts[0].After
}

return b.ID > *opts[0].After
}
}
}

filterFn := filterBucketsFn(filter)
err := s.forEachBucket(ctx, tx, descending, func(b *influxdb.Bucket) bool {
if filterFn(b) {
if count >= offset {
if count >= offset && after(b) {
bs = append(bs, b)
}
count++
Expand Down
17 changes: 17 additions & 0 deletions paging.go
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@ type PagingLinks struct {
type FindOptions struct {
Limit int
Offset int
After *ID
SortBy string
Descending bool
}
Expand All @@ -50,6 +51,18 @@ func DecodeFindOptions(r *http.Request) (*FindOptions, error) {
opts.Offset = o
}

if after := qp.Get("after"); after != "" {
id, err := IDFromString(after)
if err != nil {
return nil, &Error{
Code: EInvalid,
Err: fmt.Errorf("decoding after: %w", err),
}
}

opts.After = id
}

if limit := qp.Get("limit"); limit != "" {
l, err := strconv.Atoi(limit)
if err != nil {
Expand Down Expand Up @@ -109,6 +122,10 @@ func (f FindOptions) QueryParams() map[string][]string {
"offset": {strconv.Itoa(f.Offset)},
}

if f.After != nil {
qp["after"] = []string{f.After.String()}
}

if f.Limit > 0 {
qp["limit"] = []string{strconv.Itoa(f.Limit)}
}
Expand Down
2 changes: 1 addition & 1 deletion tenant/middleware_bucket_logging_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,6 @@ func TestBucketLoggingService(t *testing.T) {
}

func initBoltBucketLoggingService(f influxdbtesting.BucketFields, t *testing.T) (influxdb.BucketService, string, func()) {
svc, s, closer := initBoltBucketService(f, t)
svc, s, closer := initInmemBucketService(f, t)
return tenant.NewBucketLogger(zaptest.NewLogger(t), svc), s, closer
}
6 changes: 3 additions & 3 deletions tenant/service_bucket_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -10,11 +10,11 @@ import (
influxdbtesting "github.com/influxdata/influxdb/v2/testing"
)

func TestBoltBucketService(t *testing.T) {
influxdbtesting.BucketService(initBoltBucketService, t, influxdbtesting.WithoutHooks())
func TestInmemBucketService(t *testing.T) {
influxdbtesting.BucketService(initInmemBucketService, t, influxdbtesting.WithoutHooks())
}

func initBoltBucketService(f influxdbtesting.BucketFields, t *testing.T) (influxdb.BucketService, string, func()) {
func initInmemBucketService(f influxdbtesting.BucketFields, t *testing.T) (influxdb.BucketService, string, func()) {
s, closeBolt, err := NewTestInmemStore(t)
if err != nil {
t.Fatalf("failed to create new kv store: %v", err)
Expand Down
12 changes: 11 additions & 1 deletion tenant/storage_bucket.go
Original file line number Diff line number Diff line change
Expand Up @@ -191,7 +191,17 @@ func (s *Store) ListBuckets(ctx context.Context, tx kv.Tx, filter BucketFilter,
if o.Descending {
opts = append(opts, kv.WithCursorDirection(kv.CursorDescending))
}
cursor, err := b.ForwardCursor(nil, opts...)

var seek []byte
if o.After != nil {
after := (*o.After) + 1
seek, err = after.Encode()
if err != nil {
return nil, err
}
}

cursor, err := b.ForwardCursor(seek, opts...)
if err != nil {
return nil, err
}
Expand Down
48 changes: 48 additions & 0 deletions testing/bucket_service.go
Original file line number Diff line number Diff line change
Expand Up @@ -731,6 +731,54 @@ func FindBuckets(
},
},
},
{
name: "find all buckets by after and limit",
fields: BucketFields{
Organizations: []*influxdb.Organization{
{
Name: "theorg",
ID: MustIDBase16(orgOneID),
},
},
Buckets: []*influxdb.Bucket{
{
ID: MustIDBase16(bucketOneID),
OrgID: MustIDBase16(orgOneID),
Name: "abc",
},
{
ID: MustIDBase16(bucketTwoID),
OrgID: MustIDBase16(orgOneID),
Name: "def",
},
{
ID: MustIDBase16(bucketThreeID),
OrgID: MustIDBase16(orgOneID),
Name: "xyz",
},
},
},
args: args{
findOptions: influxdb.FindOptions{
After: idPtr(MustIDBase16(bucketOneID)),
Limit: 2,
},
},
wants: wants{
buckets: []*influxdb.Bucket{
{
ID: MustIDBase16(bucketTwoID),
OrgID: MustIDBase16(orgOneID),
Name: "def",
},
{
ID: MustIDBase16(bucketThreeID),
OrgID: MustIDBase16(orgOneID),
Name: "xyz",
},
},
},
},
{
name: "find all buckets by descending",
fields: BucketFields{
Expand Down

0 comments on commit 0bbf40e

Please sign in to comment.