model

package
v0.4.31 Latest Latest
Warning

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

Go to latest
Published: Feb 28, 2023 License: Apache-2.0 Imports: 21 Imported by: 49

Documentation

Index

Constants

View Source
const (
	DefaultWritePermissions = 0700
	ConfigFileName          = "config.yml"
)
View Source
const (
	EntityTypeModel              = "model"
	EntityTypeRegion             = "region"
	EntityTypeHost               = "host"
	EntityTypeComponent          = "component"
	EntityTypeParent             = "parent"
	EntityTypeSelfOrParent       = "selfOrParent"
	EntityTypeSelfOrParentSymbol = "^"
	EntityTypeChild              = "child"
	EntityTypeSelfOrChild        = "selfOrChild"
	EntityTypeAny                = "*"
)
View Source
const (
	SelectorTagPrefix = "."
	SelectorIdPrefix  = "#"
)
View Source
const Version = "0.4.0 (tw3n7ytw3n7y0n3)"

Variables

View Source
var CliInstanceId string

Functions

func ActiveInstanceId

func ActiveInstanceId() string

func ActiveInstancePath

func ActiveInstancePath() string

func AddBootstrapExtension

func AddBootstrapExtension(ext BootstrapExtension)

func AllocateDump

func AllocateDump(run string) string

func AllocateForensicScenario

func AllocateForensicScenario(run, scenario string) string

func Bootstrap

func Bootstrap() error

func BootstrapBindings

func BootstrapBindings() error

func BootstrapInstance

func BootstrapInstance() error

func BuildPath added in v0.4.0

func BuildPath() string

func ConfigBuild

func ConfigBuild() string

func ConfigDir added in v0.4.0

func ConfigDir() (string, error)

func CreateLabel

func CreateLabel(instanceId string, bindings map[string]string) error

func GetScopedEntityPath added in v0.4.0

func GetScopedEntityPath(entity Entity) []string

func HomeDir added in v0.4.0

func HomeDir() string

func InitModel added in v0.4.0

func InitModel(m *Model)

func KitBuild

func KitBuild() string

func ListDumps

func ListDumps() ([]string, error)

func MakeBuildPath added in v0.4.0

func MakeBuildPath(path string) string

func NewInstance

func NewInstance(id, workingDirectory string) (string, error)

func PersistConfig added in v0.4.0

func PersistConfig(config *FablabConfig) error

func PkiBuild

func PkiBuild() string

func ScriptBuild

func ScriptBuild() string

func Selector

func Selector(levels ...string) string

func SetActiveInstance

func SetActiveInstance(newInstanceId string) error

Types

type Action

type Action interface {
	Execute(m *Model) error
}

type ActionBinder

type ActionBinder func(m *Model) Action

func Bind added in v0.4.1

func Bind(action Action) ActionBinder

type ActionBinders

type ActionBinders map[string]ActionBinder

type ActionFunc

type ActionFunc func(m *Model) error

func (ActionFunc) Execute

func (f ActionFunc) Execute(m *Model) error

type ActivationStage

type ActivationStage interface {
	Activate(run Run) error
}

type ActivationStages

type ActivationStages []ActivationStage

type BootstrapExtension

type BootstrapExtension interface {
	Bootstrap(m *Model) error
}

type CachingVariableResolver added in v0.4.0

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

func NewCachingVariableResolver added in v0.4.0

func NewCachingVariableResolver(resolver VariableResolver) *CachingVariableResolver

func (*CachingVariableResolver) Resolve added in v0.4.0

func (self *CachingVariableResolver) Resolve(entity Entity, name string, scoped bool) (interface{}, bool)

type ChainedVariableResolver added in v0.4.0

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

func (*ChainedVariableResolver) AppendResolver added in v0.4.0

func (self *ChainedVariableResolver) AppendResolver(resolver VariableResolver)

func (*ChainedVariableResolver) Resolve added in v0.4.0

func (self *ChainedVariableResolver) Resolve(entity Entity, name string, scoped bool) (interface{}, bool)

type CmdLineArgVariableResolver added in v0.4.0

type CmdLineArgVariableResolver struct{}

func (CmdLineArgVariableResolver) Resolve added in v0.4.0

func (self CmdLineArgVariableResolver) Resolve(entity Entity, name string, _ bool) (interface{}, bool)

