Files
go-proton-api/paging.go
2022-11-23 12:03:04 +01:00

34 lines
736 B
Go

package proton
import (
"context"
"runtime"
"github.com/bradenaw/juniper/iterator"
"github.com/bradenaw/juniper/parallel"
"github.com/bradenaw/juniper/stream"
)
const maxPageSize = 150
func fetchPaged[T any](
ctx context.Context,
total, pageSize int,
fn func(ctx context.Context, page, pageSize int) ([]T, error),
) ([]T, error) {
return stream.Collect(ctx, stream.Flatten(parallel.MapStream(
ctx,
stream.FromIterator(iterator.Counter(total/pageSize+1)),
runtime.NumCPU(),
runtime.NumCPU(),
func(ctx context.Context, page int) (stream.Stream[T], error) {
values, err := fn(ctx, page, pageSize)
if err != nil {
return nil, err
}
return stream.FromIterator(iterator.Slice(values)), nil
},
)))
}