Documentation ¶
Index ¶
- Constants
- func ParseAzureDeploymentName(azureDeploymentName string) (*int, error)
- type AttributeKey
- type BaseWithGuidPrimaryKey
- type Deployment
- type EventHook
- type EventHookAuditEntry
- type InvokedOperation
- func (o *InvokedOperation) AttemptsExceeded() bool
- func (o *InvokedOperation) Attribute(key AttributeKey, v any)
- func (o *InvokedOperation) AttributeValue(key AttributeKey) (any, bool)
- func (o *InvokedOperation) Complete()
- func (o *InvokedOperation) CompletedAt() (*time.Time, error)
- func (o *InvokedOperation) CorrelationId() (*uuid.UUID, error)
- func (o *InvokedOperation) Error(err error)
- func (o *InvokedOperation) Failed() error
- func (o *InvokedOperation) FirstResult() *InvokedOperationResult
- func (o *InvokedOperation) HasAttribute(key AttributeKey) bool
- func (o *InvokedOperation) IsCompleted() bool
- func (o *InvokedOperation) IsContinuation() bool
- func (o *InvokedOperation) IsExecutable() ([]string, bool)
- func (o *InvokedOperation) IsFirstAttempt() bool
- func (o *InvokedOperation) IsRetry() bool
- func (o *InvokedOperation) IsRetrying() bool
- func (o *InvokedOperation) IsRunning() bool
- func (o *InvokedOperation) IsScheduled() bool
- func (o *InvokedOperation) LatestResult() *InvokedOperationResult
- func (o *InvokedOperation) ParameterValue(key ParameterKey) (any, bool)
- func (o *InvokedOperation) Running()
- func (o *InvokedOperation) Schedule() error
- func (o *InvokedOperation) Success() error
- func (o *InvokedOperation) Value(v any)
- type InvokedOperationAttribute
- type InvokedOperationResult
- type ParameterKey
- type Stage
- type StageNotification
- type StageNotificationEntry
Constants ¶
const DefaultNumberOfRetries = 3
Variables ¶
This section is empty.
Functions ¶
func ParseAzureDeploymentName ¶
Parses the azure deployment name and returns OUR deployment id
Types ¶
type AttributeKey ¶
type AttributeKey string
const ( AttributeKeyCorrelationId AttributeKey = "correlationId" AttributeKeyAzureDeploymentName AttributeKey = "azureDeploymentName" AttributeKeyResumeToken AttributeKey = "resumeToken" AttributeKeyArmTemplate AttributeKey = "armTemplate" )
type BaseWithGuidPrimaryKey ¶
type BaseWithGuidPrimaryKey struct { ID uuid.UUID `gorm:"type:uuid;primaryKey;"` CreatedAt time.Time UpdatedAt time.Time DeletedAt *time.Time `sql:"index"` }
Base contains common columns for all tables.
func (*BaseWithGuidPrimaryKey) BeforeCreate ¶
func (base *BaseWithGuidPrimaryKey) BeforeCreate(tx *gorm.DB) error
BeforeCreate will set a UUID rather than numeric ID.
type Deployment ¶
type Deployment struct { gorm.Model Name string `json:"name"` Template map[string]any `json:"template" gorm:"json"` Stages []Stage `json:"stages" gorm:"foreignKey:DeploymentID"` // azure properties SubscriptionId string `json:"subscriptionId"` ResourceGroup string `json:"resourceGroup"` Location string `json:"location"` }
func (*Deployment) GetAzureDeploymentName ¶
func (d *Deployment) GetAzureDeploymentName() string
Gets the azure deployment name suitable for azure deployment format - modm.<deploymentId>.<deploymentName>
func (*Deployment) ParseAzureDeploymentName ¶
func (d *Deployment) ParseAzureDeploymentName(azureDeploymentName string) (*int, error)
type EventHook ¶
type EventHook struct { BaseWithGuidPrimaryKey Callback string `json:"callback"` Name string `json:"name" gorm:"unique"` ApiKey string `json:"authKey"` }
event hook subscriptions are stored with this
func FromCreateEventHook ¶
func FromCreateEventHook(from *sdk.CreateEventHookRequest) *EventHook
Maps a command to create an event subscription to the hook data model
type EventHookAuditEntry ¶ added in v1.3.0
type EventHookAuditEntry struct { gorm.Model Hash string `json:"hash"` Message any `json:"message" gorm:"json"` }
record for all event hook messages sent
type InvokedOperation ¶
type InvokedOperation struct { BaseWithGuidPrimaryKey ParentID *uuid.UUID `json:"parentId" gorm:"type:uuid"` Name string `json:"name"` DeploymentId uint `json:"deploymentId"` Attributes []InvokedOperationAttribute `json:"attributes"` Retries uint `json:"retries"` Attempts uint `json:"attempts"` Parameters map[string]any `json:"parameters" gorm:"json"` Results map[uint]*InvokedOperationResult `json:"results" gorm:"json"` Status string `json:"status"` // the current or final status of the operation Completed bool `json:"completed"` }
InvokedOperation is a record of an operation that was invoked by the operator
remarks: attributes - specify information about or that control the operation's use and behavior
func (*InvokedOperation) AttemptsExceeded ¶
func (o *InvokedOperation) AttemptsExceeded() bool
func (*InvokedOperation) Attribute ¶
func (o *InvokedOperation) Attribute(key AttributeKey, v any)
func (*InvokedOperation) AttributeValue ¶
func (o *InvokedOperation) AttributeValue(key AttributeKey) (any, bool)
func (*InvokedOperation) Complete ¶ added in v1.3.0
func (o *InvokedOperation) Complete()
func (*InvokedOperation) CompletedAt ¶ added in v1.3.0
func (o *InvokedOperation) CompletedAt() (*time.Time, error)
func (*InvokedOperation) CorrelationId ¶ added in v1.3.1
func (o *InvokedOperation) CorrelationId() (*uuid.UUID, error)
func (*InvokedOperation) Error ¶
func (o *InvokedOperation) Error(err error)
func (*InvokedOperation) Failed ¶
func (o *InvokedOperation) Failed() error
sets the status to failed for the operation and the latest attempt's result
func (*InvokedOperation) FirstResult ¶ added in v1.3.2
func (o *InvokedOperation) FirstResult() *InvokedOperationResult
func (*InvokedOperation) HasAttribute ¶
func (o *InvokedOperation) HasAttribute(key AttributeKey) bool
does the InvokedOperation have an attribute with the specified key?
func (*InvokedOperation) IsCompleted ¶ added in v1.3.0
func (o *InvokedOperation) IsCompleted() bool
func (*InvokedOperation) IsContinuation ¶ added in v1.3.4
func (o *InvokedOperation) IsContinuation() bool
whether the operation execution is being picked up where it last left off if interrupted
func (*InvokedOperation) IsExecutable ¶
func (o *InvokedOperation) IsExecutable() ([]string, bool)
can the operation be executed? if not, then reasons are returned
func (*InvokedOperation) IsFirstAttempt ¶ added in v1.3.1
func (o *InvokedOperation) IsFirstAttempt() bool
func (*InvokedOperation) IsRetry ¶
func (o *InvokedOperation) IsRetry() bool
func (*InvokedOperation) IsRetrying ¶ added in v1.3.0
func (o *InvokedOperation) IsRetrying() bool
func (*InvokedOperation) IsRunning ¶
func (o *InvokedOperation) IsRunning() bool
func (*InvokedOperation) IsScheduled ¶ added in v1.3.0
func (o *InvokedOperation) IsScheduled() bool
func (*InvokedOperation) LatestResult ¶
func (o *InvokedOperation) LatestResult() *InvokedOperationResult
func (*InvokedOperation) ParameterValue ¶ added in v1.3.4
func (o *InvokedOperation) ParameterValue(key ParameterKey) (any, bool)
func (*InvokedOperation) Running ¶
func (o *InvokedOperation) Running()
increment the number of attempts and set the status to running if it's in a state where it can be run. return: returns true if status changed to running
func (*InvokedOperation) Schedule ¶
func (o *InvokedOperation) Schedule() error
func (*InvokedOperation) Success ¶
func (o *InvokedOperation) Success() error
sets the status to success for the operation and the latest attempt's result
func (*InvokedOperation) Value ¶
func (o *InvokedOperation) Value(v any)
type InvokedOperationAttribute ¶
type InvokedOperationAttribute struct { gorm.Model Key string `json:"key" gorm:"uniqueIndex:composite_index;index;not null"` Value any `json:"value" gorm:"json"` InvokedOperationID uuid.UUID `json:"invokedOperationId" gorm:"type:uuid;uniqueIndex:composite_index;index;not null"` }
func NewAttribute ¶
func NewAttribute(key AttributeKey, v any) InvokedOperationAttribute
func (InvokedOperationAttribute) Set ¶
func (a InvokedOperationAttribute) Set(key AttributeKey, v any) InvokedOperationAttribute
type InvokedOperationResult ¶
type ParameterKey ¶
type ParameterKey string
const ( ParameterKeyStageId ParameterKey = "stageId" ParameterKeyNestedTemplateName ParameterKey = "nestedTemplateName" )
type Stage ¶
type Stage struct { BaseWithGuidPrimaryKey DeploymentID uint `json:"deploymentId" gorm:"primaryKey"` Name string `json:"name"` AzureDeploymentName string `json:"azureDeploymentName"` // the default number of retries Retries uint `json:"retries"` }
type StageNotification ¶ added in v1.3.1
type StageNotification struct { gorm.Model OperationId uuid.UUID `json:"operationId" gorm:"type:uuid;not null"` CorrelationId uuid.UUID `json:"correlationId" gorm:"type:uuid;not null"` ResourceGroupName string `json:"resourceGroupName" gorm:"not null"` Entries []StageNotificationEntry `json:"entries" gorm:"json"` IsDone bool `json:"isDone" gorm:"not null"` }
func (*StageNotification) AllSent ¶ added in v1.3.1
func (n *StageNotification) AllSent() bool
whether all entries have been sent
func (*StageNotification) Done ¶ added in v1.3.1
func (n *StageNotification) Done()
type StageNotificationEntry ¶ added in v1.3.1
type StageNotificationEntry struct { StageId uuid.UUID `json:"stageId" gorm:"uuid;not null"` Message sdk.EventHookMessage `json:"message" gorm:"json;not null"` IsSent bool `json:"isSent" gorm:"not null"` SentAt *time.Time `json:"sentAt" gorm:"null"` }
func (*StageNotificationEntry) Sent ¶ added in v1.3.1
func (n *StageNotificationEntry) Sent()