type Component

type Component struct {
	Scope
	Id              string
	Host            *Host
	ScriptSrc       string
	ScriptName      string
	ConfigSrc       string
	ConfigName      string
	BinaryName      string
	PublicIdentity  string
	PrivateIdentity string
	Index           uint32
	ScaleIndex      uint32
	RunWithSudo     bool
}

func (*Component) Accept

func (component *Component) Accept(visitor EntityVisitor)

func (*Component) CloneComponent added in v0.4.1

func (component *Component) CloneComponent(scaleIndex uint32) *Component

func (*Component) GetChildren

func (component *Component) GetChildren() []Entity

func (*Component) GetHost

func (component *Component) GetHost() *Host

func (*Component) GetId

func (component *Component) GetId() string

func (*Component) GetModel

func (component *Component) GetModel() *Model

func (*Component) GetParentEntity

func (component *Component) GetParentEntity() Entity

func (*Component) GetPath

func (component *Component) GetPath() string

func (*Component) GetPathId added in v0.4.1

func (component *Component) GetPathId() string

func (*Component) GetRegion

func (component *Component) GetRegion() *Region

func (*Component) GetScope

func (component *Component) GetScope() *Scope

func (*Component) GetType

func (component *Component) GetType() string

func (*Component) Matches

func (component *Component) Matches(entityType string, matcher EntityMatcher) bool

func (*Component) Region

func (component *Component) Region() *Region

type ComponentDump

type ComponentDump struct {
	Scope           *ScopeDump `json:"scope,omitempty"`
	ScriptSrc       string     `json:"script_src,omitempty"`
	ScriptName      string     `json:"script_name,omitempty"`
	ConfigSrc       string     `json:"config_src,omitempty"`
	ConfigName      string     `json:"config_name,omitempty"`
	BinaryName      string     `json:"binary_name,omitempty"`
	PublicIdentity  string     `json:"public_identity,omitempty"`
	PrivateIdentity string     `json:"private_identity,omitempty"`
}

type Components

type Components map[string]*Component

type ConfigurationStage

type ConfigurationStage interface {
	Configure(run Run) error
}

type ConfigurationStages

type ConfigurationStages []ConfigurationStage

type CpuTimeslice

type CpuTimeslice struct {
	TimestampMs   int64   `json:"timestamp_ms"`
	PercentUser   float64 `json:"percent_user"`
	PercentNice   float64 `json:"percent_nice"`
	PercentSystem float64 `json:"percent_system"`
	PercentIowait float64 `json:"percent_iowait"`
	PercentSteal  float64 `json:"percent_steal"`
	PercentIdle   float64 `json:"percent_idle"`
}

type Data

type Data map[string]interface{}

type DataMetricsWriter

type DataMetricsWriter struct {
}

func (DataMetricsWriter) AcceptHostMetrics

func (DataMetricsWriter) AcceptHostMetrics(host *Host, event *MetricsEvent)

type DefaultScaleEntityFactory added in v0.4.1

type DefaultScaleEntityFactory struct{}

func (DefaultScaleEntityFactory) CreateScaledComponent added in v0.4.1

func (self DefaultScaleEntityFactory) CreateScaledComponent(source *Component, scaleIndex uint32) (*Component, error)

func (DefaultScaleEntityFactory) CreateScaledHost added in v0.4.1

func (self DefaultScaleEntityFactory) CreateScaledHost(source *Host, scaleIndex uint32) (*Host, error)

func (DefaultScaleEntityFactory) CreateScaledRegion added in v0.4.1

func (self DefaultScaleEntityFactory) CreateScaledRegion(source *Region, scaleIndex uint32) (*Region, error)

type DisposalStage

type DisposalStage interface {
	Dispose(run Run) error
}

type DisposalStages

type DisposalStages []DisposalStage

type DistributionStage

type DistributionStage interface {
	Distribute(run Run) error
}

type DistributionStages

type DistributionStages []DistributionStage

type Dump

type Dump struct {
	Scope   *ScopeDump             `json:"scope,omitempty"`
	Regions map[string]*RegionDump `json:"regions"`
}

type Entity

type Entity interface {
	GetModel() *Model
	GetType() string
	GetId() string
	GetScope() *Scope
	GetParentEntity() Entity
	Accept(EntityVisitor)
	GetChildren() []Entity
	Matches(entityType string, matcher EntityMatcher) bool

	GetVariable(name string) (interface{}, bool)
	GetVariableOr(name string, defaultValue interface{}) interface{}
	MustVariable(name string) interface{}
}

type EntityMatcher

type EntityMatcher func(Entity) bool

func (EntityMatcher) And

func (EntityMatcher) Or

type EntityVisitor

type EntityVisitor func(Entity)

type EnvVariableResolver added in v0.4.0

type EnvVariableResolver struct{}

func (EnvVariableResolver) Resolve added in v0.4.0

func (self EnvVariableResolver) Resolve(entity Entity, name string, _ bool) (interface{}, bool)

type FablabConfig added in v0.4.0

type FablabConfig struct {
	Instances  map[string]*InstanceConfig `yaml:"instances"`
	Default    string                     `yaml:"default"`
	ConfigPath string                     `yaml:"-"`
}

func GetConfig added in v0.4.0

func GetConfig() *FablabConfig

func (*FablabConfig) GetSelectedInstanceId added in v0.4.0

func (self *FablabConfig) GetSelectedInstanceId() string

type Factory

type Factory interface {
	Build(m *Model) error
}

Factory builds model instances.

type HierarchicalVariableResolver added in v0.4.0

type HierarchicalVariableResolver struct{}

func (HierarchicalVariableResolver) Resolve added in v0.4.0

func (self HierarchicalVariableResolver) Resolve(entity Entity, name string, scoped bool) (interface{}, bool)

type Host

type Host struct {
	Scope
	Id                   string
	Region               *Region
	PublicIp             string
	PrivateIp            string
	InstanceType         string
	InstanceResourceType string
	SpotPrice            string
	SpotType             string
	Components           Components
	Index                uint32
	ScaleIndex           uint32
}

func (*Host) Accept

func (host *Host) Accept(visitor EntityVisitor)

func (*Host) CloneHost added in v0.4.1

func (host *Host) CloneHost(scaleIndex uint32) *Host

func (*Host) GetChildren

func (host *Host) GetChildren() []Entity

func (*Host) GetId

func (host *Host) GetId() string

func (*Host) GetModel

func (host *Host) GetModel() *Model

func (*Host) GetParentEntity

func (host *Host) GetParentEntity() Entity

func (*Host) GetPath

func (host *Host) GetPath() string

func (*Host) GetRegion

func (host *Host) GetRegion() *Region

func (*Host) GetScope

func (host *Host) GetScope() *Scope

func (*Host) GetType

func (host *Host) GetType() string

func (*Host) Matches

func (host *Host) Matches(entityType string, matcher EntityMatcher) bool

func (*Host) RangeSortedComponents added in v0.4.1

func (host *Host) RangeSortedComponents(f func(id string, component *Component))

func (*Host) RemoveComponent added in v0.4.1

func (host *Host) RemoveComponent(component *Component)

type HostDump

type HostDump struct {
	Scope                *ScopeDump                `json:"scope,omitempty"`
	PublicIp             string                    `json:"public_ip,omitempty"`
	PrivateIp            string                    `json:"private_ip,omitempty"`
	InstanceType         string                    `json:"instance_type,omitempty"`
	InstanceResourceType string                    `json:"instance_resource_type,omitempty"`
	SpotPrice            string                    `json:"spot_price,omitempty"`
	SpotType             string                    `json:"spot_type,omitempty"`
	Components           map[string]*ComponentDump `json:"components,omitempty"`
}

func DumpHost

func DumpHost(h *Host) *HostDump

type HostSummary

type HostSummary struct {
	Cpu     []*CpuTimeslice     `json:"cpu,omitempty"`
	Memory  []*MemoryTimeslice  `json:"memory,omitempty"`
	Process []*ProcessTimeslice `json:"process,omitempty"`
}

func (*HostSummary) ToMetricsEvents

func (hs *HostSummary) ToMetricsEvents() (events []*MetricsEvent)

type Hosts

type Hosts map[string]*Host

type IdPool added in v0.4.1

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

func (*IdPool) GetNextId added in v0.4.1

func (self *IdPool) GetNextId() uint32

func (*IdPool) ReturnId added in v0.4.1

func (self *IdPool) ReturnId(id uint32)

type InfrastructureStage

type InfrastructureStage interface {
	Express(run Run) error
}

type InfrastructureStages

type InfrastructureStages []InfrastructureStage

type InstanceConfig added in v0.4.0

type InstanceConfig struct {
	Id               string `yaml:"name"`
	Model            string `yaml:"model"`
	WorkingDirectory string `yaml:"working_directory"`
}

func GetActiveInstanceConfig added in v0.4.0

func GetActiveInstanceConfig() *InstanceConfig

func (*InstanceConfig) CleanupWorkingDir added in v0.4.0

func (self *InstanceConfig) CleanupWorkingDir() error

func (*InstanceConfig) LoadLabel added in v0.4.0

func (self *InstanceConfig) LoadLabel() (*Label, error)

type InstanceState

type InstanceState int
const (
	Created InstanceState = iota
	Expressed
	Configured
	Distributed
	Activated
	Operating
	Disposed
)

func (InstanceState) String

func (instanceState InstanceState) String() string

type IperfSummary

type IperfSummary struct {
	Timeslices    []*IperfTimeslice `json:"timeslices"`
	Bytes         float64           `json:"bytes"`
	BitsPerSecond float64           `json:"bits_per_second"`
}

type IperfTimeslice

type IperfTimeslice struct {
	TimestampMs   int64   `json:"timestamp_ms"`
	BitsPerSecond float64 `json:"bits_per_second"`
}

type IperfUdpSummary

type IperfUdpSummary struct {
	Timeslices    []*IperfUdpTimeslice `json:"timeslices"`
	Bytes         float64              `json:"bytes"`
	BitsPerSecond float64              `json:"bits_per_second"`
	JitterMs      float64              `json:"jitter_ms"`
	LostPackets   float64              `json:"lost_packets"`
}

type IperfUdpTimeslice

type IperfUdpTimeslice struct {
	TimestampMs   int64   `json:"timestamp_ms"`
	BitsPerSecond float64 `json:"bits_per_second"`
	Packets       float64 `json:"packets"`
}

type Label

type Label struct {
	InstanceId string        `yaml:"id"`
	Model      string        `yaml:"model"`
	State      InstanceState `yaml:"state"`
	Bindings   Variables     `yaml:"bindings"`
	// contains filtered or unexported fields
}

func GetLabel

func GetLabel() *Label

func LoadLabel

func LoadLabel(path string) (*Label, error)

func (*Label) GetFilePath

func (label *Label) GetFilePath(fileName string) string

func (*Label) Save

func (label *Label) Save() error

func (*Label) SaveAtPath

func (label *Label) SaveAtPath(path string) error

type MapVariableResolver added in v0.4.0

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

func NewMapVariableResolver added in v0.4.0

func NewMapVariableResolver(context string, variables Variables) *MapVariableResolver

func (*MapVariableResolver) Resolve added in v0.4.0

func (self *MapVariableResolver) Resolve(entity Entity, name string, _ bool) (interface{}, bool)

func (*MapVariableResolver) UpdateVariables added in v0.4.0

func (self *MapVariableResolver) UpdateVariables(variables Variables)

type MemoryTimeslice

type MemoryTimeslice struct {
	TimestampMs   int64   `json:"timestamp_ms"`
	MemFreeK      int64   `json:"free_k"`
	AvailK        int64   `json:"avail_k"`
	UsedK         int64   `json:"used_k"`
	UsedPercent   float64 `json:"used_percent"`
	BuffersK      int64   `json:"buffers_k"`
	CachedK       int64   `json:"cached_k"`
	CommitK       int64   `json:"commit_k"`
	CommitPercent float64 `json:"commit_percent"`
	ActiveK       int64   `json:"active_k"`
	InactiveK     int64   `json:"inactive_k"`
	DirtyK        int64   `json:"dirty_k"`
}

type MetricSet

type MetricSet map[string]interface{}

func (MetricSet) AddGroupedMetric

func (s MetricSet) AddGroupedMetric(group, name string, val interface{})

func (MetricSet) VisitGroupedMetrics

func (s MetricSet) VisitGroupedMetrics(f func(name string, group MetricSet))

func (MetricSet) VisitUngroupedMetrics

func (s MetricSet) VisitUngroupedMetrics(f func(name string, val interface{}))

type MetricsEvent

type MetricsEvent struct {
	Timestamp time.Time
	Metrics   MetricSet
	Tags      map[string]string
}

type MetricsHandler

type MetricsHandler interface {
	AcceptHostMetrics(host *Host, event *MetricsEvent)
}

type Model

type Model struct {
	Id string

	Scope
	VarConfig           VarConfig
	Regions             Regions
	StructureFactories  []Factory // Factories that change the model structure, eg: add/remove hosts
	Factories           []Factory
	BootstrapExtensions []BootstrapExtension
	Actions             map[string]ActionBinder
	Infrastructure      InfrastructureStages
	Configuration       ConfigurationStages
	Distribution        DistributionStages
	Activation          ActivationStages
	Operation           OperatingStages
	Disposal            DisposalStages
	MetricsHandlers     []MetricsHandler
	Resources           Resources
	// contains filtered or unexported fields
}

func GetModel

func GetModel() *Model

func (*Model) Accept

func (m *Model) Accept(visitor EntityVisitor)

func (*Model) AcceptHostMetrics

func (m *Model) AcceptHostMetrics(host *Host, event *MetricsEvent)

func (*Model) Activate

func (m *Model) Activate(run Run) error

func (*Model) AddActivationActions

func (m *Model) AddActivationActions(actions ...string)

func (*Model) AddActivationStage

func (m *Model) AddActivationStage(stage ActivationStage)

func (*Model) AddActivationStages

func (m *Model) AddActivationStages(stage ...ActivationStage)

func (*Model) AddOperatingActions

func (m *Model) AddOperatingActions(actions ...string)

func (*Model) AddOperatingStage

func (m *Model) AddOperatingStage(stage OperatingStage)

func (*Model) AddOperatingStageF added in v0.4.0

func (m *Model) AddOperatingStageF(stage OperatingStageF)

func (*Model) AddOperatingStages

func (m *Model) AddOperatingStages(stages ...OperatingStage)

func (*Model) BindLabel

func (m *Model) BindLabel(l *Label)

func (*Model) Build

func (m *Model) Build(run Run) error

func (*Model) Dispose

func (m *Model) Dispose(run Run) error

func (*Model) Dump

func (m *Model) Dump() *Dump

func (*Model) Express

func (m *Model) Express(run Run) error

func (*Model) ForEachComponent

func (m *Model) ForEachComponent(spec string, concurrency int, f func(c *Component) error) error

func (*Model) ForEachHost

func (m *Model) ForEachHost(spec string, concurrency int, f func(host *Host) error) error

func (*Model) GetAction

func (m *Model) GetAction(name string) (Action, bool)

func (*Model) GetActions added in v0.4.1

func (m *Model) GetActions() []string

func (*Model) GetChildren

func (m *Model) GetChildren() []Entity

func (*Model) GetId

func (m *Model) GetId() string

func (*Model) GetModel

func (m *Model) GetModel() *Model

func (*Model) GetNextComponentIndex added in v0.4.1

func (m *Model) GetNextComponentIndex() uint32

func (*Model) GetNextHostIndex added in v0.4.1

func (m *Model) GetNextHostIndex() uint32

func (*Model) GetNextRegionIndex added in v0.4.1

func (m *Model) GetNextRegionIndex() uint32

func (*Model) GetParentEntity

func (m *Model) GetParentEntity() Entity

func (*Model) GetResource added in v0.4.0

func (m *Model) GetResource(name string) fs.FS

func (*Model) GetScope

func (m *Model) GetScope() *Scope

func (*Model) GetType

func (m *Model) GetType() string

func (*Model) IsBound

func (m *Model) IsBound() bool

func (*Model) IterateScopes

func (m *Model) IterateScopes(f func(i Entity, path ...string))

func (*Model) Matches

func (m *Model) Matches(entityType string, matcher EntityMatcher) bool

func (*Model) MustSelectHost

func (m *Model) MustSelectHost(spec string) *Host

func (*Model) MustSelectHosts

func (m *Model) MustSelectHosts(spec string, minCount int) ([]*Host, error)

func (*Model) MustSelectRegion

func (m *Model) MustSelectRegion(spec string) *Region

func (*Model) Operate

func (m *Model) Operate(run Run) error

func (*Model) RangeSortedRegions added in v0.4.1

func (m *Model) RangeSortedRegions(f func(id string, region *Region))

func (*Model) RemoveRegion added in v0.4.1

func (m *Model) RemoveRegion(region *Region)

func (*Model) SelectComponent

func (m *Model) SelectComponent(spec string) (*Component, error)

func (*Model) SelectComponents

func (m *Model) SelectComponents(spec string) []*Component

func (*Model) SelectHost

func (m *Model) SelectHost(spec string) (*Host, error)

func (*Model) SelectHosts

func (m *Model) SelectHosts(spec string) []*Host

func (*Model) SelectRegion

func (m *Model) SelectRegion(spec string) (*Region, error)

func (*Model) SelectRegions

func (m *Model) SelectRegions(spec string) []*Region

func (*Model) Sync

func (m *Model) Sync(run Run) error

type OperatingStage

type OperatingStage interface {
	Operate(run Run) error
}

type OperatingStageF added in v0.4.0

type OperatingStageF func(run Run) error

func (OperatingStageF) Operate added in v0.4.0

func (self OperatingStageF) Operate(run Run) error

type OperatingStages

type OperatingStages []OperatingStage

type ProcessTimeslice

type ProcessTimeslice struct {
	TimestampMs     int64   `json:"timestamp_ms"`
	RunQueueSize    int64   `json:"run_queue_size"`
	ProcessListSize int64   `json:"process_list_size"`
	LoadAverage1m   float64 `json:"load_average_1m"`
	LoadAverage5m   float64 `json:"load_average_5m"`
	LoadAverage15m  float64 `json:"load_average_15m"`
	Blocked         int64   `json:"blocked"`
}

type Region

type Region struct {
	Scope
	Model      *Model
	Id         string
	Region     string
	Site       string
	Hosts      Hosts
	Index      uint32
	ScaleIndex uint32
}

func (*Region) Accept

func (region *Region) Accept(visitor EntityVisitor)

func (*Region) CloneRegion added in v0.4.1

func (region *Region) CloneRegion(scaleIndex uint32) *Region

func (*Region) GetChildren

func (region *Region) GetChildren() []Entity

func (*Region) GetId

func (region *Region) GetId() string

func (*Region) GetModel

func (region *Region) GetModel() *Model

func (*Region) GetParentEntity

func (region *Region) GetParentEntity() Entity

func (*Region) GetScope

func (region *Region) GetScope() *Scope

func (*Region) GetType

func (region *Region) GetType() string

func (*Region) Matches

func (region *Region) Matches(entityType string, matcher EntityMatcher) bool

func (*Region) RangeSortedHosts added in v0.4.1

func (region *Region) RangeSortedHosts(f func(id string, host *Host))

func (*Region) RemoveHost added in v0.4.1

func (region *Region) RemoveHost(host *Host)

func (*Region) SelectHosts

func (region *Region) SelectHosts(hostSpec string) map[string]*Host

type RegionDump

type RegionDump struct {
	Scope *ScopeDump           `json:"scope,omitempty"`
	Id    string               `json:"id,omitempty"`
	Az    string               `json:"az,omitempty"`
	Hosts map[string]*HostDump `json:"hosts,omitempty"`
}

type Regions

type Regions map[string]*Region

type Resource added in v0.4.0

type Resource fs.FS

type Resources added in v0.4.0

type Resources map[string]Resource

type Run

type Run interface {
	GetModel() *Model
	GetLabel() *Label
	GetId() string
}

func NewRun

func NewRun() Run

type ScaleEntityFactory added in v0.4.1

type ScaleEntityFactory interface {
	CreateScaledRegion(source *Region, scaleIndex uint32) (*Region, error)
	CreateScaledHost(source *Host, scaleIndex uint32) (*Host, error)
	CreateScaledComponent(source *Component, scaleIndex uint32) (*Component, error)
}

type ScaleFactory added in v0.4.1

type ScaleFactory struct {
	Strategy      ScaleStrategy
	EntityFactory ScaleEntityFactory
}

func NewScaleFactory added in v0.4.1

func NewScaleFactory(strategy ScaleStrategy, factory ScaleEntityFactory) *ScaleFactory

func NewScaleFactoryWithDefaultEntityFactory added in v0.4.1

func NewScaleFactoryWithDefaultEntityFactory(strategy ScaleStrategy) *ScaleFactory

func (*ScaleFactory) Build added in v0.4.1

func (factory *ScaleFactory) Build(m *Model) error

func (*ScaleFactory) ProcessComponents added in v0.4.1

func (factory *ScaleFactory) ProcessComponents(m *Model) error

func (*ScaleFactory) ProcessHosts added in v0.4.1

func (factory *ScaleFactory) ProcessHosts(m *Model) error

func (*ScaleFactory) ProcessRegions added in v0.4.1

func (factory *ScaleFactory) ProcessRegions(m *Model) error

type ScaleStrategy added in v0.4.1

type ScaleStrategy interface {
	IsScaled(entity Entity) bool
	GetEntityCount(entity Entity) uint32
}

type Scope

type Scope struct {
	Defaults         Variables
	VariableResolver VariableResolver
	Data             Data
	Tags             Tags
	// contains filtered or unexported fields
}

func (*Scope) CloneScope added in v0.4.1

func (scope *Scope) CloneScope() *Scope

func (*Scope) GetBoolVariable added in v0.4.0

func (scope *Scope) GetBoolVariable(name string) (bool, bool)

func (*Scope) GetRequiredStringVariable added in v0.4.0

func (scope *Scope) GetRequiredStringVariable(holder errorz.ErrorHolder, name string) string

func (*Scope) GetStringVariable added in v0.4.0

func (scope *Scope) GetStringVariable(name string) (string, bool)

func (*Scope) GetStringVariableOr added in v0.4.0

func (scope *Scope) GetStringVariableOr(name string, defaultValue string) string

func (*Scope) GetVariable added in v0.4.0

func (scope *Scope) GetVariable(name string) (interface{}, bool)

func (*Scope) GetVariableOr added in v0.4.0

func (scope *Scope) GetVariableOr(name string, defaultValue interface{}) interface{}

func (*Scope) HasLocalOrAncestralTag added in v0.4.1

func (scope *Scope) HasLocalOrAncestralTag(tag string) bool

func (*Scope) HasTag

func (scope *Scope) HasTag(tag string) bool

func (*Scope) HasVariable added in v0.4.0

func (scope *Scope) HasVariable(name string) bool

func (*Scope) MustStringVariable added in v0.4.0

func (scope *Scope) MustStringVariable(name string) string

func (*Scope) MustVariable added in v0.4.0

func (scope *Scope) MustVariable(name string) interface{}

func (*Scope) PutVariable added in v0.4.0

func (scope *Scope) PutVariable(name string, value interface{})

func (*Scope) WithTags

func (scope *Scope) WithTags(tags ...string) *Scope

type ScopeDump

type ScopeDump struct {
	Variables map[string]interface{} `json:"variables,omitempty"`
	Data      map[string]interface{} `json:"data,omitempty"`
	Tags      []string               `json:"tags,omitempty"`
}

type ScopedVariableResolver added in v0.4.0

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

func NewScopedVariableResolver added in v0.4.0

func NewScopedVariableResolver(resolver VariableResolver) *ScopedVariableResolver

func (*ScopedVariableResolver) Resolve added in v0.4.0

func (self *ScopedVariableResolver) Resolve(entity Entity, name string, scoped bool) (interface{}, bool)

type StdOutMetricsWriter

type StdOutMetricsWriter struct {
}

func (StdOutMetricsWriter) AcceptHostMetrics

func (StdOutMetricsWriter) AcceptHostMetrics(host *Host, event *MetricsEvent)

type Tags

type Tags []string

type Templater added in v0.4.1

type Templater struct {
	errorz.ErrorHolderImpl
	// contains filtered or unexported fields
}

func (*Templater) TemplatizeComponent added in v0.4.1

func (self *Templater) TemplatizeComponent(component *Component)

func (*Templater) TemplatizeHost added in v0.4.1

func (self *Templater) TemplatizeHost(host *Host)

func (*Templater) TemplatizeRegion added in v0.4.1

func (self *Templater) TemplatizeRegion(region *Region)

func (*Templater) TemplatizeScope added in v0.4.1

func (self *Templater) TemplatizeScope(scope *Scope)

func (*Templater) TemplatizeString added in v0.4.1

func (self *Templater) TemplatizeString(val string) string

type VarConfig added in v0.4.0

type VarConfig struct {
	VariableNameParser            VariableNameParser
	CommandLineVariableNameMapper VariableNameMapper
	CommandLinePrefixes           []string
	EnvVariableNameMapper         VariableNameMapper
	DefaultVariableResolver       VariableResolver
	DefaultScopedVariableResolver VariableResolver
	SecretsKeys                   []string
	VariableNamePrefixMapper      VariableNamePrefixMapper
	ResolverLogger                func(resolver string, entity Entity, name string, result interface{}, found bool, msgAndArgs ...interface{})
	BindingResolver               *MapVariableResolver
	LabelResolver                 *MapVariableResolver
}

func (*VarConfig) EnableDebugLogger added in v0.4.0

func (self *VarConfig) EnableDebugLogger()

func (*VarConfig) SetDefaults added in v0.4.0

func (self *VarConfig) SetDefaults()

type VariableDump

type VariableDump struct {
	Description    string `json:"description,omitempty"`
	Default        string `json:"default,omitempty"`
	Required       bool   `json:"required"`
	Scoped         bool   `json:"scoped"`
	GlobalFallback bool   `json:"global_fallback"`
	Sensitive      bool   `json:"sensitive"`
	Binder         string `json:"binder,omitempty"`
	Value          string `json:"value,omitempty"`
	Bound          bool   `json:"bound"`
}

type VariableNameMapper added in v0.4.0

type VariableNameMapper func(string) string

type VariableNameParser added in v0.4.0

type VariableNameParser func(string) []string

type VariableNamePrefixMapper added in v0.4.0

type VariableNamePrefixMapper func(entityPath []string, name string) string

type VariableResolver added in v0.4.0

type VariableResolver interface {
	Resolve(entity Entity, name string, scoped bool) (interface{}, bool)
}

type Variables

type Variables map[string]interface{}

func (Variables) Canonicalize added in v0.4.0

func (v Variables) Canonicalize()

func (Variables) Clone added in v0.4.1

func (v Variables) Clone() Variables

func (Variables) ForEach added in v0.4.1

func (v Variables) ForEach(f func(k string, v interface{}) (bool, interface{}))

func (Variables) Get

func (v Variables) Get(name []string) (interface{}, bool)

func (Variables) Put

func (v Variables) Put(name []string, newValue interface{})

type ZitiFabricLinkMetricsSummary

type ZitiFabricLinkMetricsSummary struct {
	LinkId        string  `json:"link_id"`
	LatencyP9999  float64 `json:"latency_p9999"`
	RxBytesRateM1 float64 `json:"rx_bytes_rate_m1"`
	TxBytesRateM1 float64 `json:"tx_bytes_rate_m1"`
}

type ZitiFabricLinkSummary

type ZitiFabricLinkSummary struct {
	LinkId      string  `json:"link_id"`
	State       string  `json:"state"`
	SrcRouterId string  `json:"src_router_id"`
	SrcLatency  float64 `json:"src_latency"`
	DstRouterId string  `json:"dst_router_id"`
	DstLatency  float64 `json:"dst_latency"`
}

type ZitiFabricMeshSummary

type ZitiFabricMeshSummary struct {
	TimestampMs int64                   `json:"timestamp_ms"`
	RouterIds   []string                `json:"router_ids"`
	Links       []ZitiFabricLinkSummary `json:"links,omitempty"`
}

type ZitiFabricRouterMetricsSummary

type ZitiFabricRouterMetricsSummary struct {
	SourceId             string                         `json:"source_id"`
	TimestampMs          int64                          `json:"timestamp_ms"`
	FabricRxBytesRateM1  float64                        `json:"fabric_rx_bytes_rate_m1"`
	FabricTxBytesRateM1  float64                        `json:"fabric_tx_bytes_rate_m1"`
	IngressRxBytesRateM1 float64                        `json:"ingress_rx_bytes_rate_m1"`
	IngressTxBytesRateM1 float64                        `json:"ingress_tx_bytes_rate_m1"`
	EgressRxBytesRateM1  float64                        `json:"egress_rx_bytes_rate_m1"`
	EgressTxBytesRateM1  float64                        `json:"egress_tx_bytes_rate_m1"`
	Links                []ZitiFabricLinkMetricsSummary `json:"links,omitempty"`
}

Jump to

Keyboard shortcuts

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