Documentation ¶
Index ¶
- func DestroyCluster(ctx context.Context, api API, clusterId string) error
- func DialPort(ctx context.Context, cluster *KubernetesCluster, targetPort int) (net.Conn, error)
- func DialPortWithToken(ctx context.Context, token fnapi.Token, cluster *KubernetesCluster, ...) (net.Conn, error)
- func Register()
- func RegistryCreds(ctx context.Context) (*authn.Basic, error)
- func SetupFlags(flags *pflag.FlagSet, hide bool)
- func StartRefreshing(ctx context.Context, api API, clusterId string, handle func(error) error) error
- func TailClusterLogs(ctx context.Context, api API, opts *LogsOpts, handle func(LogBlock) error) error
- type API
- type Attachment
- type BuildCluster
- type BuildCluster_ColocatedPort
- type ClusterShape
- type CreateClusterOpts
- type CreateClusterResult
- type CreateKubernetesClusterRequest
- type CreateKubernetesClusterResponse
- type DestroyKubernetesClusterRequest
- type GetKubernetesClusterRequest
- type GetKubernetesClusterResponse
- type GetLogsRequest
- type GetLogsResponse
- type GithubWorkflowInfo
- type ImageRegistry
- type KubernetesCluster
- type KubernetesClusterMetadata
- type LabelEntry
- type ListKubernetesClustersRequest
- type ListKubernetesClustersResponse
- type LogBlock
- type LogLine
- type LogsOpts
- type LogsSelector
- type RefreshKubernetesClusterRequest
- type RefreshKubernetesClusterResponse
- type StartCreateKubernetesClusterResponse
- type TailLogsRequest
- type WaitKubernetesClusterRequest
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func DialPortWithToken ¶ added in v0.0.165
func RegistryCreds ¶ added in v0.0.166
func SetupFlags ¶ added in v0.0.164
func StartRefreshing ¶ added in v0.0.181
Types ¶
type API ¶ added in v0.0.103
type API struct { StartCreateKubernetesCluster fnapi.Call[CreateKubernetesClusterRequest] GetKubernetesCluster fnapi.Call[GetKubernetesClusterRequest] WaitKubernetesCluster fnapi.Call[WaitKubernetesClusterRequest] ListKubernetesClusters fnapi.Call[ListKubernetesClustersRequest] DestroyKubernetesCluster fnapi.Call[DestroyKubernetesClusterRequest] RefreshKubernetesCluster fnapi.Call[RefreshKubernetesClusterRequest] TailClusterLogs fnapi.Call[TailLogsRequest] GetClusterLogs fnapi.Call[GetLogsRequest] }
var Endpoint API
type Attachment ¶ added in v0.0.167
type BuildCluster ¶
type BuildCluster struct {
Colocated *BuildCluster_ColocatedPort `json:"colocated,omitempty"`
}
type ClusterShape ¶
type CreateClusterOpts ¶ added in v0.0.135
type CreateClusterOpts struct { MachineType string Ephemeral bool // Whether to keep the cluster alive, regardless of it being ephemeral. // This is typically needed if you want to execute multiple ns commands on an ephemeral cluster. KeepAtExit bool Purpose string Features []string AuthorizedSshKeys []string UniqueTag string }
type CreateClusterResult ¶
type CreateClusterResult struct { ClusterId string Cluster *KubernetesCluster Registry *ImageRegistry BuildCluster *BuildCluster Deadline *time.Time }
func CreateAndWaitCluster ¶
func CreateAndWaitCluster(ctx context.Context, api API, opts CreateClusterOpts) (*CreateClusterResult, error)
func EnsureBuildCluster ¶ added in v0.0.166
func EnsureBuildCluster(ctx context.Context, api API) (*CreateClusterResult, error)
func WaitCluster ¶
type CreateKubernetesClusterRequest ¶
type CreateKubernetesClusterRequest struct { OpaqueUserAuth []byte `json:"opaque_user_auth,omitempty"` Ephemeral bool `json:"ephemeral,omitempty"` DocumentedPurpose string `json:"documented_purpose,omitempty"` AuthorizedSshKeys []string `json:"authorized_ssh_keys,omitempty"` MachineType string `json:"machine_type,omitempty"` Feature []string `json:"feature,omitempty"` UniqueTag string `json:"unique_tag,omitempty"` }
type CreateKubernetesClusterResponse ¶
type CreateKubernetesClusterResponse struct { Status string `json:"status,omitempty"` ClusterId string `json:"cluster_id,omitempty"` Cluster *KubernetesCluster `json:"cluster,omitempty"` Registry *ImageRegistry `json:"registry,omitempty"` BuildCluster *BuildCluster `json:"build_cluster,omitempty"` Deadline string `json:"deadline,omitempty"` }
type GetKubernetesClusterResponse ¶
type GetKubernetesClusterResponse struct { Cluster *KubernetesCluster `json:"cluster,omitempty"` Registry *ImageRegistry `json:"registry,omitempty"` BuildCluster *BuildCluster `json:"build_cluster,omitempty"` Deadline string `json:"deadline,omitempty"` }
func GetCluster ¶
type GetLogsRequest ¶ added in v0.0.168
type GetLogsRequest struct { ClusterID string `json:"cluster_id,omitempty"` StartTs *time.Time `json:"start_ts,omitempty"` EndTs *time.Time `json:"end_ts,omitempty"` Include []*LogsSelector `json:"include,omitempty"` Exclude []*LogsSelector `json:"exclude,omitempty"` }
type GetLogsResponse ¶ added in v0.0.168
type GetLogsResponse struct {
LogBlock []LogBlock `json:"log_block,omitempty"`
}
func GetClusterLogs ¶ added in v0.0.168
type GithubWorkflowInfo ¶ added in v0.0.175
type GithubWorkflowInfo struct { Repository string `json:"repository,omitempty"` RunId string `json:"run_id,omitempty"` RunAttempt string `json:"run_attempt,omitempty"` Sha string `json:"sha,omitempty"` Ref string `json:"ref,omitempty"` Actor string `json:"actor,omitempty"` Workflow string `json:"workflow,omitempty"` }
type ImageRegistry ¶
type ImageRegistry struct {
EndpointAddress string `json:"endpoint_address,omitempty"`
}
type KubernetesCluster ¶
type KubernetesCluster struct { AppURL string `json:"app_url,omitempty"` ClusterId string `json:"cluster_id,omitempty"` Created string `json:"created,omitempty"` DestroyedAt string `json:"destroyed_at,omitempty"` Deadline string `json:"deadline,omitempty"` SSHProxyEndpoint string `json:"ssh_proxy_endpoint,omitempty"` SshPrivateKey []byte `json:"ssh_private_key,omitempty"` DocumentedPurpose string `json:"documented_purpose,omitempty"` Shape *ClusterShape `json:"shape,omitempty"` EndpointAddress string `json:"endpoint_address,omitempty"` CertificateAuthorityData []byte `json:"certificate_authority_data,omitempty"` ClientCertificateData []byte `json:"client_certificate_data,omitempty"` ClientKeyData []byte `json:"client_key_data,omitempty"` KubernetesDistribution string `json:"kubernetes_distribution,omitempty"` Platform []string `json:"platform,omitempty"` IngressDomain string `json:"ingress_domain,omitempty"` Label []*LabelEntry `json:"label,omitempty"` CreatorId string `json:"creator_id,omitempty"` GithubWorkflow *GithubWorkflowInfo `json:"github_workflow,omitempty"` }
type KubernetesClusterMetadata ¶ added in v0.0.176
type KubernetesClusterMetadata struct { ClusterId string `json:"cluster_id,omitempty"` Created string `json:"created,omitempty"` DestroyedAt string `json:"destroyed_at,omitempty"` Deadline string `json:"deadline,omitempty"` DocumentedPurpose string `json:"documented_purpose,omitempty"` Shape *ClusterShape `json:"shape,omitempty"` KubernetesDistribution string `json:"kubernetes_distribution,omitempty"` Platform []string `json:"platform,omitempty"` IngressDomain string `json:"ingress_domain,omitempty"` Label []*LabelEntry `json:"label,omitempty"` CreatorId string `json:"creator_id,omitempty"` GithubWorkflow *GithubWorkflowInfo `json:"github_workflow,omitempty"` }
type LabelEntry ¶
type ListKubernetesClustersResponse ¶ added in v0.0.176
type ListKubernetesClustersResponse struct {
Clusters []KubernetesClusterMetadata `json:"cluster"`
}
func ListClusters ¶
type LogLine ¶ added in v0.0.168
type LogsOpts ¶ added in v0.0.168
type LogsOpts struct { ClusterID string StartTs *time.Time EndTs *time.Time Include []*LogsSelector Exclude []*LogsSelector }
type LogsSelector ¶ added in v0.0.168
type RefreshKubernetesClusterRequest ¶ added in v0.0.181
type RefreshKubernetesClusterRequest struct {
ClusterId string `json:"cluster_id,omitempty"`
}
type RefreshKubernetesClusterResponse ¶ added in v0.0.181
type RefreshKubernetesClusterResponse struct {
NewDeadline string `json:"new_deadline,omitempty"`
}
func RefreshCluster ¶ added in v0.0.181
type StartCreateKubernetesClusterResponse ¶
type StartCreateKubernetesClusterResponse struct { ClusterId string `json:"cluster_id,omitempty"` ClusterFragment *KubernetesCluster `json:"cluster_fragment,omitempty"` Registry *ImageRegistry `json:"registry,omitempty"` Deadline string `json:"deadline,omitempty"` }
func CreateCluster ¶
func CreateCluster(ctx context.Context, api API, opts CreateClusterOpts) (*StartCreateKubernetesClusterResponse, error)
type TailLogsRequest ¶ added in v0.0.168
type TailLogsRequest struct { ClusterID string `json:"cluster_id,omitempty"` Include []*LogsSelector `json:"include,omitempty"` Exclude []*LogsSelector `json:"exclude,omitempty"` }
Click to show internal directories.
Click to hide internal directories.