Tested with `kind` and GKE. Note: "nodes" shown in `docker buildx ls` are unrelated to Kubernetes "nodes". Probably buildx should come up with an alternative term. Usage: $ kind create cluster $ export KUBECONFIG="$(kind get kubeconfig-path --name="kind")" $ docker buildx create --driver kubernetes --driver-opt replicas=3 --use $ docker buildx build -t foo --load . `--load` loads the image into the local Docker. Driver opts: - `image=IMAGE` - Sets the container image to be used for running buildkit. - `namespace=NS` - Sets the Kubernetes namespace. Defaults to the current namespace. - `replicas=N` - Sets the number of `Pod` replicas. Defaults to 1. - `rootless=(true|false)` - Run the container as a non-root user without `securityContext.privileged`. Defaults to false. - `loadbalance=(sticky|random)` - Load-balancing strategy. If set to "sticky", the pod is chosen using the hash of the context path. Defaults to "sticky" Signed-off-by: Akihiro Suda <akihiro.suda.cz@hco.ntt.co.jp>
59 lines
1.5 KiB
Go
59 lines
1.5 KiB
Go
package pagination
|
|
|
|
import (
|
|
"fmt"
|
|
"reflect"
|
|
|
|
"github.com/gophercloud/gophercloud"
|
|
)
|
|
|
|
// MarkerPage is a stricter Page interface that describes additional functionality required for use with NewMarkerPager.
|
|
// For convenience, embed the MarkedPageBase struct.
|
|
type MarkerPage interface {
|
|
Page
|
|
|
|
// LastMarker returns the last "marker" value on this page.
|
|
LastMarker() (string, error)
|
|
}
|
|
|
|
// MarkerPageBase is a page in a collection that's paginated by "limit" and "marker" query parameters.
|
|
type MarkerPageBase struct {
|
|
PageResult
|
|
|
|
// Owner is a reference to the embedding struct.
|
|
Owner MarkerPage
|
|
}
|
|
|
|
// NextPageURL generates the URL for the page of results after this one.
|
|
func (current MarkerPageBase) NextPageURL() (string, error) {
|
|
currentURL := current.URL
|
|
|
|
mark, err := current.Owner.LastMarker()
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
|
|
q := currentURL.Query()
|
|
q.Set("marker", mark)
|
|
currentURL.RawQuery = q.Encode()
|
|
|
|
return currentURL.String(), nil
|
|
}
|
|
|
|
// IsEmpty satisifies the IsEmpty method of the Page interface
|
|
func (current MarkerPageBase) IsEmpty() (bool, error) {
|
|
if b, ok := current.Body.([]interface{}); ok {
|
|
return len(b) == 0, nil
|
|
}
|
|
err := gophercloud.ErrUnexpectedType{}
|
|
err.Expected = "[]interface{}"
|
|
err.Actual = fmt.Sprintf("%v", reflect.TypeOf(current.Body))
|
|
return true, err
|
|
}
|
|
|
|
// GetBody returns the linked page's body. This method is needed to satisfy the
|
|
// Page interface.
|
|
func (current MarkerPageBase) GetBody() interface{} {
|
|
return current.Body
|
|
}
|