packer-cn/vendor/github.com/yandex-cloud/go-sdk/sdkresolvers/dataproc_resolver.go

75 lines
2.1 KiB
Go

// Copyright (c) 2019 YANDEX LLC.
package sdkresolvers
import (
"context"
"google.golang.org/grpc"
dataproc "github.com/yandex-cloud/go-genproto/yandex/cloud/dataproc/v1"
ycsdk "github.com/yandex-cloud/go-sdk"
)
type dataprocClusterResolver struct {
BaseNameResolver
}
func DataprocClusterResolver(name string, opts ...ResolveOption) ycsdk.Resolver {
return &dataprocClusterResolver{
BaseNameResolver: NewBaseNameResolver(name, "cluster", opts...),
}
}
func (r *dataprocClusterResolver) Run(ctx context.Context, sdk *ycsdk.SDK, opts ...grpc.CallOption) error {
err := r.ensureFolderID()
if err != nil {
return err
}
resp, err := sdk.Dataproc().Cluster().List(ctx, &dataproc.ListClustersRequest{
FolderId: r.FolderID(),
Filter: CreateResolverFilter("name", r.Name),
PageSize: DefaultResolverPageSize,
}, opts...)
return r.findName(resp.GetClusters(), err)
}
type dataprocSubclusterResolver struct {
BaseNameResolver
}
func DataprocSubclusterResolver(name string, opts ...ResolveOption) ycsdk.Resolver {
return &dataprocSubclusterResolver{
BaseNameResolver: NewBaseNameResolver(name, "subcluster", opts...),
}
}
func (r *dataprocSubclusterResolver) Run(ctx context.Context, sdk *ycsdk.SDK, opts ...grpc.CallOption) error {
resp, err := sdk.Dataproc().Subcluster().List(ctx, &dataproc.ListSubclustersRequest{
ClusterId: r.opts.clusterID,
Filter: CreateResolverFilter("name", r.Name),
PageSize: DefaultResolverPageSize,
}, opts...)
return r.findName(resp.GetSubclusters(), err)
}
type dataprocJobResolver struct {
BaseNameResolver
}
func DataprocJobResolver(name string, opts ...ResolveOption) ycsdk.Resolver {
return &dataprocJobResolver{
BaseNameResolver: NewBaseNameResolver(name, "job", opts...),
}
}
func (r *dataprocJobResolver) Run(ctx context.Context, sdk *ycsdk.SDK, opts ...grpc.CallOption) error {
resp, err := sdk.Dataproc().Job().List(ctx, &dataproc.ListJobsRequest{
ClusterId: r.opts.clusterID,
Filter: CreateResolverFilter("name", r.Name),
PageSize: DefaultResolverPageSize,
}, opts...)
return r.findName(resp.GetJobs(), err)
}