From eadc5d5d314449bd0ea82756f8e7acdaf10fc9a5 Mon Sep 17 00:00:00 2001 From: Patrik Date: Wed, 6 Nov 2024 16:44:42 +0100 Subject: [PATCH] fix(pagination): always enforce max size is set (#820) --- pagination/keysetpagination/paginator.go | 11 +++++++++-- pagination/keysetpagination/paginator_test.go | 5 +++++ 2 files changed, 14 insertions(+), 2 deletions(-) diff --git a/pagination/keysetpagination/paginator.go b/pagination/keysetpagination/paginator.go index a69a8f64..0d94f6a8 100644 --- a/pagination/keysetpagination/paginator.go +++ b/pagination/keysetpagination/paginator.go @@ -34,6 +34,9 @@ var ErrUnknownOrder = errors.New("unknown order") const ( OrderDescending Order = "DESC" OrderAscending Order = "ASC" + + DefaultSize = 100 + DefaultMaxSize = 500 ) func (o Order) extract() (string, string, error) { @@ -62,7 +65,7 @@ func (p *Paginator) Size() int { size = 100 } } - if p.maxSize > 0 && size > p.maxSize { + if size > p.maxSize { size = p.maxSize } return size @@ -229,7 +232,11 @@ func withIsLast(isLast bool) Option { } func GetPaginator(modifiers ...Option) *Paginator { - opts := &Paginator{} + opts := &Paginator{ + // these can still be overridden by the modifiers, but they should never be unset + maxSize: DefaultMaxSize, + defaultSize: DefaultSize, + } for _, f := range modifiers { opts = f(opts) } diff --git a/pagination/keysetpagination/paginator_test.go b/pagination/keysetpagination/paginator_test.go index edcff86e..293c6a72 100644 --- a/pagination/keysetpagination/paginator_test.go +++ b/pagination/keysetpagination/paginator_test.go @@ -86,6 +86,11 @@ func TestPaginator(t *testing.T) { opts: nil, expectedSize: 100, }, + { + name: "default max size", + opts: []Option{WithSize(1000)}, + expectedSize: DefaultMaxSize, + }, { name: "with size and token", opts: []Option{WithSize(10), WithToken(StringPageToken("token"))},