File: paging.go

package info (click to toggle)
golang-github-henrybear327-go-proton-api 1.0.0-4
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 1,088 kB
  • sloc: sh: 55; makefile: 26
file content (36 lines) | stat: -rw-r--r-- 830 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
package proton

import (
	"context"
	"runtime"

	"github.com/ProtonMail/gluon/async"
	"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, c *Client,
	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) {
			defer async.HandlePanic(c.m.panicHandler)

			values, err := fn(ctx, page, pageSize)
			if err != nil {
				return nil, err
			}

			return stream.FromIterator(iterator.Slice(values)), nil
		},
	)))
}