minion

package
v0.0.0-...-346ceef Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: May 30, 2023 License: Apache-2.0 Imports: 13 Imported by: 0

Documentation

Overview

Package minion provides Registry interface and implementation for storing Minions.

Index

Constants

This section is empty.

Variables

View Source
var ErrDoesNotExist = fmt.Errorf("The requested resource does not exist.")
View Source
var ErrNotHealty = fmt.Errorf("The requested minion is not healthy.")

Functions

This section is empty.

Types

type CachingRegistry

type CachingRegistry struct {
	// contains filtered or unexported fields
}

func (*CachingRegistry) CreateMinion

func (r *CachingRegistry) CreateMinion(ctx api.Context, minion *api.Minion) error

func (*CachingRegistry) DeleteMinion

func (r *CachingRegistry) DeleteMinion(ctx api.Context, nodeID string) error

func (*CachingRegistry) GetMinion

func (r *CachingRegistry) GetMinion(ctx api.Context, nodeID string) (*api.Minion, error)

func (*CachingRegistry) ListMinions

func (r *CachingRegistry) ListMinions(ctx api.Context) (*api.MinionList, error)

type Clock

type Clock interface {
	Now() time.Time
}

type CloudRegistry

type CloudRegistry struct {
	// contains filtered or unexported fields
}

func NewCloudRegistry

func NewCloudRegistry(cloud cloudprovider.Interface, matchRE string, staticResources *api.NodeResources) (*CloudRegistry, error)

func (CloudRegistry) CreateMinion

func (r CloudRegistry) CreateMinion(ctx api.Context, minion *api.Minion) error

func (CloudRegistry) DeleteMinion

func (r CloudRegistry) DeleteMinion(ctx api.Context, nodeID string) error

func (*CloudRegistry) GetMinion

func (r *CloudRegistry) GetMinion(ctx api.Context, nodeID string) (*api.Minion, error)

func (*CloudRegistry) ListMinions

func (r *CloudRegistry) ListMinions(ctx api.Context) (*api.MinionList, error)

type HealthyRegistry

type HealthyRegistry struct {
	// contains filtered or unexported fields
}

func (*HealthyRegistry) CreateMinion

func (r *HealthyRegistry) CreateMinion(ctx api.Context, minion *api.Minion) error

func (*HealthyRegistry) DeleteMinion

func (r *HealthyRegistry) DeleteMinion(ctx api.Context, minionID string) error

func (*HealthyRegistry) GetMinion

func (r *HealthyRegistry) GetMinion(ctx api.Context, minionID string) (*api.Minion, error)

func (*HealthyRegistry) ListMinions

func (r *HealthyRegistry) ListMinions(ctx api.Context) (currentMinions *api.MinionList, err error)

type REST

type REST struct {
	// contains filtered or unexported fields
}

REST implements the RESTStorage interface, backed by a MinionRegistry.

func NewREST

func NewREST(m Registry) *REST

NewREST returns a new REST.

func (*REST) Create

func (rs *REST) Create(ctx api.Context, obj runtime.Object) (<-chan runtime.Object, error)

func (*REST) Delete

func (rs *REST) Delete(ctx api.Context, id string) (<-chan runtime.Object, error)

func (*REST) Get

func (rs *REST) Get(ctx api.Context, id string) (runtime.Object, error)

func (*REST) List

func (rs *REST) List(ctx api.Context, label, field labels.Selector) (runtime.Object, error)

func (*REST) New

func (rs *REST) New() runtime.Object

func (*REST) Update

func (rs *REST) Update(ctx api.Context, minion runtime.Object) (<-chan runtime.Object, error)

type Registry

type Registry interface {
	ListMinions(ctx api.Context) (*api.MinionList, error)
	CreateMinion(ctx api.Context, minion *api.Minion) error
	GetMinion(ctx api.Context, minionID string) (*api.Minion, error)
	DeleteMinion(ctx api.Context, minionID string) error
}

MinionRegistry is an interface for things that know how to store minions.

func NewCachingRegistry

func NewCachingRegistry(delegate Registry, ttl time.Duration) (Registry, error)

func NewHealthyRegistry

func NewHealthyRegistry(delegate Registry, client *http.Client) Registry

type SystemClock

type SystemClock struct{}

func (SystemClock) Now

func (SystemClock) Now() time.Time

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL