Documentation ¶
Index ¶
Constants ¶
View Source
const DefaultMembraneVersion = "v0.22.0"
//go:embed membraneversion.txt var DefaultMembraneVersion string TODO delete this later
Variables ¶
View Source
var DefaultOTELCollectorVersion string
Functions ¶
This section is empty.
Types ¶
type Collection ¶
type Collection struct{}
type ComputeUnit ¶
type ComputeUnit struct { Name string `yaml:"-"` // Triggers used to invoke this compute unit, e.g. Topic Subscriptions Triggers Triggers `yaml:"triggers,omitempty"` // The memory of the compute instance in MB: default 128 Memory int `yaml:"memory,omitempty"` // The minimum number of instances to keep alive: default 0 MinScale int `yaml:"minScale,omitempty"` // The maximum number of instances to scale to: default 10 MaxScale int `yaml:"maxScale,omitempty"` // The max running time of the function: default 15 Timeout int `yaml:"timeout,omitempty"` // Telemetry sampling percentage Telemetry int `yaml:"telemetry,omitempty"` }
type Config ¶
type Config struct { Name string `yaml:"name"` Dir string `yaml:"-"` Handlers []string `yaml:"handlers"` }
func ConfigFromProjectPath ¶ added in v1.4.0
ConfigFromProjectPath - loads the config nitric.yaml file from the project path, defaults to the current working directory
type Container ¶
type Container struct { Dockerfile string `yaml:"dockerfile"` Args []string `yaml:"args,omitempty"` ComputeUnit `yaml:",inline"` }
func (*Container) ImageTagName ¶
ImageTagName returns the default image tag for a source image built from this function provider the provider name (e.g. aws), used to uniquely identify builds for specific providers
func (*Container) Unit ¶
func (c *Container) Unit() *ComputeUnit
type Function ¶
type Function struct { // The location of the function handler Handler string `yaml:"handler"` ComputeUnit `yaml:",inline"` // The number of workers this function contains WorkerCount int }
func FunctionFromHandler ¶
func (*Function) ImageTagName ¶
ImageTagName returns the default image tag for a source image built from this function provider the provider name (e.g. aws), used to uniquely identify builds for specific providers
func (*Function) RelativeHandlerPath ¶
func (*Function) Unit ¶
func (f *Function) Unit() *ComputeUnit
type Project ¶
type Project struct { Dir string `yaml:"-"` Name string `yaml:"name"` Functions map[string]Function `yaml:"functions,omitempty"` Collections map[string]Collection `yaml:"collections,omitempty"` Containers map[string]Container `yaml:"containers,omitempty"` Buckets map[string]Bucket `yaml:"buckets,omitempty"` Topics map[string]Topic `yaml:"topics,omitempty"` Queues map[string]Queue `yaml:"queues,omitempty"` Schedules map[string]Schedule `yaml:"schedules,omitempty"` ApiDocs map[string]*openapi3.T `yaml:"-"` SecurityDefinitions map[string]map[string]*v1.ApiSecurityDefinition `yaml:"-"` Apis map[string]string `yaml:"apis,omitempty"` // TODO: Not currently supported by nitric.yaml configuration (but is technically definable using the proto model) // We may want to decouple the definition from contracts at a later stage // but re-using the contract here provides us a serializable entity with no // repetition/redefinition // NOTE: if we want to use the proto definition here we would need support for yaml parsing to use customisable tags Policies []*v1.PolicyResource `yaml:"-"` Secrets map[string]Secret `yaml:"secrets,omitempty"` }
func FromConfig ¶
type Schedule ¶
type Schedule struct { Expression string `yaml:"expression"` // The Topic to be targeted for schedule Target ScheduleTarget `yaml:"target"` Event ScheduleEvent `yaml:"event"` }
type ScheduleEvent ¶
type ScheduleEvent struct { PayloadType string `yaml:"payloadType"` Payload map[string]interface{} `yaml:"payload,omitempty"` }
A subset of a NitricEvent excluding it's requestId This will be generated based on the scedule
type ScheduleTarget ¶
Click to show internal directories.
Click to hide internal directories.