// Copyright (c) HashiCorp, Inc. // SPDX-License-Identifier: BUSL-1.1 package authtoken import ( "context" "time" "github.com/hashicorp/boundary/internal/errors" "github.com/hashicorp/boundary/internal/pagination" ) // List lists up to page size auth tokens, filtering out entries that // do not pass the filter item function. It will automatically request // more auth tokens from the database, at page size chunks, to fill the page. // It returns a new list token used to continue pagination or refresh items. // Auth tokens are ordered by create time descending (most recently created first). func List( ctx context.Context, grantsHash []byte, pageSize int, filterItemFn pagination.ListFilterFunc[*AuthToken], repo *Repository, withScopeIds []string, ) (*pagination.ListResponse[*AuthToken], error) { const op = "authtoken.List" switch { case len(grantsHash) == 0: return nil, errors.New(ctx, errors.InvalidParameter, op, "missing grants hash") case pageSize < 1: return nil, errors.New(ctx, errors.InvalidParameter, op, "page size must be at least 1") case filterItemFn == nil: return nil, errors.New(ctx, errors.InvalidParameter, op, "missing filter item callback") case repo == nil: return nil, errors.New(ctx, errors.InvalidParameter, op, "missing repo") case withScopeIds == nil: return nil, errors.New(ctx, errors.InvalidParameter, op, "missing scope ids") } listItemsFn := func(ctx context.Context, lastPageItem *AuthToken, limit int) ([]*AuthToken, time.Time, error) { opts := []Option{ WithLimit(limit), } if lastPageItem != nil { opts = append(opts, WithStartPageAfterItem(lastPageItem)) } return repo.listAuthTokens(ctx, withScopeIds, opts...) } return pagination.List(ctx, grantsHash, pageSize, filterItemFn, listItemsFn, repo.estimatedCount) }