Documentation ¶
Overview ¶
Package service - this package file will contain base service interfaces and structs for embedding into other service packages
Package service this file contains general error strings, types, or constants that are used within the service package ¶
Package service is a temporary package and will eventually be replace with cacao-types/service/user.go TODO: EJS - replace with cacao-types
Index ¶
- Constants
- Variables
- func NewInteractiveSessionID() common.ID
- func NewJS2ProjectID() common.ID
- func NewTemplateID() common.ID
- func NewUserActionID() common.ID
- func NewWorkspaceID() common.ID
- type AWMProvider
- type Actor
- type CacaoAlreadyExistError
- type CacaoCommunicationError
- type CacaoError
- func ConvertJSONToCacaoError(jsonBytes []byte) (CacaoError, error)
- func NewCacaoAlreadyExistError(contextualMsg string) CacaoError
- func NewCacaoAlreadyExistErrorWithOptions(contextualMsg string, options ...CacaoErrorOption) CacaoError
- func NewCacaoCommunicationError(contextualMsg string) CacaoError
- func NewCacaoCommunicationErrorWithOptions(contextualMsg string, options ...CacaoErrorOption) CacaoError
- func NewCacaoGeneralError(contextualMsg string) CacaoError
- func NewCacaoGeneralErrorWithOptions(contextualMsg string, options ...CacaoErrorOption) CacaoError
- func NewCacaoInvalidParameterError(contextualMsg string) CacaoError
- func NewCacaoInvalidParameterErrorWithOptions(contextualMsg string, options ...CacaoErrorOption) CacaoError
- func NewCacaoMarshalError(contextualMsg string) CacaoError
- func NewCacaoMarshalErrorWithOptions(contextualMsg string, options ...CacaoErrorOption) CacaoError
- func NewCacaoNotFoundError(contextualMsg string) CacaoError
- func NewCacaoNotFoundErrorWithOptions(contextualMsg string, options ...CacaoErrorOption) CacaoError
- func NewCacaoNotImplementedError(contextualMsg string) CacaoError
- func NewCacaoNotImplementedErrorWithOptions(contextualMsg string, options ...CacaoErrorOption) CacaoError
- func NewCacaoOperationCanceledError(contextualMsg string) CacaoError
- func NewCacaoOperationCanceledErrorWithOptions(contextualMsg string, options ...CacaoErrorOption) CacaoError
- func NewCacaoTimeoutError(contextualMsg string) CacaoError
- func NewCacaoTimeoutErrorWithOptions(contextualMsg string, options ...CacaoErrorOption) CacaoError
- func NewCacaoUnauthorizedError(contextualMsg string) CacaoError
- func NewCacaoUnauthorizedErrorWithOptions(contextualMsg string, options ...CacaoErrorOption) CacaoError
- func ToCacaoError(err error) CacaoError
- type CacaoErrorBase
- func (err *CacaoErrorBase) ContextualError() string
- func (err *CacaoErrorBase) Error() string
- func (err *CacaoErrorBase) GetBase() CacaoErrorBase
- func (err *CacaoErrorBase) IsTemporary() bool
- func (err *CacaoErrorBase) MarshalJSON() ([]byte, error)
- func (err *CacaoErrorBase) ReplaceOptions(options CacaoErrorOptions)
- func (err *CacaoErrorBase) SetContextualError(message string)
- func (err *CacaoErrorBase) SetOptions(options ...CacaoErrorOption)
- func (err *CacaoErrorBase) SetStandardError(message CacaoStandardErrorMessage)
- func (err *CacaoErrorBase) StandardError() CacaoStandardErrorMessage
- type CacaoErrorOption
- type CacaoErrorOptions
- type CacaoGeneralError
- type CacaoInvalidParameterError
- type CacaoMarshalError
- type CacaoNotFoundError
- type CacaoNotImplementedError
- type CacaoOperationCanceledError
- type CacaoStandardErrorMessage
- type CacaoTimeoutError
- type CacaoUnauthorizedError
- type CredentialClient
- type CredentialCreateRequest
- type CredentialCreateResponse
- type CredentialDeleteRequest
- type CredentialDeleteResponse
- type CredentialGetReply
- type CredentialGetRequest
- type CredentialListFilter
- type CredentialListReply
- type CredentialListRequest
- type CredentialModel
- func (c *CredentialModel) AddTag(s string)
- func (c *CredentialModel) GetPrimaryID() string
- func (c *CredentialModel) GetRedacted() CredentialModel
- func (c *CredentialModel) GetTags() []string
- func (c *CredentialModel) RemoveAllTags()
- func (c *CredentialModel) RemoveTag(s string)
- func (c *CredentialModel) Verify() (bool, error)
- type CredentialType
- type CredentialUpdate
- type CredentialUpdateRequest
- type CredentialUpdateResponse
- type DepCheckDeletionRequest
- type DepCheckDeletionResponse
- type DepCheckDeletionResult
- type DependencyMediatorClient
- type Deployment
- type DeploymentClient
- type DeploymentCreateParam
- type DeploymentCreateRunRequest
- type DeploymentCreateRunResult
- type DeploymentCreationRequest
- type DeploymentCreationResult
- type DeploymentDeletionRequest
- type DeploymentDeletionResult
- type DeploymentFilter
- type DeploymentGetLogsQuery
- type DeploymentGetLogsReply
- type DeploymentGetQuery
- type DeploymentGetRawStateQuery
- type DeploymentGetRawStateReply
- type DeploymentGetReply
- type DeploymentGetRunQuery
- type DeploymentGetRunReply
- type DeploymentList
- type DeploymentListOption
- type DeploymentListQuery
- type DeploymentListReply
- type DeploymentListRunQuery
- type DeploymentListRunReply
- type DeploymentLogsLocationQuery
- type DeploymentLogsLocationReply
- type DeploymentParameter
- type DeploymentParameterUpdateRequest
- type DeploymentParameterUpdateResult
- type DeploymentParameterValues
- type DeploymentPendingStatus
- type DeploymentResource
- type DeploymentResourceAction
- type DeploymentResourceType
- type DeploymentRun
- type DeploymentRunCreateParam
- type DeploymentRunList
- type DeploymentRunListOption
- type DeploymentStartMonitoring
- type DeploymentStartMonitoringResult
- type DeploymentStateRefresh
- type DeploymentStateRefreshResult
- type DeploymentStateRefreshStarted
- type DeploymentStateView
- type DeploymentStatus
- func (ds DeploymentStatus) AllowDeletion() bool
- func (ds DeploymentStatus) AllowRunCreation() bool
- func (ds DeploymentStatus) AvailableTransition() []DeploymentPendingStatus
- func (ds DeploymentStatus) String() string
- func (ds DeploymentStatus) Valid() bool
- func (ds DeploymentStatus) ValidPendingStatus(pendingStatus DeploymentPendingStatus) bool
- type DeploymentStopMonitoring
- type DeploymentStopMonitoringResult
- type DeploymentUpdateRequest
- type DeploymentUpdateResult
- type FilterField
- type GitTemplateSource
- type GitTemplateSourceAccessParameters
- type InteractiveSessionClient
- type InteractiveSessionListModel
- type InteractiveSessionModel
- type InteractiveSessionProtocol
- type InteractiveSessionState
- type JS2Allocation
- type JS2AllocationClient
- type JS2PI
- type JS2ProjectListModel
- type JS2ProjectModel
- type JS2UserModel
- type LogsLocation
- type OpenStackCredential
- type OpenStackInstanceAttributes
- type OpenStackVolumeAttributes
- type ProviderClient
- type ProviderListModel
- type ProviderModel
- type ProviderRequest
- type ProviderResponse
- type ProviderType
- type ReplyListStream
- type RequestPagination
- type Session
- type SessionContext
- type SortByField
- type SortDirection
- type StanDependencyMediatorClient
- func (dm StanDependencyMediatorClient) DeleteCredential(ctx context.Context, session Session, credID string) (DepCheckDeletionResult, error)
- func (dm StanDependencyMediatorClient) DeleteProvider(ctx context.Context, session Session, provider common.ID) (DepCheckDeletionResult, error)
- func (dm StanDependencyMediatorClient) DeleteTemplate(ctx context.Context, session Session, template common.ID) (DepCheckDeletionResult, error)
- func (dm StanDependencyMediatorClient) DeleteWorkspace(ctx context.Context, session Session, workspace common.ID) (DepCheckDeletionResult, error)
- type Template
- type TemplateCacaoTask
- type TemplateCacaoTaskExecuteOn
- func (t TemplateCacaoTaskExecuteOn) MarshalBSONValue() (bsontype.Type, []byte, error)
- func (t TemplateCacaoTaskExecuteOn) MarshalJSON() ([]byte, error)
- func (t TemplateCacaoTaskExecuteOn) String() string
- func (t *TemplateCacaoTaskExecuteOn) UnmarshalBSONValue(bt bsontype.Type, b []byte) error
- func (t *TemplateCacaoTaskExecuteOn) UnmarshalJSON(b []byte) error
- type TemplateCacaoTaskExecuteOnType
- type TemplateCacaoTaskKeyVal
- type TemplateCacaoTaskRunAction
- type TemplateCacaoTaskType
- type TemplateClient
- type TemplateCustomFieldType
- type TemplateCustomFieldTypeListItemModel
- type TemplateCustomFieldTypeListModel
- type TemplateCustomFieldTypeModel
- func (t *TemplateCustomFieldTypeModel) GetDescription() string
- func (t *TemplateCustomFieldTypeModel) GetName() string
- func (t *TemplateCustomFieldTypeModel) GetPrimaryID() string
- func (t *TemplateCustomFieldTypeModel) GetQueryData() string
- func (t *TemplateCustomFieldTypeModel) GetQueryMethod() TemplateCustomFieldTypeQueryMethod
- func (t *TemplateCustomFieldTypeModel) GetQueryParams() map[string]string
- func (t *TemplateCustomFieldTypeModel) GetQueryResultJSONPathFilter() string
- func (t *TemplateCustomFieldTypeModel) GetQueryTarget() string
- func (t *TemplateCustomFieldTypeModel) GetUpdateFieldNames() []string
- func (t *TemplateCustomFieldTypeModel) SetDescription(description string)
- func (t *TemplateCustomFieldTypeModel) SetName(name string)
- func (t *TemplateCustomFieldTypeModel) SetPrimaryID(name string)
- func (t *TemplateCustomFieldTypeModel) SetQueryData(data string)
- func (t *TemplateCustomFieldTypeModel) SetQueryMethod(queryMethod TemplateCustomFieldTypeQueryMethod)
- func (t *TemplateCustomFieldTypeModel) SetQueryParams(queryParams map[string]string)
- func (t *TemplateCustomFieldTypeModel) SetQueryResultJSONPathFilter(jsonpath string)
- func (t *TemplateCustomFieldTypeModel) SetQueryTarget(target string)
- func (t *TemplateCustomFieldTypeModel) SetUpdateFieldNames(fieldNames []string)
- type TemplateCustomFieldTypeQueryMethod
- type TemplateCustomFieldTypeQueryResult
- type TemplateCustomFieldTypeQueryResultModel
- type TemplateEngine
- type TemplateFilter
- type TemplateFilterKey
- type TemplateFormat
- type TemplateGithubWebhook
- type TemplateGitlabWebhook
- type TemplateListItemModel
- type TemplateListModel
- type TemplateMetadata
- func (meta *TemplateMetadata) GetFilter(key TemplateFilterKey) *TemplateFilter
- func (meta *TemplateMetadata) GetFilterValueStrArr(key TemplateFilterKey) []string
- func (meta *TemplateMetadata) GetImagesAllowed() []string
- func (meta *TemplateMetadata) GetImagesBlocked() []string
- func (meta *TemplateMetadata) GetParameter(name string) *TemplateParameter
- type TemplateModel
- func (t TemplateModel) GetCreatedAt() time.Time
- func (t TemplateModel) GetCredentialID() string
- func (t *TemplateModel) GetDescription() string
- func (t *TemplateModel) GetID() common.ID
- func (t TemplateModel) GetIncludeCacaoReservedPurposes() bool
- func (t TemplateModel) GetLatestVersionID() common.ID
- func (t *TemplateModel) GetMetadata() TemplateMetadata
- func (t *TemplateModel) GetName() string
- func (t *TemplateModel) GetOwner() string
- func (t *TemplateModel) GetPrimaryID() common.ID
- func (t *TemplateModel) GetSource() TemplateSource
- func (t *TemplateModel) GetUIMetadata() TemplateUIMetadata
- func (t *TemplateModel) GetUpdateFieldNames() []string
- func (t TemplateModel) GetUpdatedAt() time.Time
- func (t *TemplateModel) IsDeleted() bool
- func (t *TemplateModel) IsPublic() bool
- func (t *TemplateModel) SetCredentialID(credentialID string)
- func (t *TemplateModel) SetDescription(description string)
- func (t *TemplateModel) SetID(id common.ID)
- func (t *TemplateModel) SetIncludeCacaoReservedPurposes(include bool)
- func (t *TemplateModel) SetName(name string)
- func (t *TemplateModel) SetPrimaryID(id common.ID)
- func (t *TemplateModel) SetPublic(isPublic bool)
- func (t *TemplateModel) SetSource(source TemplateSource)
- func (t *TemplateModel) SetUpdateFieldNames(fieldNames []string)
- type TemplateParameter
- func (param *TemplateParameter) CheckValue(value interface{}) (typeName string, resultValue interface{}, err error)
- func (param *TemplateParameter) CheckValueFromString(value string) (string, interface{}, error)
- func (param *TemplateParameter) CorrectDataType() error
- func (param *TemplateParameter) UnmarshalJSON(b []byte) error
- type TemplateProviderType
- type TemplatePurpose
- type TemplateSource
- type TemplateSourceCredential
- type TemplateSourceType
- type TemplateSourceTypeListModel
- type TemplateSourceVisibility
- type TemplateType
- type TemplateTypeListItemModel
- type TemplateTypeListModel
- type TemplateTypeModel
- func (t *TemplateTypeModel) GetEngine() TemplateEngine
- func (t *TemplateTypeModel) GetFormats() []TemplateFormat
- func (t *TemplateTypeModel) GetName() TemplateTypeName
- func (t *TemplateTypeModel) GetPrimaryID() TemplateTypeName
- func (t *TemplateTypeModel) GetProviderTypes() []TemplateProviderType
- func (t *TemplateTypeModel) GetUpdateFieldNames() []string
- func (t *TemplateTypeModel) SetEngine(engine TemplateEngine)
- func (t *TemplateTypeModel) SetFormats(formats []TemplateFormat)
- func (t *TemplateTypeModel) SetName(name TemplateTypeName)
- func (t *TemplateTypeModel) SetPrimaryID(id TemplateTypeName)
- func (t *TemplateTypeModel) SetProviderTypes(providerTypes []TemplateProviderType)
- func (t *TemplateTypeModel) SetUpdateFieldNames(fieldNames []string)
- type TemplateTypeName
- type TemplateUIField
- type TemplateUIGroup
- type TemplateUIGroupItem
- func (item *TemplateUIGroupItem) GetField() *TemplateUIField
- func (item *TemplateUIGroupItem) GetGroup() *TemplateUIGroup
- func (item *TemplateUIGroupItem) GetRow() *TemplateUIRow
- func (item *TemplateUIGroupItem) IsField() bool
- func (item *TemplateUIGroupItem) IsGroup() bool
- func (item *TemplateUIGroupItem) IsRow() bool
- func (item TemplateUIGroupItem) MarshalBSON() ([]byte, error)
- func (item *TemplateUIGroupItem) MarshalJSON() ([]byte, error)
- func (item *TemplateUIGroupItem) UnmarshalBSON(b []byte) error
- func (item *TemplateUIGroupItem) UnmarshalJSON(b []byte) error
- type TemplateUIGroupType
- type TemplateUIKeyVal
- type TemplateUIMetadata
- type TemplateUIRow
- type TemplateUIRowType
- type TemplateUIStep
- type TemplateVersion
- type TemplateVersionDisableRequest
- type TemplateVersionDisableResponse
- type TemplateVersionListModel
- type TemplateVersionModel
- type TemplateWebhook
- type TemplateWebhookClient
- type TemplateWebhookCreationRequest
- type TemplateWebhookCreationResponse
- type TemplateWebhookDeletionRequest
- type TemplateWebhookDeletionResponse
- type TemplateWebhookListReply
- type TemplateWebhookListRequest
- type TemplateWebhookPlatformType
- type TerraformWorkflowData
- type TokenAuthCheckRequest
- type TokenClient
- type TokenCreateBulkModel
- type TokenCreateModel
- type TokenListModel
- type TokenModel
- type TokenType
- type TokenTypeListModel
- type UserActionClient
- type UserActionItem
- func (item *UserActionItem) GetScriptAction() *UserScriptActionItem
- func (item *UserActionItem) IsScriptAction() bool
- func (item UserActionItem) MarshalBSON() ([]byte, error)
- func (item UserActionItem) MarshalJSON() ([]byte, error)
- func (item *UserActionItem) SetScriptAction(scriptAction *UserScriptActionItem)
- func (item *UserActionItem) UnmarshalBSON(b []byte) error
- func (item *UserActionItem) UnmarshalJSON(b []byte) error
- type UserActionListModel
- type UserActionMethod
- type UserActionModel
- type UserActionScriptDataType
- type UserActionScriptSourceType
- type UserActionType
- type UserClient
- type UserList
- type UserListFilter
- type UserListModel
- func (ul *UserListModel) GetFilter() UserListFilter
- func (ul *UserListModel) GetNextStart() int
- func (ul *UserListModel) GetSize() int
- func (ul *UserListModel) GetStart() int
- func (ul *UserListModel) GetTotalFilterSize() int
- func (ul *UserListModel) GetUsers() []UserModel
- func (ul *UserListModel) HasNext() bool
- type UserModel
- type UserScriptActionItem
- type UserSettingsReply
- type UserSettingsRequest
- type UserUpdate
- type UserUpdateRequest
- type VisibilityType
- type WorkflowCreate
- type WorkflowCreateFailed
- type WorkflowCreated
- type WorkflowResubmit
- type WorkflowResubmitFailed
- type WorkflowResubmitted
- type WorkflowTerminate
- type WorkflowTerminateFailed
- type WorkflowTerminated
- type WorkspaceClient
- type WorkspaceListModel
- type WorkspaceModel
Constants ¶
const ( NatsSubjectCredentials common.QueryOp = common.NatsQueryOpPrefix + "credentials" NatsSubjectCredentialsGet = NatsSubjectCredentials + ".get" NatsSubjectCredentialsList = NatsSubjectCredentials + ".list" EventCredentialAddRequested common.EventType = "org.cyverse.events.CredentialAddRequested" EventCredentialGenerationRequested common.EventType = "org.cyverse.events.Credential.GenerationRequested" EventCredentialUpdateRequested common.EventType = "org.cyverse.events.CredentialUpdateRequested" EventCredentialDeleteRequested common.EventType = "org.cyverse.events.CredentialDeleteRequested" EventCredentialAdded common.EventType = "org.cyverse.events.CredentialAdded" EventCredentialUpdated common.EventType = "org.cyverse.events.CredentialUpdated" EventCredentialDeleted common.EventType = "org.cyverse.events.CredentialDeleted" EventCredentialAddError common.EventType = "org.cyverse.events.CredentialAddError" EventCredentialUpdateError common.EventType = "org.cyverse.events.CredentialUpdateError" EventCredentialDeleteError common.EventType = "org.cyverse.events.CredentialDeleteError" EventCredentialGetError common.EventType = "org.cyverse.events.CredentialGetError" EventCredentialListError common.EventType = "org.cyverse.events.CredentialListError" )
QueryOp & EventType for credential operations
const ( // EventDepMedDeleteProvider is event type for deleting a provider with dependent checking EventDepMedDeleteProvider = depMedPrefix + "deleteProvider" EventDepMedProviderDeletionErrored = depMedPrefix + "providerDeletionErrored" EventDepMedProviderHasDependent = depMedPrefix + "providerHasDependent" EventDepMedProviderDeleted = depMedPrefix + "providerDeleted" )
EventType constants for deleting provider via dependency mediator
const ( // EventDepMedDeleteTemplate is event type for deleting a template with dependent checking EventDepMedDeleteTemplate = depMedPrefix + "deleteTemplate" EventDepMedTemplateDeletionErrored = depMedPrefix + "templateDeletionErrored" EventDepMedTemplateHasDependent = depMedPrefix + "templateHasDependent" EventDepMedTemplateDeleted = depMedPrefix + "templateDeleted" )
EventType constants for deleting template via dependency mediator
const ( // EventDepMedDeleteWorkspace is event type for deleting a workspace with dependent checking EventDepMedDeleteWorkspace = depMedPrefix + "deleteWorkspace" EventDepMedWorkspaceDeletionErrored = depMedPrefix + "workspaceDeletionErrored" EventDepMedWorkspaceHasDependent = depMedPrefix + "workspaceHasDependent" EventDepMedWorkspaceDeleted = depMedPrefix + "workspaceDeleted" )
EventType constants for deleting workspace via dependency mediator
const ( // EventDepMedDeleteCredential is event type for deleting a credential with dependent checking EventDepMedDeleteCredential = depMedPrefix + "deleteCredential" EventDepMedCredentialDeletionErrored = depMedPrefix + "credentialDeletionErrored" EventDepMedCredentialHasDependent = depMedPrefix + "credentialHasDependent" EventDepMedCredentialDeleted = depMedPrefix + "credentialDeleted" )
EventType constants for deleting credential via dependency mediator
const ( // DeploymentGetQueryType ... DeploymentGetQueryType common.QueryOp = "cyverse.deployment.get" // DeploymentListQueryType ... DeploymentListQueryType common.QueryOp = "cyverse.deployment.list" // DeploymentGetRunQueryType ... DeploymentGetRunQueryType common.QueryOp = "cyverse.deployment.getRun" // DeploymentListRunQueryType ... DeploymentListRunQueryType common.QueryOp = "cyverse.deployment.listRun" // DeploymentGetRawStateQueryType ... DeploymentGetRawStateQueryType common.QueryOp = "cyverse.deployment.getRawState" // DeploymentGetLogsQueryType ... // Deprecated: logs itself should be fetched over HTTP instead of over NATS, use NATS for fetching HTTP URL to the logs DeploymentGetLogsQueryType common.QueryOp = "cyverse.deployment.getLogs" // DeploymentGetLogsLocationQueryType is query type for fetching location of logs for deployment or deployment run DeploymentGetLogsLocationQueryType common.QueryOp = "cyverse.deployment.getLogsLocation" )
const ( GeneralUnmarshalFromUserMSError string = "could not unmarshal User object on User microservice side" GeneralEventOpTimeoutError string = "event operation timeout" GeneralEventOpCanceledError string = "event operation was canceled" GeneralActorNotAuthorizedError string = "actor not authorized" GeneralActorNotFoundError string = "actor was not found; perhaps you can use the bypass option" GeneralMethodNotYetImplementedError string = "method not yet implemented" )
these general errors strings, perhaps applicable to multiple service to create a new error object from this string, call error.New(string)
const ( UserUsernameNotSetError string = "username was not set before using User" // if username not initialized before Load UserActorNotSetError string = "actor was not set" UserUsernameNotFoundError string = "username not found" UserUsernameReservedCannotAddError string = "username is reserved, cannot add user" UserUsernameExistsCannotAddError string = "username exists, cannot add user" UserUpdateError string = "user could not be updated" UserDeleteError string = "user could not be deleted" UserSettingsError string = "problem decoding settings from database" )
these are user object type of errors to create a new error, call error.New(string)
const ( ProviderActorNotSetError string = "actor was not set" ProviderIDNotSetError string = "provide id was not set" )
these are provider object type of errors to create a new error, call error.New(string)
const ( UserListFilterNotSetError string = "user list filter was not set before Search/SearchNext" UserListFilterInvalidStartIndexError string = "user list filter has invalid start index" UserListFilterInvalidMaxItemsError string = "user list filter has invalid max items" UserListLoadBoundaryError string = "next start index is invalid or no more elements to load beyond end of user list" UserListEmptyListError string = "user list results size 0" )
these are user list types of errors to create a new error, call error.New(string)
const ( // NatsSubjectInteractiveSession is the prefix of the queue name for Interactivesession queries NatsSubjectInteractiveSession common.QueryOp = common.NatsQueryOpPrefix + "interactivesession" // InteractiveSessionListQueryOp is the queue name for InteractiveSessionList query InteractiveSessionListQueryOp = NatsSubjectInteractiveSession + ".list" // InteractiveSessionGetQueryOp is the queue name for InteractiveSessionGet query InteractiveSessionGetQueryOp = NatsSubjectInteractiveSession + ".get" // InteractiveSessionGetByInstanceIDQueryOp is the queue name for InteractiveSessionGetByInstanceID query InteractiveSessionGetByInstanceIDQueryOp = NatsSubjectInteractiveSession + ".getByInstanceID" // InteractiveSessionGetByInstanceAddressQueryOp is the queue name for InteractiveSessionGetByInstanceAddress query InteractiveSessionGetByInstanceAddressQueryOp = NatsSubjectInteractiveSession + ".getByInstanceAddress" // InteractiveSessionCheckPrerequisitesQueryOp is the queue name for InteractiveSessionCheckPrerequisites query InteractiveSessionCheckPrerequisitesQueryOp = NatsSubjectInteractiveSession + ".checkPrerequisites" // InteractiveSessionCreateRequestedEvent is the cloudevent subject for InteractiveSessionCreate InteractiveSessionCreateRequestedEvent common.EventType = common.EventTypePrefix + "InteractiveSessionCreateRequested" // InteractiveSessionDeactivateRequestedEvent is the cloudevent subject for InteractiveSessionDeactivate InteractiveSessionDeactivateRequestedEvent common.EventType = common.EventTypePrefix + "InteractiveSessionDeactivateRequested" // InteractiveSessionCreatedEvent is the cloudevent subject for InteractiveSessionCreated InteractiveSessionCreatedEvent common.EventType = common.EventTypePrefix + "InteractiveSessionCreated" // InteractiveSessionDeactivatedEvent is the cloudevent subject for InteractiveSessionDeactivated InteractiveSessionDeactivatedEvent common.EventType = common.EventTypePrefix + "InteractiveSessionDeactivated" // InteractiveSessionCreateFailedEvent is the cloudevent subject for InteractiveSessionCreateFailed InteractiveSessionCreateFailedEvent common.EventType = common.EventTypePrefix + "InteractiveSessionCreateFailed" // InteractiveSessionDeactivateFailedEvent is the cloudevent subject for InteractiveSessionDeactivateFailed InteractiveSessionDeactivateFailedEvent common.EventType = common.EventTypePrefix + "InteractiveSessionDeactivateFailed" )
Nats subjects
const ( // NatsSubjectJS2Allocation is the prefix of the queue name for JS2Allocation queries NatsSubjectJS2Allocation common.QueryOp = common.NatsQueryOpPrefix + "js2allocation" // JS2UserGetQueryOp is the queue name for JS2UserGet query JS2UserGetQueryOp = NatsSubjectJS2Allocation + ".getUser" // JS2ProjectListQueryOp is the queue name for JS2ProjectList query JS2ProjectListQueryOp = NatsSubjectJS2Allocation + ".list" )
Nats subjects
const ( // NatsSubjectProvider is the prefix of the queue name for Provider queries NatsSubjectProvider common.QueryOp = common.NatsQueryOpPrefix + "provider" // ProviderGetQueryOp is the queue name for ProviderGet query ProviderGetQueryOp = NatsSubjectProvider + ".get" // ProviderListQueryOp is the queue name for ProviderList query ProviderListQueryOp = NatsSubjectProvider + ".list" // ProviderCreateRequestedEvent is the cloudevent subject for ProviderCreate ProviderCreateRequestedEvent common.EventType = common.EventTypePrefix + "ProviderCreateRequested" // ProviderDeleteAdminRequestedEvent is the cloudevent subject for ProviderDeleteAdmin ProviderDeleteRequestedEvent common.EventType = common.EventTypePrefix + "ProviderDeleteRequested" // ProviderUpdateRequestedEvent is the cloudevent subject for ProviderUpdate ProviderUpdateRequestedEvent common.EventType = common.EventTypePrefix + "ProviderUpdateRequested" // ProviderCreatedEvent is the cloudevent subject for ProviderCreated ProviderCreatedEvent common.EventType = common.EventTypePrefix + "ProviderCreated" // ProviderDeletedEvent is the cloudevent subject for ProviderDeleted ProviderDeletedEvent common.EventType = common.EventTypePrefix + "ProviderDeleted" // ProviderUpdatedEvent is the cloudevent subject for ProviderUpdated ProviderUpdatedEvent common.EventType = common.EventTypePrefix + "ProviderUpdated" // ProviderCreateFailedEvent is the cloudevent subject for ProviderCreateFailed ProviderCreateFailedEvent common.EventType = common.EventTypePrefix + "ProviderCreateFailed" // ProviderDeleteFailedEvent is the cloudevent subject for ProviderDeleteFailed ProviderDeleteFailedEvent common.EventType = common.EventTypePrefix + "ProviderDeleteFailed" // ProviderUpdateFailedEvent is the cloudevent subject for ProviderUpdateFailed ProviderUpdateFailedEvent common.EventType = common.EventTypePrefix + "ProviderUpdateFailed" )
Nats subjects
const ( // NatsSubjectTemplate is the prefix of the queue name for Template queries NatsSubjectTemplate common.QueryOp = common.NatsQueryOpPrefix + "template" ///////////////////////////////////////////////////////////////////////// // TemplateSourceType ///////////////////////////////////////////////////////////////////////// // TemplateSourceTypeListQueryOp is the queue name for TemplateSourceTypeList query TemplateSourceTypeListQueryOp = NatsSubjectTemplate + ".listSourceTypes" ///////////////////////////////////////////////////////////////////////// // TemplateType ///////////////////////////////////////////////////////////////////////// // TemplateTypeListQueryOp is the queue name for TemplateTypeList query TemplateTypeListQueryOp = NatsSubjectTemplate + ".listTypes" // TemplateTypeGetQueryOp is the queue name for TemplateTypeGet query TemplateTypeGetQueryOp = NatsSubjectTemplate + ".getType" // TemplateTypeCreateRequestedEvent is the cloudevent subject for TemplateTypeCreate TemplateTypeCreateRequestedEvent common.EventType = common.EventTypePrefix + "TemplateTypeCreateRequested" // TemplateTypeDeleteRequestedEvent is the cloudevent subject for TemplateTypeDelete TemplateTypeDeleteRequestedEvent common.EventType = common.EventTypePrefix + "TemplateTypeDeleteRequested" // TemplateTypeUpdateRequestedEvent is the cloudevent subject for TemplateTypeUpdate TemplateTypeUpdateRequestedEvent common.EventType = common.EventTypePrefix + "TemplateTypeUpdateRequested" // TemplateTypeCreatedEvent is the cloudevent subject for TemplateTypeCreated TemplateTypeCreatedEvent common.EventType = common.EventTypePrefix + "TemplateTypeCreated" // TemplateTypeDeletedEvent is the cloudevent subject for TemplateTypeDeleted TemplateTypeDeletedEvent common.EventType = common.EventTypePrefix + "TemplateTypeDeleted" // TemplateTypeUpdatedEvent is the loudevent subject for TemplateTypeUpdated TemplateTypeUpdatedEvent common.EventType = common.EventTypePrefix + "TemplateTypeUpdated" // TemplateTypeCreateFailedEvent is the cloudevent subject for TemplateTypeCreateFailed TemplateTypeCreateFailedEvent common.EventType = common.EventTypePrefix + "TemplateTypeCreateFailed" // TemplateTypeDeleteFailedEvent is the eloudevent subject for TemplateTypeDeleteFailed TemplateTypeDeleteFailedEvent common.EventType = common.EventTypePrefix + "TemplateTypeDeleteFailed" // TemplateTypeUpdateFailedEvent is the loudevent subject for TemplateTypeUpdateFailed TemplateTypeUpdateFailedEvent common.EventType = common.EventTypePrefix + "TemplateTypeUpdateFailed" ///////////////////////////////////////////////////////////////////////// // TemplateCustomFieldType ///////////////////////////////////////////////////////////////////////// // TemplateCustomFieldTypeListQueryOp is the queue name for TemplateCustomFieldTypeList query TemplateCustomFieldTypeListQueryOp = NatsSubjectTemplate + ".listCustomFieldTypes" // TemplateCustomFieldTypeGetQueryOp is the queue name for TemplateCustomFieldTypeGet query TemplateCustomFieldTypeGetQueryOp = NatsSubjectTemplate + ".getCustomFieldType" // TemplateCustomFieldTypeQueryQueryOp is the queue name for TemplateCustomFieldTypeQuery query TemplateCustomFieldTypeQueryQueryOp = NatsSubjectTemplate + ".queryCustomFieldType" // TemplateCustomFieldTypeCreateRequestedEvent is the cloudevent subject for TemplateCustomFieldTypeCreate TemplateCustomFieldTypeCreateRequestedEvent common.EventType = common.EventTypePrefix + "TemplateCustomFieldTypeCreateRequested" // TemplateCustomFieldTypeDeleteRequestedEvent is the cloudevent subject for TemplateCustomFieldTypeDelete TemplateCustomFieldTypeDeleteRequestedEvent common.EventType = common.EventTypePrefix + "TemplateCustomFieldTypeDeleteRequested" // TemplateCustomFieldTypeUpdateRequestedEvent is the cloudevent subject for TemplateCustomFieldTypeUpdate TemplateCustomFieldTypeUpdateRequestedEvent common.EventType = common.EventTypePrefix + "TemplateCustomFieldTypeUpdateRequested" // TemplateCustomFieldTypeCreatedEvent is the cloudevent subject for TemplateCustomFieldTypeCreated TemplateCustomFieldTypeCreatedEvent common.EventType = common.EventTypePrefix + "TemplateCustomFieldTypeCreated" // TemplateCustomFieldTypeDeletedEvent is the cloudevent subject for TemplateCustomFieldTypeDeleted TemplateCustomFieldTypeDeletedEvent common.EventType = common.EventTypePrefix + "TemplateCustomFieldTypeDeleted" // TemplateCustomFieldTypeUpdatedEvent is the cloudevent subject for TemplateCustomFieldTypeUpdated TemplateCustomFieldTypeUpdatedEvent common.EventType = common.EventTypePrefix + "TemplateCustomFieldTypeUpdated" // TemplateCustomFieldTypeCreateFailedEvent is the cloudevent subject for TemplateCustomFieldTypeCreateFailed TemplateCustomFieldTypeCreateFailedEvent common.EventType = common.EventTypePrefix + "TemplateCustomFieldTypeCreateFailed" // TemplateCustomFieldTypeDeleteFailedEvent is the cloudevent subject for TemplateCustomFieldTypeDeleteFailed TemplateCustomFieldTypeDeleteFailedEvent common.EventType = common.EventTypePrefix + "TemplateCustomFieldTypeDeleteFailed" // TemplateCustomFieldTypeUpdateFailedEvent is the cloudevent subject for TemplateCustomFieldTypeUpdateFailed TemplateCustomFieldTypeUpdateFailedEvent common.EventType = common.EventTypePrefix + "TemplateCustomFieldTypeUpdateFailed" ///////////////////////////////////////////////////////////////////////// // Template ///////////////////////////////////////////////////////////////////////// // TemplateListQueryOp is the queue name for TemplateList query TemplateListQueryOp = NatsSubjectTemplate + ".list" // TemplateGetQueryOp is the queue name for TemplateGet query TemplateGetQueryOp = NatsSubjectTemplate + ".get" // TemplateVersionListQueryOp is the queue name for TemplateVersionList query TemplateVersionListQueryOp = NatsSubjectTemplate + ".version.list" // TemplateVersionGetQueryOp is the queue name for TemplateVersionGet query TemplateVersionGetQueryOp = NatsSubjectTemplate + ".version.get" // TemplateImportRequestedEvent is the cloudevent subject for TemplateImport TemplateImportRequestedEvent common.EventType = common.EventTypePrefix + "TemplateImportRequested" // TemplateDeleteRequestedEvent is the cloudevent subject for TemplateDelete TemplateDeleteRequestedEvent common.EventType = common.EventTypePrefix + "TemplateDeleteRequested" // TemplateUpdateRequestedEvent is the cloudevent subject for TemplateUpdate TemplateUpdateRequestedEvent common.EventType = common.EventTypePrefix + "TemplateUpdateRequested" // TemplateSyncRequestedEvent is the cloudevent subject for TemplateSync TemplateSyncRequestedEvent common.EventType = common.EventTypePrefix + "TemplateSyncRequested" // TemplateVersionDisableRequestedEvent is the cloudevent subject for disable request for a template version TemplateVersionDisableRequestedEvent common.EventType = common.EventTypePrefix + "Template.Version.DisableRequested" // TemplateImportedEvent is the cloudevent subject for TemplateImported TemplateImportedEvent common.EventType = common.EventTypePrefix + "TemplateImported" // TemplateDeletedEvent is the cloudevent subject for TemplateDeleted TemplateDeletedEvent common.EventType = common.EventTypePrefix + "TemplateDeleted" // TemplateUpdatedEvent is the cloudevent subject for TemplateUpdated TemplateUpdatedEvent common.EventType = common.EventTypePrefix + "TemplateUpdated" // TemplateSyncedEvent is the cloudevent subject for TemplateSynced TemplateSyncedEvent common.EventType = common.EventTypePrefix + "TemplateSynced" // TemplateImportFailedEvent is the cloudevent subject for TemplateImportFailed TemplateImportFailedEvent common.EventType = common.EventTypePrefix + "TemplateImportFailed" // TemplateDeleteFailedEvent is the cloudevent subject for TemplateDeleteFailed TemplateDeleteFailedEvent common.EventType = common.EventTypePrefix + "TemplateDeleteFailed" // TemplateUpdateFailedEvent is the cloudevent subject for TemplateUpdateFailed TemplateUpdateFailedEvent common.EventType = common.EventTypePrefix + "TemplateUpdateFailed" // TemplateSyncFailedEvent is the cloudevent subject for TemplateSyncFailed TemplateSyncFailedEvent common.EventType = common.EventTypePrefix + "TemplateSyncFailed" // TemplateVersionDisabledEvent is the cloudevent subject for VersionDisabled TemplateVersionDisabledEvent common.EventType = common.EventTypePrefix + "Template.Version.Disabled" // TemplateVersionDisableFailedEvent is the cloudevent subject for VersionDisableFailed TemplateVersionDisableFailedEvent common.EventType = common.EventTypePrefix + "Template.Version.DisableFailed" )
Nats subjects
const ( // NatsSubjectTemplateWebhook is the prefix of the queue name for Template Webhook queries NatsSubjectTemplateWebhook common.QueryOp = common.NatsQueryOpPrefix + "template.webhook" // TemplateWebhookListQueryOp is the queue name for TemplateWebhookList query TemplateWebhookListQueryOp = NatsSubjectTemplateWebhook + ".list" // TemplateWebhookCreateRequestedEvent is the cloudevent subject for TemplateWebhookCreationRequest TemplateWebhookCreateRequestedEvent common.EventType = common.EventTypePrefix + "Template.Webhook.CreateRequested" // TemplateWebhookDeleteRequestedEvent is the cloudevent subject for TemplateWebhookDeletionRequest TemplateWebhookDeleteRequestedEvent common.EventType = common.EventTypePrefix + "Template.Webhook.DeleteRequested" // TemplateWebhookCreatedEvent is the cloudevent subject for TemplateWebhookCreationResponse TemplateWebhookCreatedEvent common.EventType = common.EventTypePrefix + "Template.Webhook.Created" // TemplateWebhookDeletedEvent is the cloudevent subject for TemplateWebhookDeletionResponse TemplateWebhookDeletedEvent common.EventType = common.EventTypePrefix + "Template.Webhook.Deleted" // TemplateWebhookCreateFailedEvent is the cloudevent subject for TemplateWebhookCreationResponse TemplateWebhookCreateFailedEvent common.EventType = common.EventTypePrefix + "Template.Webhook.CreateFailed" // TemplateWebhookDeleteFailedEvent is the cloudevent subject for TemplateWebhookDeletionResponse TemplateWebhookDeleteFailedEvent common.EventType = common.EventTypePrefix + "Template.Webhook.DeleteFailed" )
const ( // NatsSubjectToken is the prefix of the queue name for Token queries NatsSubjectToken common.QueryOp = common.NatsQueryOpPrefix + "token" // TokenListQueryOp is the queue name for TokenList query TokenListQueryOp = NatsSubjectToken + ".list" // TokenGetQueryOp is the queue name for TokenGet query TokenGetQueryOp = NatsSubjectToken + ".get" // TokenAuthCheckQueryOp is the queue name for checking authN and authZ of a token TokenAuthCheckQueryOp = NatsSubjectToken + ".authCheck" // TokenTypesListQueryOp is the cloudevent subject for ListTokenTypes TokenTypesListQueryOp = NatsSubjectToken + ".listTypes" // TokenCreateRequestedEvent is the cloudevent subject for TokenCreate TokenCreateRequestedEvent common.EventType = common.EventTypePrefix + "TokenCreateRequested" // TokenDeleteRequestedEvent is the cloudevent subject for TokenDelete TokenDeleteRequestedEvent common.EventType = common.EventTypePrefix + "TokenDeleteRequested" // TokenUpdateRequestedEvent is the cloudevent subject for TokenUpdate TokenUpdateRequestedEvent common.EventType = common.EventTypePrefix + "TokenUpdateRequested" // TokenRevokeRequestedEvent is the cloudevent subject for TokenRevoke TokenRevokeRequestedEvent common.EventType = common.EventTypePrefix + "TokenRevokeRequested" // TokenCreatedEvent is the cloudevent subject for TokenCreated TokenCreatedEvent common.EventType = common.EventTypePrefix + "TokenCreated" // TokenDeletedEvent is the cloudevent subject for TokenDeleted TokenDeletedEvent common.EventType = common.EventTypePrefix + "TokenDeleted" // TokenUpdatedEvent is the cloudevent subject for TokenUpdated TokenUpdatedEvent common.EventType = common.EventTypePrefix + "TokenUpdated" // TokenRevokedEvent is the cloudevent subject for TokenRevoked TokenRevokedEvent common.EventType = common.EventTypePrefix + "TokenRevoked" // TokenCreateFailedEvent is the cloudevent subject for TokenCreateFailed TokenCreateFailedEvent common.EventType = common.EventTypePrefix + "TokenCreateFailed" // TokenDeleteFailedEvent is the cloudevent subject for TokenDeleteFailed TokenDeleteFailedEvent common.EventType = common.EventTypePrefix + "TokenDeleteFailed" // TokenUpdateFailedEvent is the cloudevent subject for TokenUpdateFailed TokenUpdateFailedEvent common.EventType = common.EventTypePrefix + "TokenUpdateFailed" // TokenRevokeFailedEvent is the cloudevent subject for TokenRevokeFailed TokenRevokeFailedEvent common.EventType = common.EventTypePrefix + "TokenRevokeFailed" )
Nats subjects
const ( // DefaultUserListItemsMax is the default maximum number of UserList items to return DefaultUserListItemsMax = 500 // ReservedCacaoSystemActor is a special actor that is used by the API gateway and perhaps other internal services, // which may be used to perform adminstrative operations on the user microservice, such as autocreating users // This is not a real user and logic should be added to prohibit creation of such a username ReservedCacaoSystemActor = "RESERVED_CACAO_SYSTEM_ACTOR" // ReservedAnonymousActor is a special actor that is used by the API gateway to denote public access. This is used // for endpoints that do not require authentication, but needs to publish events/query onto the message bus. ReservedAnonymousActor = "RESERVED_ANONYMOUS_ACTOR" )
const ( // NatsSubjectUserAction is the prefix of the queue name for UserAction queries NatsSubjectUserAction common.QueryOp = common.NatsQueryOpPrefix + "user_action" // UserActionListQueryOp is the queue name for UserActionList query UserActionListQueryOp = NatsSubjectUserAction + ".list" // UserActionGetQueryOp is the queue name for UserActionGet query UserActionGetQueryOp = NatsSubjectUserAction + ".get" // UserActionCreateRequestedEvent is the cloudevent subject for UserActionCreate UserActionCreateRequestedEvent common.EventType = common.EventTypePrefix + "UserActionCreateRequested" // UserActionDeleteRequestedEvent is the cloudevent subject for UserActionDelete UserActionDeleteRequestedEvent common.EventType = common.EventTypePrefix + "UserActionDeleteRequested" // UserActionUpdateRequestedEvent is the cloudevent subject for UserActionUpdate UserActionUpdateRequestedEvent common.EventType = common.EventTypePrefix + "UserActionUpdateRequested" // UserActionCreatedEvent is the cloudevent subject for UserActionCreated UserActionCreatedEvent common.EventType = common.EventTypePrefix + "UserActionCreated" // UserActionDeletedEvent is the cloudevent subject for UserActionDeleted UserActionDeletedEvent common.EventType = common.EventTypePrefix + "UserActionDeleted" // UserActionUpdatedEvent is the cloudevent subject for UserActionUpdated UserActionUpdatedEvent common.EventType = common.EventTypePrefix + "UserActionUpdated" // UserActionCreateFailedEvent is the cloudevent subject for UserActionCreateFailed UserActionCreateFailedEvent common.EventType = common.EventTypePrefix + "UserActionCreateFailed" // UserActionDeleteFailedEvent is the cloudevent subject for UserActionDeleteFailed UserActionDeleteFailedEvent common.EventType = common.EventTypePrefix + "UserActionDeleteFailed" // UserActionUpdateFailedEvent is the cloudevent subject for UserActionUpdateFailed UserActionUpdateFailedEvent common.EventType = common.EventTypePrefix + "UserActionUpdateFailed" )
Nats subjects
const ( NatsSubjectUsers common.QueryOp = common.NatsQueryOpPrefix + "users" NatsSubjectUsersGet common.QueryOp = NatsSubjectUsers + ".get" NatsSubjectUsersGetWithSettings common.QueryOp = NatsSubjectUsers + ".getwithsettings" NatsSubjectUsersList common.QueryOp = NatsSubjectUsers + ".list" EventUserLogin common.EventType = common.EventTypePrefix + "UserLogin" EventUserAddRequested common.EventType = common.EventTypePrefix + "UserAddRequested" EventUserUpdateRequested common.EventType = common.EventTypePrefix + "UserUpdateRequested" EventUserDeleteRequested common.EventType = common.EventTypePrefix + "UserDeleteRequested" EventUserAdded common.EventType = common.EventTypePrefix + "UserAdded" EventUserUpdated common.EventType = common.EventTypePrefix + "UserUpdated" EventUserDeleted common.EventType = common.EventTypePrefix + "UserDeleted" EventUserAddError common.EventType = common.EventTypePrefix + "UserAddError" EventUserUpdateError common.EventType = common.EventTypePrefix + "UserUpdateError" EventUserDeleteError common.EventType = common.EventTypePrefix + "UserDeleteError" )
Nats Subjects root, get, list and other channels
const ( NatsSubjectUserConfigsGet common.QueryOp = NatsSubjectUsers + ".getconfigs" NatsSubjectUserFavoritesGet common.QueryOp = NatsSubjectUsers + ".getfavorites" NatsSubjectUserRecentsGet common.QueryOp = NatsSubjectUsers + ".getrecents" NatsSubjectUserSettingsGet common.QueryOp = NatsSubjectUsers + ".getsettings" EventUserConfigSetRequested common.EventType = common.EventTypePrefix + "UserConfigSetRequested" EventUserFavoriteAddRequested common.EventType = common.EventTypePrefix + "UserFavoriteAddRequested" EventUserFavoriteDeleteRequested common.EventType = common.EventTypePrefix + "UserFavoriteDeleteRequested" EventUserRecentSetRequested common.EventType = common.EventTypePrefix + "UserRecentSetRequested" EventUserConfigSet common.EventType = common.EventTypePrefix + "UserConfigSet" EventUserFavoriteAdded common.EventType = common.EventTypePrefix + "UserFavoriteAdded" EventUserFavoriteDeleted common.EventType = common.EventTypePrefix + "UserFavoriteDeleted" EventUserRecentSet common.EventType = common.EventTypePrefix + "UserRecentSet" EventUserConfigSetError common.EventType = common.EventTypePrefix + "UserConfigSetError" EventUserFavoriteAddError common.EventType = common.EventTypePrefix + "UserFavoriteAddError" EventUserFavoriteDeleteError common.EventType = common.EventTypePrefix + "UserFavoriteDeleteError" EventUserRecentSetError common.EventType = common.EventTypePrefix + "UserRecentSetError" )
EventType constants for operations that manipulates user configs/settings
const ( // NatsSubjectWorkspace is the prefix of the queue name for Workspace queries NatsSubjectWorkspace common.QueryOp = common.NatsQueryOpPrefix + "workspace" // WorkspaceListQueryOp is the queue name for WorkspaceList query WorkspaceListQueryOp = NatsSubjectWorkspace + ".list" // WorkspaceGetQueryOp is the queue name for WorkspaceGet query WorkspaceGetQueryOp = NatsSubjectWorkspace + ".get" // WorkspaceCreateRequestedEvent is the cloudevent subject for WorkspaceCreate WorkspaceCreateRequestedEvent common.EventType = common.EventTypePrefix + "WorkspaceCreateRequested" // WorkspaceDeleteRequestedEvent is the cloudevent subject for WorkspaceDelete WorkspaceDeleteRequestedEvent common.EventType = common.EventTypePrefix + "WorkspaceDeleteRequested" // WorkspaceUpdateRequestedEvent is the cloudevent subject for WorkspaceUpdate WorkspaceUpdateRequestedEvent common.EventType = common.EventTypePrefix + "WorkspaceUpdateRequested" // WorkspaceCreatedEvent is the cloudevent subject for WorkspaceCreated WorkspaceCreatedEvent common.EventType = common.EventTypePrefix + "WorkspaceCreated" // WorkspaceDeletedEvent is the cloudevent subject for WorkspaceDeleted WorkspaceDeletedEvent common.EventType = common.EventTypePrefix + "WorkspaceDeleted" // WorkspaceUpdatedEvent is the cloudevent subject for WorkspaceUpdated WorkspaceUpdatedEvent common.EventType = common.EventTypePrefix + "WorkspaceUpdated" // WorkspaceCreateFailedEvent is the cloudevent subject for WorkspaceCreateFailed WorkspaceCreateFailedEvent common.EventType = common.EventTypePrefix + "WorkspaceCreateFailed" // WorkspaceDeleteFailedEvent is the cloudevent subject for WorkspaceDeleteFailed WorkspaceDeleteFailedEvent common.EventType = common.EventTypePrefix + "WorkspaceDeleteFailed" // WorkspaceUpdateFailedEvent is the cloudevent subject for WorkspaceUpdateFailed WorkspaceUpdateFailedEvent common.EventType = common.EventTypePrefix + "WorkspaceUpdateFailed" )
Nats subjects
const DeploymentCreateFailed common.EventType = common.EventTypePrefix + "DeploymentCreateFailed"
DeploymentCreateFailed ...
const DeploymentCreateRunRequested common.EventType = common.EventTypePrefix + "DeploymentCreateRunRequested"
DeploymentCreateRunRequested ...
const DeploymentCreated common.EventType = common.EventTypePrefix + "DeploymentCreated"
DeploymentCreated ...
const DeploymentCreationRequested common.EventType = common.EventTypePrefix + "DeploymentCreationRequested"
DeploymentCreationRequested ...
const DeploymentDeleteFailed common.EventType = common.EventTypePrefix + "DeploymentDeleteFailed"
DeploymentDeleteFailed ...
const DeploymentDeleted common.EventType = common.EventTypePrefix + "DeploymentDeleted"
DeploymentDeleted ...
const DeploymentDeletionRequested common.EventType = common.EventTypePrefix + "DeploymentDeletionRequested"
DeploymentDeletionRequested ...
const DeploymentDeletionStarted common.EventType = common.EventTypePrefix + "DeploymentDeletionStarted"
DeploymentDeletionStarted indicate that the deletion has started but not yet finished. This event is only emitted if the deletion involves clean up cloud resources. Note: deletion could still fail after this.
const DeploymentIDPrefix string = "deployment"
DeploymentIDPrefix is the prefix for deployment ID
const DeploymentMonitoringStartFailed common.EventType = common.EventTypePrefix + "DeploymentMonitoringStartFailed"
DeploymentMonitoringStartFailed ...
const DeploymentMonitoringStarted common.EventType = common.EventTypePrefix + "DeploymentMonitoringStarted"
DeploymentMonitoringStarted ...
const DeploymentMonitoringStopFailed common.EventType = common.EventTypePrefix + "DeploymentMonitoringStopFailed"
DeploymentMonitoringStopFailed ...
const DeploymentMonitoringStopped common.EventType = common.EventTypePrefix + "DeploymentMonitoringStopped"
DeploymentMonitoringStopped ...
const DeploymentParameterUpdateFailed common.EventType = common.EventTypePrefix + "DeploymentParameterUpdateFailed"
DeploymentParameterUpdateFailed ...
const DeploymentParameterUpdateRequested common.EventType = common.EventTypePrefix + "DeploymentParameterUpdateRequested"
DeploymentParameterUpdateRequested ...
const DeploymentParameterUpdated common.EventType = common.EventTypePrefix + "DeploymentParameterUpdated"
DeploymentParameterUpdated ...
const DeploymentRunCreateFailed common.EventType = common.EventTypePrefix + "DeploymentRunCreateFailed"
DeploymentRunCreateFailed ...
const DeploymentRunCreated common.EventType = common.EventTypePrefix + "DeploymentRunCreated"
DeploymentRunCreated ...
const DeploymentStartMonitoringRequested common.EventType = common.EventTypePrefix + "DeploymentStartMonitoringRequested"
DeploymentStartMonitoringRequested ...
const DeploymentStateRefreshFailed common.EventType = common.EventTypePrefix + "DeploymentStateRefreshFailed"
DeploymentStateRefreshFailed ...
const DeploymentStateRefreshRequested common.EventType = common.EventTypePrefix + "DeploymentStateRefreshRequested"
DeploymentStateRefreshRequested ...
const DeploymentStateRefreshed common.EventType = common.EventTypePrefix + "DeploymentStateRefreshed"
DeploymentStateRefreshed ...
const DeploymentStopMonitoringRequested common.EventType = common.EventTypePrefix + "DeploymentStopMonitoringRequested"
DeploymentStopMonitoringRequested ...
const DeploymentUpdateFailed common.EventType = common.EventTypePrefix + "DeploymentUpdateFailed"
DeploymentUpdateFailed ...
const DeploymentUpdateRequested common.EventType = common.EventTypePrefix + "DeploymentParameterUpdateRequested"
DeploymentUpdateRequested ...
const DeploymentUpdated common.EventType = common.EventTypePrefix + "DeploymentUpdated"
DeploymentUpdated ...
const EventDeploymentStateRefreshStarted common.EventType = common.EventTypePrefix + "DeploymentStateRefreshStarted"
EventDeploymentStateRefreshStarted is event type that indicates the refresh state has started
const RunIDPrefix string = "run"
RunIDPrefix is the prefix for run ID
const (
UserListFilterValueEmptyWarning string = "Warning UserFilter value was not set, will return all"
)
these are just warning strings to create a new error, call error.New(string)
const WorkflowCreateFailedEvent common.EventType = common.EventTypePrefix + "WorkflowCreateFailed"
WorkflowCreateFailedEvent is the event name of WorkflowCreateFailed
const WorkflowCreateRequestedEvent common.EventType = common.EventTypePrefix + "WorkflowCreateRequested"
WorkflowCreateRequestedEvent is the type name of WorkflowCreate request
const WorkflowCreatedEvent common.EventType = common.EventTypePrefix + "WorkflowCreated"
WorkflowCreatedEvent is the cloudevent name of WorkflowCreated defined below
const WorkflowResubmitFailedEvent common.EventType = common.EventTypePrefix + "WorkflowResubmitFailed"
WorkflowResubmitFailedEvent is the name of the WorkflowResubmitFailed event
const WorkflowResubmitRequestedEvent common.EventType = common.EventTypePrefix + "WorkflowResubmitRequested"
WorkflowResubmitRequestedEvent is the type name of WorkflowResubmit request
const WorkflowResubmittedEvent common.EventType = common.EventTypePrefix + "WorkflowResubmitted"
WorkflowResubmittedEvent is the name of the WorkflowResubmitted event
const WorkflowTerminateFailedEvent common.EventType = common.EventTypePrefix + "WorkflowTerminateFailed"
WorkflowTerminateFailedEvent is the name of the WorkflowTerminateFailed
const WorkflowTerminateRequestedEvent common.EventType = common.EventTypePrefix + "WorkflowTerminateRequested"
WorkflowTerminateRequestedEvent is the type name of WorkflowTerminate request
const WorkflowTerminatedEvent common.EventType = common.EventTypePrefix + "WorkflowTerminated"
WorkflowTerminatedEvent is the name of the WorkflowTerminated
Variables ¶
var DeploymentStatusAllowDeletion = []DeploymentStatus{ DeploymentStatusNone, DeploymentStatusActive, DeploymentStatusCreationErrored, DeploymentStatusDeletionErrored, }
DeploymentStatusAllowDeletion is list of current status that allows deletion.
var DeploymentStatusAllowRunCreation = []DeploymentStatus{ DeploymentStatusNone, DeploymentStatusActive, DeploymentStatusCreationErrored, }
DeploymentStatusAllowRunCreation is list of current status that allows run creation.
var ( // TemplateCacaoReservedPurposes defines cacao reserved purposes TemplateCacaoReservedPurposes []TemplatePurpose = []TemplatePurpose{TemplatePurposeCacaoPrerequisite} )
Functions ¶
func NewInteractiveSessionID ¶
NewInteractiveSessionID generates a new InteractiveSessionID
func NewJS2ProjectID ¶
NewJS2ProjectID generates a new JS2ProjectID
func NewUserActionID ¶
NewUserActionID generates a new UserActionID
Types ¶
type AWMProvider ¶
type AWMProvider string
AWMProvider is the ID of cloud provider, used by Argo Workflow Mediator(AWM)
type Actor ¶
Actor is the user that performs certain action. This is for scenario where you only need to express the user that initiate actions without including error like Session does.
func ActorFromSession ¶
ActorFromSession construct Actor from service.Session
type CacaoAlreadyExistError ¶
type CacaoAlreadyExistError struct {
CacaoErrorBase
}
CacaoAlreadyExistError is an error for object already exist
type CacaoCommunicationError ¶
type CacaoCommunicationError struct {
CacaoErrorBase
}
CacaoCommunicationError is an error for communication failure.
type CacaoError ¶
type CacaoError interface { // Error returns error message that includes both contextual and standard error messages. Error() string // ContextualError returns contextual error message. e.g., "actor 'edwin' is not authorized to create a user" ContextualError() string // StandardError returns standard error message. e.g., "unauthorize access" StandardError() CacaoStandardErrorMessage // IsTemporary tells if the error is transitive meaning that you may get different result at next call. IsTemporary() bool // MarshalJSON marshals the error to JSON bytes MarshalJSON() ([]byte, error) // GetBase returns CacaoErrorBase type GetBase() CacaoErrorBase }
CacaoError is for cacao service errors.
func ConvertJSONToCacaoError ¶
func ConvertJSONToCacaoError(jsonBytes []byte) (CacaoError, error)
ConvertJSONToCacaoError converts JSON bytes into CacaoError
func NewCacaoAlreadyExistError ¶
func NewCacaoAlreadyExistError(contextualMsg string) CacaoError
NewCacaoAlreadyExistError creates a new CacaoAlreadyExistError
func NewCacaoAlreadyExistErrorWithOptions ¶
func NewCacaoAlreadyExistErrorWithOptions(contextualMsg string, options ...CacaoErrorOption) CacaoError
NewCacaoAlreadyExistErrorWithOptions creates a new CacaoAlreadyExistError with options
func NewCacaoCommunicationError ¶
func NewCacaoCommunicationError(contextualMsg string) CacaoError
NewCacaoCommunicationError creates a new CacaoCommunicationError
func NewCacaoCommunicationErrorWithOptions ¶
func NewCacaoCommunicationErrorWithOptions(contextualMsg string, options ...CacaoErrorOption) CacaoError
NewCacaoCommunicationErrorWithOptions creates a new CacaoCommunicationError with options
func NewCacaoGeneralError ¶
func NewCacaoGeneralError(contextualMsg string) CacaoError
NewCacaoGeneralError creates a new CacaoGeneralError
func NewCacaoGeneralErrorWithOptions ¶
func NewCacaoGeneralErrorWithOptions(contextualMsg string, options ...CacaoErrorOption) CacaoError
NewCacaoGeneralErrorWithOptions creates a new CacaoGeneralError with options
func NewCacaoInvalidParameterError ¶
func NewCacaoInvalidParameterError(contextualMsg string) CacaoError
NewCacaoInvalidParameterError creates a new CacaoInvalidParameterError
func NewCacaoInvalidParameterErrorWithOptions ¶
func NewCacaoInvalidParameterErrorWithOptions(contextualMsg string, options ...CacaoErrorOption) CacaoError
NewCacaoInvalidParameterErrorWithOptions creates a new CacaoInvalidParameterError with options
func NewCacaoMarshalError ¶
func NewCacaoMarshalError(contextualMsg string) CacaoError
NewCacaoMarshalError creates a new CacaoMarshalError
func NewCacaoMarshalErrorWithOptions ¶
func NewCacaoMarshalErrorWithOptions(contextualMsg string, options ...CacaoErrorOption) CacaoError
NewCacaoMarshalErrorWithOptions creates a new CacaoMarshalError with options
func NewCacaoNotFoundError ¶
func NewCacaoNotFoundError(contextualMsg string) CacaoError
NewCacaoNotFoundError creates a new CacaoNotFoundError
func NewCacaoNotFoundErrorWithOptions ¶
func NewCacaoNotFoundErrorWithOptions(contextualMsg string, options ...CacaoErrorOption) CacaoError
NewCacaoNotFoundErrorWithOptions creates a new CacaoNotFoundError with options
func NewCacaoNotImplementedError ¶
func NewCacaoNotImplementedError(contextualMsg string) CacaoError
NewCacaoNotImplementedError creates a new CacaoNotImplementedError
func NewCacaoNotImplementedErrorWithOptions ¶
func NewCacaoNotImplementedErrorWithOptions(contextualMsg string, options ...CacaoErrorOption) CacaoError
NewCacaoNotImplementedErrorWithOptions creates a new CacaoNotImplementedError with options
func NewCacaoOperationCanceledError ¶
func NewCacaoOperationCanceledError(contextualMsg string) CacaoError
NewCacaoOperationCanceledError creates a new CacaoOperationCanceledError
func NewCacaoOperationCanceledErrorWithOptions ¶
func NewCacaoOperationCanceledErrorWithOptions(contextualMsg string, options ...CacaoErrorOption) CacaoError
NewCacaoOperationCanceledErrorWithOptions creates a new CacaoOperationCanceledError with options
func NewCacaoTimeoutError ¶
func NewCacaoTimeoutError(contextualMsg string) CacaoError
NewCacaoTimeoutError creates a new CacaoTimeoutError
func NewCacaoTimeoutErrorWithOptions ¶
func NewCacaoTimeoutErrorWithOptions(contextualMsg string, options ...CacaoErrorOption) CacaoError
NewCacaoTimeoutErrorWithOptions creates a new CacaoTimeoutError with options
func NewCacaoUnauthorizedError ¶
func NewCacaoUnauthorizedError(contextualMsg string) CacaoError
NewCacaoUnauthorizedError creates a new CacaoUnauthorizedError
func NewCacaoUnauthorizedErrorWithOptions ¶
func NewCacaoUnauthorizedErrorWithOptions(contextualMsg string, options ...CacaoErrorOption) CacaoError
NewCacaoUnauthorizedErrorWithOptions creates a new CacaoUnauthorizedError with options
func ToCacaoError ¶
func ToCacaoError(err error) CacaoError
ToCacaoError check if error is CacaoError, if not wrap the error message into a general error
type CacaoErrorBase ¶
type CacaoErrorBase struct { StandardMessage CacaoStandardErrorMessage `json:"standard_msg"` ContextualMessage string `json:"contextual_msg,omitempty"` Options CacaoErrorOptions `json:"options,omitempty"` }
CacaoErrorBase is a struct for base cacao service error type.
func (*CacaoErrorBase) ContextualError ¶
func (err *CacaoErrorBase) ContextualError() string
ContextualError returns a contextual error message
func (*CacaoErrorBase) GetBase ¶
func (err *CacaoErrorBase) GetBase() CacaoErrorBase
GetBase returns CacaoErrorBase type
func (*CacaoErrorBase) IsTemporary ¶
func (err *CacaoErrorBase) IsTemporary() bool
IsTemporary returns whether the error is temporary
func (*CacaoErrorBase) MarshalJSON ¶
func (err *CacaoErrorBase) MarshalJSON() ([]byte, error)
MarshalJSON returns JSON bytes
func (*CacaoErrorBase) ReplaceOptions ¶
func (err *CacaoErrorBase) ReplaceOptions(options CacaoErrorOptions)
ReplaceOptions replace existing options
func (*CacaoErrorBase) SetContextualError ¶
func (err *CacaoErrorBase) SetContextualError(message string)
SetContextualError sets a contextual error message
func (*CacaoErrorBase) SetOptions ¶
func (err *CacaoErrorBase) SetOptions(options ...CacaoErrorOption)
SetOptions sets options
func (*CacaoErrorBase) SetStandardError ¶
func (err *CacaoErrorBase) SetStandardError(message CacaoStandardErrorMessage)
SetStandardError sets a standard error message
func (*CacaoErrorBase) StandardError ¶
func (err *CacaoErrorBase) StandardError() CacaoStandardErrorMessage
StandardError returns a standard error message
type CacaoErrorOption ¶
type CacaoErrorOption func(options *CacaoErrorOptions)
CacaoErrorOption is a option type for CacaoError
func CacaoErrorTemporary ¶
func CacaoErrorTemporary(val bool) CacaoErrorOption
CacaoErrorTemporary creates an option for CacaoError meaning that the error is temporary
type CacaoErrorOptions ¶
type CacaoErrorOptions struct {
Temporary bool `json:"temporary,omitempty"` // set true if the error is temporary one
}
CacaoErrorOptions is an option that stores additional information of the error
type CacaoGeneralError ¶
type CacaoGeneralError struct {
CacaoErrorBase
}
CacaoGeneralError is an error for general failure.
type CacaoInvalidParameterError ¶
type CacaoInvalidParameterError struct {
CacaoErrorBase
}
CacaoInvalidParameterError is an error for invalid input parameter
type CacaoMarshalError ¶
type CacaoMarshalError struct {
CacaoErrorBase
}
CacaoMarshalError is an error for marshal and unmarshal.
type CacaoNotFoundError ¶
type CacaoNotFoundError struct {
CacaoErrorBase
}
CacaoNotFoundError is an error for object not found
type CacaoNotImplementedError ¶
type CacaoNotImplementedError struct {
CacaoErrorBase
}
CacaoNotImplementedError is an error for function not implemented
type CacaoOperationCanceledError ¶
type CacaoOperationCanceledError struct {
CacaoErrorBase
}
CacaoOperationCanceledError is an error for operation canceled
type CacaoStandardErrorMessage ¶
type CacaoStandardErrorMessage string
CacaoStandardErrorMessage is an error message type, describing error type. It is also used to determine error type (e.g., CacaoMarshalError) from CacaoError interface.
const ( CacaoMarshalErrorMessage CacaoStandardErrorMessage = "marshal/unmarshal failed" CacaoTimeoutErrorMessage CacaoStandardErrorMessage = "operation timedout error" CacaoOperationCanceledErrorMessage CacaoStandardErrorMessage = "operation canceled error" CacaoInvalidParameterErrorMessage CacaoStandardErrorMessage = "invalid parameter error" CacaoNotFoundErrorMessage CacaoStandardErrorMessage = "object not found" CacaoAlreadyExistErrorMessage CacaoStandardErrorMessage = "object already exist" CacaoNotImplementedErrorMessage CacaoStandardErrorMessage = "function not implemenated" CacaoCommunicationErrorMessage CacaoStandardErrorMessage = "communication failed" // e.g., NATS request failed CacaoGeneralErrorMessage CacaoStandardErrorMessage = "work failed" )
defines standard error messages the standard error messages are used to determine types of CacaoError and to describe error
type CacaoTimeoutError ¶
type CacaoTimeoutError struct {
CacaoErrorBase
}
CacaoTimeoutError is an error for operation timeout
type CacaoUnauthorizedError ¶
type CacaoUnauthorizedError struct {
}CacaoUnauthorizedError is an error for unauthorized user/access
type CredentialClient ¶
type CredentialClient interface { Get(ctx context.Context, actor Actor, ID string) (*CredentialModel, error) List(ctx context.Context, actor Actor, filter CredentialListFilter) ([]CredentialModel, error) Add(ctx context.Context, actor Actor, secret CredentialModel) (credID string, err error) Update(ctx context.Context, actor Actor, credID string, update CredentialUpdate) error Delete(ctx context.Context, actor Actor, ID string) error Generate(ctx context.Context, actor Actor, credential CredentialModel) (credID string, err error) }
CredentialClient ...
func NewNatsCredentialClientFromConn ¶
func NewNatsCredentialClientFromConn(queryConn messaging2.QueryConnection, eventConn messaging2.EventConnection) (CredentialClient, error)
NewNatsCredentialClientFromConn creates a new client from existing Connections. Note if you only need query functionality, then only supply queryConn, same for event functionality and eventConn.
type CredentialCreateRequest ¶
type CredentialCreateRequest CredentialModel
CredentialCreateRequest ...
type CredentialCreateResponse ¶
type CredentialCreateResponse struct { Session `json:",inline"` Username string `json:"username,omitempty"` ID string `json:"id,omitempty"` Type CredentialType `json:"type,omitempty"` }
CredentialCreateResponse ...
type CredentialDeleteRequest ¶
type CredentialDeleteRequest struct { Session `json:",inline"` Username string `json:"username"` ID string `json:"id"` }
CredentialDeleteRequest ...
type CredentialDeleteResponse ¶
type CredentialDeleteResponse struct { Session `json:",inline"` Username string `json:"username,omitempty"` ID string `json:"id,omitempty"` Type CredentialType `json:"type,omitempty"` }
CredentialDeleteResponse ...
type CredentialGetRequest ¶
type CredentialGetRequest struct { Session `json:",inline"` Username string `json:"username"` ID string `json:"id"` }
CredentialGetRequest ...
type CredentialListFilter ¶
type CredentialListFilter struct { Username string `json:"username"` // owner, default to actor Type CredentialType `json:"type,omitempty"` // leave empty if all types IsSystem *bool `json:"is_system,omitempty"` // leave nil if both system & non-system Disabled *bool `json:"disabled,omitempty"` // leave nil if both disabled & enabled Tags map[string]string `json:"tag"` // leave tag value as empty if only want to check tag name present }
CredentialListFilter contains the filter options supported by the list operation
type CredentialListReply ¶
type CredentialListReply struct { Session `json:",inline"` Username string `json:"username"` // owner List []CredentialModel `json:"list"` }
CredentialListReply ...
type CredentialListRequest ¶
type CredentialListRequest struct { Session `json:",inline"` Filter CredentialListFilter `json:",inline"` }
CredentialListRequest ...
type CredentialModel ¶
type CredentialModel struct { Session ID string `json:"id"` Name string `json:"name"` Username string `json:"username"` Type CredentialType `json:"type"` Value string `json:"value,omitempty"` Description string `json:"description,omitempty"` IsSystem bool `json:"is_system,omitempty"` IsHidden bool `json:"is_hidden,omitempty"` Disabled bool `json:"disabled"` Visibility VisibilityType `json:"visibility,omitempty"` // not currently used, neither service nor client respect this value. There is a default value "Default" Tags map[string]string `json:"tags,omitempty"` CreatedAt time.Time `json:"created_at"` UpdatedAt time.Time `json:"updated_at"` UpdatedBy string `json:"updated_by"` UpdatedEmulatorBy string `json:"updated_emulator_by"` }
CredentialModel ...
func (*CredentialModel) AddTag ¶
func (c *CredentialModel) AddTag(s string)
AddTag add a tag to the credential. Tag is added as a tag key (unique within a credential)
func (*CredentialModel) GetPrimaryID ¶
func (c *CredentialModel) GetPrimaryID() string
GetPrimaryID returns the globally unique ID of the credential, which is the combination of owner's username and credential ID.
func (*CredentialModel) GetRedacted ¶
func (c *CredentialModel) GetRedacted() CredentialModel
GetRedacted will return a new Secret with the Value set to "REDACTED"
func (*CredentialModel) GetTags ¶
func (c *CredentialModel) GetTags() []string
GetTags return tags as a list of string (tag keys)
func (*CredentialModel) RemoveTag ¶
func (c *CredentialModel) RemoveTag(s string)
RemoveTag removes a tag from credential.
func (*CredentialModel) Verify ¶
func (c *CredentialModel) Verify() (bool, error)
Verify verify a credential model
type CredentialType ¶
type CredentialType string
CredentialType is the type of credential.
const ( GitCredentialType CredentialType = "git" PublicSSHKeyCredentialType CredentialType = "ssh" PrivateSSHKeyCredentialType CredentialType = "ssh_private" OpenStackCredentialType CredentialType = "openstack" AWSCredentialType CredentialType = "aws" KubeconfigCredentialType CredentialType = "kubeconfig" )
CredentialType Constants
type CredentialUpdate ¶
type CredentialUpdate struct { Name *string `json:"name,omitempty"` // modify type could affect other service, there is not a clear use case to modify credential type, credential created with wrong type should be deleted and re-created. //Type *CredentialType `json:"type,omitempty"` Value *string `json:"value,omitempty"` Description *string `json:"description,omitempty"` Disabled *bool `json:"disabled,omitempty"` Visibility *VisibilityType `json:"visibility,omitempty"` // update or add (if tag name does not exist) tags UpdateOrAddTags map[string]string `json:"update_tags,omitempty"` DeleteTags map[string]struct{} `json:"delete_tags,omitempty"` }
CredentialUpdate is a struct that contains fields for credential that can be updated. Fields in this struct should correspond to fields in CredentialModel, but the type should be null-able equivalent (e.g. string => *string). If the value of a field in this struct is nil, that means the field should not be updated.
func (CredentialUpdate) NeedToUpdate ¶
func (update CredentialUpdate) NeedToUpdate() bool
NeedToUpdate checks if there is a need to update credential.
type CredentialUpdateRequest ¶
type CredentialUpdateRequest struct { Session `json:",inline"` Username string `json:"username"` ID string `json:"id"` Update CredentialUpdate `json:"update"` }
CredentialUpdateRequest ...
type CredentialUpdateResponse ¶
type CredentialUpdateResponse struct { Session `json:",inline"` Username string `json:"username"` ID string `json:"id"` Type CredentialType `json:"type,omitempty"` ValueUpdated bool `json:"value_updated"` }
CredentialUpdateResponse ...
type DepCheckDeletionRequest ¶
DepCheckDeletionRequest is event body for deletion request with dependent checking. Note: the type of object to be deleted is not specified by fields in this struct, but by the event type.
type DepCheckDeletionResponse ¶
type DepCheckDeletionResponse struct { Session ID string `json:"ID"` Deleted bool `json:"deleted"` HasDependent bool `json:"has_dependent"` }
DepCheckDeletionResponse is event body for response to deletion request with dependent checking. Note: the type of object to be deleted is not specified by fields in this struct, but by the event type.
func (DepCheckDeletionResponse) Errored ¶
func (resp DepCheckDeletionResponse) Errored() bool
Errored return true if the response has errored
type DepCheckDeletionResult ¶
DepCheckDeletionResult is the result of a deletion operation with dependency check
type DependencyMediatorClient ¶
type DependencyMediatorClient interface { DeleteCredential(ctx context.Context, session Session, credID string) (DepCheckDeletionResult, error) DeleteTemplate(ctx context.Context, session Session, template common.ID) (DepCheckDeletionResult, error) DeleteProvider(ctx context.Context, session Session, provider common.ID) (DepCheckDeletionResult, error) DeleteWorkspace(ctx context.Context, session Session, workspace common.ID) (DepCheckDeletionResult, error) }
DependencyMediatorClient is client interface for dependency mediator which checks and enforce for dependency relationship between different objects. e.g. a Credential cannot be deleted when there is a deployment dependent on it.
func NewDependencyMediatorClientFromConn ¶
func NewDependencyMediatorClientFromConn(queryConn messaging2.QueryConnection, eventConn messaging2.EventConnection) (DependencyMediatorClient, error)
NewDependencyMediatorClientFromConn ...
type Deployment ¶
type Deployment struct { ID common.ID `json:"id"` Name string `json:"name"` Description string `json:"description"` CreatedAt time.Time `json:"created_at"` UpdatedAt time.Time `json:"updated_at"` Owner string `json:"owner"` Workspace common.ID `json:"workspace"` Template common.ID `json:"template"` TemplateType TemplateTypeName `json:"template_type"` PrimaryCloud common.ID `json:"primary_cloud"` CurrentStatus DeploymentStatus `json:"current_status"` PendingStatus DeploymentPendingStatus `json:"pending_status"` StatusMsg string `json:"status_msg"` // map[CredentialID]ProviderID CloudCredentials map[string]common.ID `json:"cloud_credentials"` GitCredential string `json:"git_credential"` LastRun *DeploymentRun `json:"last_run"` }
Deployment ...
type DeploymentClient ¶
type DeploymentClient interface { Get(ctx context.Context, actor Actor, deploymentID common.ID) (*Deployment, error) Search(ctx context.Context, actor Actor, option DeploymentListOption) (DeploymentList, error) SearchNext(ctx context.Context, actor Actor, list DeploymentList) (DeploymentList, error) GetRun(ctx context.Context, actor Actor, deployment, run common.ID) (*DeploymentRun, error) SearchRun(ctx context.Context, actor Actor, option DeploymentRunListOption) (DeploymentRunList, error) SearchRunNext(ctx context.Context, actor Actor, list DeploymentRunList) (DeploymentRunList, error) GetRawState(ctx context.Context, actor Actor, deployment, run common.ID) ([]byte, error) ListDeploymentLogsLocations(ctx context.Context, actor Actor, deployment common.ID) ([]LogsLocation, error) ListRunLogsLocations(ctx context.Context, actor Actor, deployment, run common.ID) ([]LogsLocation, error) CreateAsync(actor Actor, tid common.TransactionID, option DeploymentCreateParam) error RefreshStateAsync(actor Actor, tid common.TransactionID, deployment common.ID) error UpdateAsync(actor Actor, tid common.TransactionID, deployment Deployment, updateFields []string) error UpdateParametersAsync(actor Actor, tid common.TransactionID, deployment common.ID, param DeploymentParameterValues) error DeleteAsync(actor Actor, tid common.TransactionID, deployment common.ID) error CreateRunAsync(actor Actor, tid common.TransactionID, param DeploymentRunCreateParam) error Create(ctx context.Context, actor Actor, tid common.TransactionID, option DeploymentCreateParam) (deployment common.ID, err error) // RefreshState may return (nil, nil) if the state refresh has started, but not completed. RefreshState(ctx context.Context, actor Actor, tid common.TransactionID, deployment common.ID) (*DeploymentStateView, error) Update(ctx context.Context, actor Actor, tid common.TransactionID, deployment Deployment, updateFields []string) (common.ID, error) UpdateParameters(ctx context.Context, actor Actor, tid common.TransactionID, deployment common.ID, param DeploymentParameterValues) (runID common.ID, err error) // Delete sends a deletion request and listen for a response. // Because deletion can be an async process (it needs time to clean up provisioned resources if any), when this call // return with no error, the deployment could still be in the deletion process. // The boolean return value indicate whether deployment has been deleted by this call. Delete(ctx context.Context, actor Actor, tid common.TransactionID, deployment common.ID) (deleted bool, err error) CreateRun(ctx context.Context, actor Actor, tid common.TransactionID, param DeploymentRunCreateParam) (*DeploymentRun, error) }
DeploymentClient is interface to interact with the Deployment Service. Async methods only publish the request, they do NOT wait for response. Sync method will generate new transaction ID if empty.
func NewDeploymentClientFromConn ¶
func NewDeploymentClientFromConn(queryConn messaging2.QueryConnection, eventConn messaging2.EventConnection) (DeploymentClient, error)
NewDeploymentClientFromConn creates a new client from existing connections.
Note, if you only need query functionality, then only supply queryConn, same for event functionality and eventConn.
type DeploymentCreateParam ¶
type DeploymentCreateParam struct { Name string `json:"name"` Description string `json:"description"` Workspace common.ID `json:"workspace"` Template common.ID `json:"template"` PrimaryCloud common.ID `json:"primary_cloud"` // all cloud providers that this deployment operates on CloudProviders []common.ID `json:"cloud_providers"` // map[CredentialID]ProviderID CloudCredentials map[string]common.ID `json:"cloud_credentials"` // if private git repo GitCredential string `json:"git_credential"` }
DeploymentCreateParam are parameter needed to create a new deployment.
type DeploymentCreateRunRequest ¶
type DeploymentCreateRunRequest struct { Session `json:",inline"` CreateParam DeploymentRunCreateParam `json:",inline"` }
DeploymentCreateRunRequest is an event that request the creation of a deployment run
type DeploymentCreateRunResult ¶
type DeploymentCreateRunResult struct { Session `json:",inline"` Run DeploymentRun `json:"run"` }
DeploymentCreateRunResult is an event that contains the result to the create run request
type DeploymentCreationRequest ¶
type DeploymentCreationRequest struct { Session `json:",inline"` CreateParam DeploymentCreateParam `json:",inline"` }
DeploymentCreationRequest is an event that request the creation of a deployment
type DeploymentCreationResult ¶
DeploymentCreationResult is an event that contains the result to the creation request
type DeploymentDeletionRequest ¶
type DeploymentDeletionRequest struct { Session `json:",inline"` // deployment ID ID common.ID `json:"id"` }
DeploymentDeletionRequest is an event that request the deletion of a deployment
type DeploymentDeletionResult ¶
type DeploymentDeletionResult struct { Session `json:",inline"` // deployment ID ID common.ID `json:"id"` TemplateType TemplateTypeName `json:"template_type"` }
DeploymentDeletionResult is an event that contains the result to the deletion request
type DeploymentFilter ¶
type DeploymentFilter struct { User string `json:"user,omitempty"` Template common.ID `json:"template,omitempty"` TemplateSet []common.ID `json:"template_set,omitempty"` Workspace common.ID `json:"workspace,omitempty"` PrimaryCloudProvider common.ID `json:"primary_provider,omitempty"` LastRunStatus string `json:"last_run_status,omitempty"` CurrentStatus DeploymentStatus `json:"current_status,omitempty"` PendingStatus DeploymentPendingStatus `json:"pending_status,omitempty"` // list deployment with any current status, this override the CurrentStatus filter AllCurrentStatus bool `json:"all_current_status,omitempty"` CredentialID string `json:"credential,omitempty"` }
DeploymentFilter are filters available on deployment list. Only results matched the set filter will be retained.
type DeploymentGetLogsQuery ¶
type DeploymentGetLogsQuery struct { Session `json:",inline"` Deployment common.ID `json:"deployment"` Run common.ID `json:"run"` }
DeploymentGetLogsQuery is a query to fetch the current logs of a deployment run Deprecated: logs itself should be fetched over HTTP instead of over NATS, use NATS for fetching HTTP URL to the logs
type DeploymentGetLogsReply ¶
type DeploymentGetLogsReply struct { Session `json:",inline"` Deployment common.ID `json:"deployment"` Logs string `json:"logs"` }
DeploymentGetLogsReply is reply for GetLogs query Deprecated: logs itself should be fetched over HTTP instead of over NATS, use NATS for fetching HTTP URL to the logs
func (DeploymentGetLogsReply) ToCloudEvent ¶
func (r DeploymentGetLogsReply) ToCloudEvent(source string) (cloudevents.Event, error)
ToCloudEvent converts to cloudevent
type DeploymentGetQuery ¶
DeploymentGetQuery is a query to fetch a single deployment
type DeploymentGetRawStateQuery ¶
type DeploymentGetRawStateQuery struct { Session `json:",inline"` Deployment common.ID `json:"deployment"` Run common.ID `json:"run"` }
DeploymentGetRawStateQuery is a query to fetch the most recent raw state of a deployment run
type DeploymentGetRawStateReply ¶
type DeploymentGetRawStateReply struct { Session `json:",inline"` RawState []byte `json:"raw_state"` }
DeploymentGetRawStateReply is reply for GetRawState query
func (DeploymentGetRawStateReply) ToCloudEvent ¶
func (r DeploymentGetRawStateReply) ToCloudEvent(source string) (cloudevents.Event, error)
ToCloudEvent converts to cloudevent
type DeploymentGetReply ¶
type DeploymentGetReply struct { Session `json:",inline"` Deployment Deployment `json:"deployment"` DeploymentID common.ID `json:"id"` }
DeploymentGetReply is reply to Get query
func (DeploymentGetReply) ToCloudEvent ¶
func (r DeploymentGetReply) ToCloudEvent(source string) (cloudevents.Event, error)
ToCloudEvent converts to cloudevent
type DeploymentGetRunQuery ¶
type DeploymentGetRunQuery struct { Session `json:",inline"` Deployment common.ID `json:"deployment"` Run common.ID `json:"run"` }
DeploymentGetRunQuery is a query to fetch a specific instance of deployment run
type DeploymentGetRunReply ¶
type DeploymentGetRunReply struct { Session `json:",inline"` Deployment common.ID `json:"deployment"` Run DeploymentRun `json:"run"` }
DeploymentGetRunReply is reply yo GetRun query
func (DeploymentGetRunReply) ToCloudEvent ¶
func (r DeploymentGetRunReply) ToCloudEvent(source string) (cloudevents.Event, error)
ToCloudEvent converts to cloudevent
type DeploymentList ¶
type DeploymentList interface { GetOptions() DeploymentListOption GetDeployments() []Deployment GetStart() int // index of start of current list, -1 if no results or error GetSize() int // size of the current list, 0 if nothing is found, -1 if error GetNextStart() int // index of next partition to retrieve, -1 if error is found }
DeploymentList is a list of deployment with helper for pagination.
type DeploymentListOption ¶
type DeploymentListOption struct { SortBy SortByField SortDirection SortDirection Filter DeploymentFilter // offset that the result list should begins on Offset int PageSize int // Return full run object for the CurrentRun/LastRun, if false then only the Run ID is populated for CurrentRun/LastRun FullRunObject bool `json:"full_run"` }
DeploymentListOption is option for fetching a list of deployment.
type DeploymentListQuery ¶
type DeploymentListQuery struct { Session `json:",inline"` Filters DeploymentFilter `json:"filters"` SortBy SortByField `json:"sort_by"` SortDirection SortDirection `json:"sort_dir"` Offset int `json:"offset"` // Return full run object for the CurrentRun/LastRun, if false then only the Run ID is populated for CurrentRun/LastRun FullRunObject bool `json:"full_run"` // no limit if -1. Limit int `json:"limit"` }
DeploymentListQuery is a query to fetch a list of deployments
type DeploymentListReply ¶
type DeploymentListReply struct { Session `json:",inline"` Offset int `json:"offset"` Count int `json:"count"` // Return full run object for the CurrentRun/LastRun, if false then only the Run ID is populated for CurrentRun/LastRun FullRunObject bool `json:"full_run"` Deployments []Deployment `json:"deployments"` ReplyListStream `json:",inline"` }
DeploymentListReply is reply to List query
func (DeploymentListReply) ToCloudEvent ¶
func (r DeploymentListReply) ToCloudEvent(source string) (cloudevents.Event, error)
ToCloudEvent converts to cloudevent
type DeploymentListRunQuery ¶
type DeploymentListRunQuery struct { Session `json:",inline"` Deployment common.ID `json:"deployment"` RequestPagination `json:",inline"` }
DeploymentListRunQuery is a query that fetch a list of deployment run for a specific deployment
type DeploymentListRunReply ¶
type DeploymentListRunReply struct { Session `json:",inline"` Offset int `json:"offset"` Count int `json:"count"` Runs []DeploymentRun `json:"runs"` ReplyListStream `json:",inline"` }
DeploymentListRunReply is reply to ListRun query
func (DeploymentListRunReply) ToCloudEvent ¶
func (r DeploymentListRunReply) ToCloudEvent(source string) (cloudevents.Event, error)
ToCloudEvent converts to cloudevent
type DeploymentLogsLocationQuery ¶
type DeploymentLogsLocationQuery struct { Session `json:",inline"` Deployment common.ID `json:"deployment"` TemplateType TemplateTypeName `json:"template_type"` // if Run is empty, list only logs that are specific to deployment, e.g. deletion logs Run common.ID `json:"run"` }
DeploymentLogsLocationQuery ...
type DeploymentLogsLocationReply ¶
type DeploymentLogsLocationReply struct { Session `json:",inline"` Deployment common.ID `json:"deployment"` TemplateType TemplateTypeName `json:"template_type"` Run common.ID `json:"run"` LogsLocations []LogsLocation `json:"logs_locations"` }
DeploymentLogsLocationReply ...
func (DeploymentLogsLocationReply) ToCloudEvent ¶
func (r DeploymentLogsLocationReply) ToCloudEvent(source string) (cloudevents.Event, error)
ToCloudEvent converts to cloudevent
type DeploymentParameter ¶
type DeploymentParameter struct { Name string `json:"name"` Type string `json:"type"` Value interface{} `json:"value"` }
DeploymentParameter is one instance of parameter to deployment
type DeploymentParameterUpdateRequest ¶
type DeploymentParameterUpdateRequest struct { Session `json:",inline"` Deployment common.ID `json:"id"` ParamValues DeploymentParameterValues `json:"param_values"` }
DeploymentParameterUpdateRequest is an event that request updating paramters of a deployment
type DeploymentParameterUpdateResult ¶
DeploymentParameterUpdateResult is an event that contains the result to the update parameter request
type DeploymentParameterValues ¶
type DeploymentParameterValues map[string]interface{} // map[ParamName]ParamValue
DeploymentParameterValues is the values of parameters
type DeploymentPendingStatus ¶
type DeploymentPendingStatus string
DeploymentPendingStatus is a pending status of deployment, it represents a pending transition that occurs on the deployment object.
const ( // DeploymentStatusNoPending means that the deployment has no pending transition. DeploymentStatusNoPending DeploymentPendingStatus = "none" // DeploymentStatusCreating is the pending status when a run is running. DeploymentStatusCreating DeploymentPendingStatus = "creating" // DeploymentStatusDeleting is the pending status when a deployment is deleting. DeploymentStatusDeleting DeploymentPendingStatus = "deleting" )
func (DeploymentPendingStatus) String ¶
func (ps DeploymentPendingStatus) String() string
String ...
type DeploymentResource ¶
type DeploymentResource struct { ID string `json:"id"` Type DeploymentResourceType `json:"type"` ProviderType string `json:"provider_type"` Provider common.ID `json:"provider"` Attributes map[string]interface{} `json:"attributes"` SensitiveAttributes []interface{} `json:"sensitive_attributes"` AvailableActions []DeploymentResourceAction `json:"available_actions"` }
DeploymentResource is a type of resource
type DeploymentResourceAction ¶
type DeploymentResourceAction string
DeploymentResourceAction is actions that can be performed on resource level or resource instance level
const ( // OpenWebShell ... OpenWebShell DeploymentResourceAction = "web_shell" // OpenWebDesktop ... OpenWebDesktop DeploymentResourceAction = "web_desktop" // OpenStackStartInstance ... OpenStackStartInstance DeploymentResourceAction = "start" // OpenStackShutDownInstance ... OpenStackShutDownInstance DeploymentResourceAction = "shut_down" // OpenStackShelveInstance ... OpenStackShelveInstance DeploymentResourceAction = "shelve" // OpenStackUnshelveInstance ... OpenStackUnshelveInstance DeploymentResourceAction = "unshelve" // OpenStackSuspendInstance ... OpenStackSuspendInstance DeploymentResourceAction = "suspend" // OpenStackResumeInstance ... OpenStackResumeInstance DeploymentResourceAction = "resume" )
type DeploymentResourceType ¶
type DeploymentResourceType string
DeploymentResourceType is the name of the resource type
const OpenStackInstance DeploymentResourceType = "openstack_instance"
OpenStackInstance ...
const OpenStackVolume DeploymentResourceType = "openstack_volume"
OpenStackVolume ...
type DeploymentRun ¶
type DeploymentRun struct { ID common.ID `json:"id"` Deployment common.ID `json:"deployment"` Owner string `json:"owner"` Start time.Time `json:"start"` End time.Time `json:"end"` TemplateVersion common.ID `json:"template_version"` GitURL string `json:"git_url"` CommitHash string `json:"commit"` Parameters []DeploymentParameter `json:"parameters"` // map[CredentialID]ProviderID CloudCredentials map[string]common.ID `json:"cloud_credentials"` GitCredential string `json:"git_credential"` Status string `json:"status"` StatusMsg string `json:"status_msg"` // most recent state LastState DeploymentStateView `json:"last_state"` StateUpdatedAt time.Time `json:"state_updated_at"` }
DeploymentRun is the result of running the deployment. For VM-based, it happens each time the template is run/executed/applied. Including initial creation, re-apply after parameter updates, explicit re-apply requested by user.
type DeploymentRunCreateParam ¶
type DeploymentRunCreateParam struct { Deployment common.ID `json:"deployment"` // the version of the template to use for the run, leave empty to use the latest version. TemplateVersion common.ID `json:"template_version"` ParamValues DeploymentParameterValues `json:"param_values"` }
DeploymentRunCreateParam are parameters that are needed to create a deployment run
type DeploymentRunList ¶
type DeploymentRunList interface { GetOption() DeploymentRunListOption GetRuns() []DeploymentRun GetStart() int // index of start of current list, -1 if no results or error GetSize() int // size of the current list, 0 if nothing is found, -1 if error GetNextStart() int // index of next partition to retrieve, -1 if error is found }
DeploymentRunList is an list of deployment runs with pagination helper
type DeploymentRunListOption ¶
type DeploymentRunListOption struct { Deployment common.ID // offset that the result list should begins on Offset int PageSize int }
DeploymentRunListOption is option available for fetching a list of deployment runs.
type DeploymentStartMonitoring ¶
type DeploymentStartMonitoring struct { Session `json:",inline"` // deployment ID ID common.ID `json:"id"` }
DeploymentStartMonitoring is an event that request the specified deployment to be monitored
type DeploymentStartMonitoringResult ¶
type DeploymentStartMonitoringResult struct { Session `json:",inline"` // deployment ID ID common.ID `json:"id"` }
DeploymentStartMonitoringResult is an event that contains the result to start monitoring request
type DeploymentStateRefresh ¶
DeploymentStateRefresh is an event to request a state refresh on a deployment
type DeploymentStateRefreshResult ¶
type DeploymentStateRefreshResult struct { Session `json:",inline"` ID common.ID `json:"id"` State DeploymentStateView `json:"state"` }
DeploymentStateRefreshResult an event that contains result to the state refresh request
type DeploymentStateRefreshStarted ¶
type DeploymentStateRefreshStarted struct { Session `json:",inline"` TemplateType TemplateTypeName `json:"template_type"` Deployment common.ID `json:"deployment"` // The last run for the deployment. The refreshed state will be saved into this run if successful. Run common.ID `json:"run"` }
DeploymentStateRefreshStarted is the event body for EventDeploymentStateRefreshStarted.
type DeploymentStateView ¶
type DeploymentStateView struct {
Resources []DeploymentResource `json:"resources"`
}
DeploymentStateView is a higher level view of raw state
type DeploymentStatus ¶
type DeploymentStatus string
DeploymentStatus is the status of a deployment, note that it is different from the status of a run.
const ( // DeploymentStatusNone is the initial status for deployment, when deployment has no run. DeploymentStatusNone DeploymentStatus = "none" // DeploymentStatusActive is the status for deployment that has 1+ run, and last run succeeds. DeploymentStatusActive DeploymentStatus = "active" // DeploymentStatusDeleted is the status when a deployment is deleted successfully. DeploymentStatusDeleted DeploymentStatus = "deleted" // DeploymentStatusCreationErrored is the status when a deployment's last run failed. DeploymentStatusCreationErrored DeploymentStatus = "creation_errored" // DeploymentStatusDeletionErrored is the status when the deletion failed. DeploymentStatusDeletionErrored DeploymentStatus = "deletion_errored" )
func (DeploymentStatus) AllowDeletion ¶
func (ds DeploymentStatus) AllowDeletion() bool
AllowDeletion ...
func (DeploymentStatus) AllowRunCreation ¶
func (ds DeploymentStatus) AllowRunCreation() bool
AllowRunCreation ...
func (DeploymentStatus) AvailableTransition ¶
func (ds DeploymentStatus) AvailableTransition() []DeploymentPendingStatus
AvailableTransition shows what pending status is available based on the current status. return nil if status is not valid status.
func (DeploymentStatus) ValidPendingStatus ¶
func (ds DeploymentStatus) ValidPendingStatus(pendingStatus DeploymentPendingStatus) bool
ValidPendingStatus ...
type DeploymentStopMonitoring ¶
type DeploymentStopMonitoring struct { Session `json:",inline"` // deployment ID ID common.ID `json:"id"` }
DeploymentStopMonitoring is an event that request to stop monitoring the specified deployment
type DeploymentStopMonitoringResult ¶
type DeploymentStopMonitoringResult struct { Session `json:",inline"` // deployment ID ID common.ID `json:"id"` }
DeploymentStopMonitoringResult is an event that contains the result to stop monitoring request
type DeploymentUpdateRequest ¶
type DeploymentUpdateRequest struct { Session `json:",inline"` Deployment Deployment `json:"deployment"` UpdateFields []string `json:"update_fields"` }
DeploymentUpdateRequest is an event that request updating of a deployment.
type DeploymentUpdateResult ¶
DeploymentUpdateResult is an event that contains the result to the update request
type FilterField ¶
type FilterField string
FilterField is the name of the User field to be filtered on when listing users.
const ( UsernameFilterField FilterField = "UsernameField" IsAdminFilterField FilterField = "IsAdminField" )
FilterField constants
type GitTemplateSource ¶
type GitTemplateSource struct { URI string `json:"uri"` AccessParameters GitTemplateSourceAccessParameters `json:"access_parameters"` Visibility TemplateSourceVisibility `json:"source_visibility"` }
GitTemplateSource is a convenience type for access the AccessParameters of TemplateSource. This offers better type safety than accessing the map[string]interface{} directly.
type GitTemplateSourceAccessParameters ¶
type GitTemplateSourceAccessParameters struct { Branch string `json:"branch" mapstructure:"branch"` Tag string `json:"tag" mapstructure:"tag"` Path string `json:"path" mapstructure:"path"` Commit string `json:"commit" mapstructure:"commit"` }
GitTemplateSourceAccessParameters ...
type InteractiveSessionClient ¶
type InteractiveSessionClient interface { Get(ctx context.Context, actor Actor, interactiveSessionID common.ID) (*InteractiveSessionModel, error) GetByInstanceID(ctx context.Context, actor Actor, instanceID string) (*InteractiveSessionModel, error) GetByInstanceAddress(ctx context.Context, actor Actor, instanceAddress string) (*InteractiveSessionModel, error) List(ctx context.Context, actor Actor) ([]InteractiveSessionModel, error) CheckPrerequisites(ctx context.Context, actor Actor, protocol InteractiveSessionProtocol, instanceAddress string, instanceAdminUsername string) (bool, error) Create(ctx context.Context, actor Actor, interactiveSession InteractiveSessionModel) (common.ID, error) Deactivate(ctx context.Context, actor Actor, interactiveSessionID common.ID) error }
InteractiveSessionClient is the client for InteractiveSession The ISMS Client contains three methods: Create, List and Check.
Get: Is used to get an interactive session stored in the database. GetByInstanceID: Is used to get an interactive session stored in the database by instance ID. GetByInstanceAddress: Is used to get an interactive session stored in the database by instance address. ListAll: Is used to list all interactive sessions stored in the database. List: Is used to list all active/creating interactive sessions. CheckPrerequisites: Is used to check if the given interactive session can be created. Please provide the following fields when checking: InstanceAddress // IP Address of the instance (String) InstanceAdminUsername // Admin username of the instance (string) Protocol // Either SSH or VNC (String) Create: Is used to create and interactive session. Please provide the following fields when creating a session: InstanceID // (String) InstanceAddress // IP Address of the instance (String) InstanceAdminUsername // Admin username of the instance (string) Protocol // Either SSH or VNC (String) CloudID // Identifier of the cloud where the instance is hosted. (String) Deactivate: Is used to change the state of an interactive session to inactive.
func NewNatsInteractiveSessionClientFromConn ¶
func NewNatsInteractiveSessionClientFromConn(queryConn messaging2.QueryConnection, eventConn messaging2.EventConnection) (InteractiveSessionClient, error)
NewNatsInteractiveSessionClientFromConn creates a new client from existing Connections.
Note if you only need query functionality, then only supply queryConn, same for event functionality and eventConn.
type InteractiveSessionListModel ¶
type InteractiveSessionListModel struct { Session InteractiveSessions []InteractiveSessionModel `json:"interactive_sessions"` }
InteractiveSessionListModel is the InteractiveSession list model
type InteractiveSessionModel ¶
type InteractiveSessionModel struct { Session ID common.ID `json:"id"` Owner string `json:"owner"` InstanceID string `json:"instance_id"` InstanceAddress string `json:"instance_address"` InstanceAdminUsername string `json:"instance_admin_username"` CloudID string `json:"cloud_id"` Protocol InteractiveSessionProtocol `json:"protocol"` RedirectURL string `json:"redirect_url"` State InteractiveSessionState `json:"state"` CreatedAt time.Time `json:"created_at"` UpdatedAt time.Time `json:"updated_at"` }
InteractiveSessionModel is the InteractiveSession model The proper model for the ISMS. Containing all needed fields both incoming and outgoing.
InstanceID: ID of the instance to connect to. InstanceAddress: IP-Address of the instance to connect to. InstanceAdminUsername: Admin username in the instance to login CloudID: ID of the cloud to connect to. Protocol: Protocol of the session RedirectURL: Contains the URL containing both IP+Encrypted Key returned by the ISMS. Used to redirect the user to a Guacamole Lite server. State: state of the interactive session
func (*InteractiveSessionModel) GetPrimaryID ¶
func (i *InteractiveSessionModel) GetPrimaryID() common.ID
GetPrimaryID returns the primary ID of the InteractiveSession
type InteractiveSessionProtocol ¶
type InteractiveSessionProtocol string
InteractiveSessionProtocol is the protocol of an interactive session
const ( // InteractiveSessionProtocolUnknown is for an unknown interactive session protocol InteractiveSessionProtocolUnknown InteractiveSessionProtocol = "" // InteractiveSessionProtocolSSH is for a SSH interactive session protocol InteractiveSessionProtocolSSH InteractiveSessionProtocol = "ssh" // InteractiveSessionProtocolVNC is for a VNC interactive session protocol InteractiveSessionProtocolVNC InteractiveSessionProtocol = "vnc" )
func (InteractiveSessionProtocol) MarshalJSON ¶
func (p InteractiveSessionProtocol) MarshalJSON() ([]byte, error)
MarshalJSON returns the JSON representation of a InteractiveSessionProtocol.
func (InteractiveSessionProtocol) String ¶
func (p InteractiveSessionProtocol) String() string
String returns the string representation of a InteractiveSessionProtocol.
func (*InteractiveSessionProtocol) UnmarshalJSON ¶
func (p *InteractiveSessionProtocol) UnmarshalJSON(b []byte) error
UnmarshalJSON converts the JSON representation of a InteractiveSessionProtocol to the appropriate enumeration constant.
type InteractiveSessionState ¶
type InteractiveSessionState string
InteractiveSessionState is the state of an interactive session
const ( // InteractiveSessionStateUnknown is for the unknown interactive session InteractiveSessionStateUnknown InteractiveSessionState = "" // InteractiveSessionStateCreating is for the interactive session in creation InteractiveSessionStateCreating InteractiveSessionState = "creating" // InteractiveSessionStateFailed is for the interactive session failed in creation InteractiveSessionStateFailed InteractiveSessionState = "failed" // InteractiveSessionStateActive is for the active interactive session InteractiveSessionStateActive InteractiveSessionState = "active" // InteractiveSessionStateInactive is for the inactive interactive session InteractiveSessionStateInactive InteractiveSessionState = "inactive" )
func (InteractiveSessionState) MarshalJSON ¶
func (p InteractiveSessionState) MarshalJSON() ([]byte, error)
MarshalJSON returns the JSON representation of a InteractiveSessionState.
func (InteractiveSessionState) String ¶
func (p InteractiveSessionState) String() string
String returns the string representation of a InteractiveSessionState.
func (*InteractiveSessionState) UnmarshalJSON ¶
func (p *InteractiveSessionState) UnmarshalJSON(b []byte) error
UnmarshalJSON converts the JSON representation of a InteractiveSessionState to the appropriate enumeration constant.
type JS2Allocation ¶
type JS2Allocation struct { ID string `json:"id"` Start time.Time `json:"start"` End time.Time `json:"end"` ProjectCode string `json:"project_code"` Resource string `json:"resource"` ComputeAllocated float64 `json:"compute_allocated"` ComputeUsed float64 `json:"compute_used"` StorageAllocated float64 `json:"storage_allocated"` }
JS2Allocation is a struct for JetStream Allocation information
type JS2AllocationClient ¶
type JS2AllocationClient interface { // Deprecated: new js2allocation service no longer support this GetUser(ctx context.Context, actor Actor, nocache bool) (*JS2UserModel, error) List(ctx context.Context, actor Actor, nocache bool) ([]JS2ProjectModel, error) }
JS2AllocationClient is the client for JS2Allocation
func NewNatsJS2AllocationClientFromConn ¶
func NewNatsJS2AllocationClientFromConn(queryConn messaging2.QueryConnection, eventConn messaging2.EventConnection) (JS2AllocationClient, error)
NewNatsJS2AllocationClientFromConn creates a new client from existing Connections.
type JS2PI ¶
type JS2PI struct { Username string `json:"username"` FirstName string `json:"firstname"` LastName string `json:"lastname"` }
JS2PI is a struct for JetStream PI information
type JS2ProjectListModel ¶
type JS2ProjectListModel struct { Session Projects []JS2ProjectModel `json:"projects"` NoCache bool `json:"nocache"` }
JS2ProjectListModel is the JS2 Project list model
type JS2ProjectModel ¶
type JS2ProjectModel struct { Session ID common.ID `json:"id"` Owner string `json:"owner"` Title string `json:"title"` Description string `json:"description,omitempty"` PI JS2PI `json:"pi"` Allocations []JS2Allocation `json:"allocations"` RetrievedAt time.Time `json:"retrieved_at"` }
JS2ProjectModel is the JS2 Project model
func (*JS2ProjectModel) GetPrimaryID ¶
func (p *JS2ProjectModel) GetPrimaryID() common.ID
GetPrimaryID returns the primary ID of the JS2 Project
type JS2UserModel ¶
type JS2UserModel struct { Session Owner string `json:"owner"` TACCUsername string `json:"tacc_username"` RetrievedAt time.Time `json:"retrieved_at"` NoCache bool `json:"nocache"` }
JS2UserModel is the JS2 User model
func (*JS2UserModel) GetPrimaryID ¶
func (u *JS2UserModel) GetPrimaryID() string
GetPrimaryID returns the primary ID of the JS2 User
type LogsLocation ¶
type LogsLocation struct { DeploymentStatus DeploymentStatus `json:"deployment_status"` RunStatus string `json:"run_status"` LogsID string `json:"logs_id"` LogsURL string `json:"logs_url"` AuthHeader string `json:"auth_header"` }
LogsLocation describe the location to download the deployment/run logs.
Run logs will have RunStatus != "" and DeploymentStatus == "". Deployment logs will have RunStatus == "" and , DeploymentStatus != "".
Currently, there is only deletion logs for deployment, so DeploymentStatus will either be "" or "deleted".
func (LogsLocation) IsDeploymentDeletionLogs ¶
func (l LogsLocation) IsDeploymentDeletionLogs() bool
IsDeploymentDeletionLogs ...
func (LogsLocation) IsDeploymentLogs ¶
func (l LogsLocation) IsDeploymentLogs() bool
IsDeploymentLogs ...
func (LogsLocation) IsRunExecutionLogs ¶
func (l LogsLocation) IsRunExecutionLogs() bool
IsRunExecutionLogs returns true if logs is when deployment is in execution stage.
func (LogsLocation) IsRunPreflightLogs ¶
func (l LogsLocation) IsRunPreflightLogs() bool
IsRunPreflightLogs returns true if logs is when deployment is in pre-flight stage.
type OpenStackCredential ¶
type OpenStackCredential struct { IdentityAPIVersion string `json:"OS_IDENTITY_API_VERSION" mapstructure:"OS_IDENTITY_API_VERSION"` RegionName string `json:"OS_REGION_NAME" mapstructure:"OS_REGION_NAME"` Interface string `json:"OS_INTERFACE" mapstructure:"OS_INTERFACE"` AuthURL string `json:"OS_AUTH_URL" mapstructure:"OS_AUTH_URL"` ProjectDomainID string `json:"OS_PROJECT_DOMAIN_ID" mapstructure:"OS_PROJECT_DOMAIN_ID"` ProjectDomainName string `json:"OS_PROJECT_DOMAIN_NAME" mapstructure:"OS_PROJECT_DOMAIN_NAME"` ProjectID string `json:"OS_PROJECT_ID" mapstructure:"OS_PROJECT_ID"` ProjectName string `json:"OS_PROJECT_NAME" mapstructure:"OS_PROJECT_NAME"` UserDomainName string `json:"OS_USER_DOMAIN_NAME" mapstructure:"OS_USER_DOMAIN_NAME"` Username string `json:"OS_USERNAME" mapstructure:"OS_USERNAME"` Password string `json:"OS_PASSWORD" mapstructure:"OS_PASSWORD"` AuthType string `json:"OS_AUTH_TYPE" mapstructure:"OS_AUTH_TYPE"` AppCredID string `json:"OS_APPLICATION_CREDENTIAL_ID" mapstructure:"OS_APPLICATION_CREDENTIAL_ID"` AppCredName string `json:"OS_APPLICATION_CREDENTIAL_NAME" mapstructure:"OS_APPLICATION_CREDENTIAL_NAME"` AppCredSecret string `json:"OS_APPLICATION_CREDENTIAL_SECRET" mapstructure:"OS_APPLICATION_CREDENTIAL_SECRET"` }
OpenStackCredential is credential for OpenStack. This include both username/password and Application Credential.
type OpenStackInstanceAttributes ¶
type OpenStackInstanceAttributes struct { ID uuid.UUID `json:"id"` // FIXME rebundant field? There is already ID field in DeploymentResource Name string `json:"name"` FloatingIP net.IP `json:"floating_ip"` Image string `json:"image"` ImageID uuid.UUID `json:"image_id"` Flavor string `json:"flavor"` FlavorID uuid.UUID `json:"flavor_id"` Status string `json:"status"` Volumes []uuid.UUID `json:"volumes,omitempty"` }
OpenStackInstanceAttributes corresponds to the Attributes in DeploymentResourceInstance
type OpenStackVolumeAttributes ¶
type OpenStackVolumeAttributes struct { ID uuid.UUID `json:"id"` // FIXME rebundant field? Name string `json:"name"` Size uint64 `json:"size"` }
OpenStackVolumeAttributes corresponds to the Attributes in DeploymentResourceInstance
type ProviderClient ¶
type ProviderClient interface { Get(ctx context.Context, actor Actor, id common.ID) (*ProviderModel, error) List(ctx context.Context, actor Actor) ([]ProviderModel, error) Create(ctx context.Context, actor Actor, provider ProviderModel) (common.ID, common.TransactionID, error) Delete(ctx context.Context, actor Actor, id common.ID) (common.TransactionID, error) Update(ctx context.Context, actor Actor, provider ProviderModel) (common.TransactionID, error) }
ProviderClient is the client for provider metadata service
func NewNatsProviderClientFromConn ¶
func NewNatsProviderClientFromConn(queryConn messaging2.QueryConnection, eventConn messaging2.EventConnection) (ProviderClient, error)
NewNatsProviderClientFromConn creates a new client from existing connections.
Note, if you only need query functionality, then only supply queryConn, same for event functionality and eventConn.
type ProviderListModel ¶
type ProviderListModel struct { Session List []ProviderModel `json:"list"` }
ProviderListModel ...
type ProviderModel ¶
type ProviderModel struct { ID common.ID `json:"id" bson:"_id"` Name string `json:"name" bson:"name"` Type ProviderType `json:"type" bson:"type"` URL string `json:"url" bson:"url"` Owner string `json:"owner"` Public bool `json:"public"` CreatedAt time.Time `json:"created_at,omitempty" bson:"created_at"` UpdatedAt time.Time `json:"updated_at,omitempty" bson:"updated_at"` Metadata map[string]interface{} `json:"metadata,omitempty" bson:"metadata"` }
ProviderModel represents a provider
type ProviderRequest ¶
type ProviderRequest struct { Session ProviderModel }
ProviderRequest is the request object used for operations (get/list/create/update/delete), this is the struct that is being embedded into data field of cloudevent.
type ProviderResponse ¶
type ProviderResponse ProviderRequest
ProviderResponse is the response/reply struct for operations like get/create/update/delete.
type ProviderType ¶
type ProviderType string
ProviderType is the type of provider
const ( OpenStackProviderType ProviderType = "openstack" AWSProviderType ProviderType = "aws" )
ProviderType constants
type ReplyListStream ¶
type ReplyListStream struct { // total number of replies, at least 1 TotalReplies int `json:"total_reply"` // index of the reply, start at 0 ReplyIndex int `json:"reply_index"` }
ReplyListStream contains fields needed for streaming a list of objects in multiple replies
type RequestPagination ¶
type RequestPagination struct { // offset that a page begins on Offset int `json:"offset"` // limit of page size, -1 for unlimited page size PageSizeLimit int `json:"limit"` }
RequestPagination contains fields needed to request pagination in the list result
type Session ¶
type Session struct { SessionActor string `json:"actor"` SessionEmulator string `json:"emulator,omitempty"` // Deprecated: use ServiceError instead ErrorType string `json:"error_type,omitempty"` // the type of error // Deprecated: use ServiceError instead ErrorMessage string `json:"error_message,omitempty"` // custom or contextual error message ServiceError CacaoErrorBase `json:"service_error,omitempty"` // Ultimately, this will replace ErrorType and ErrorMessage fields above. }
Session implements SessionContext. ErrorType & ErrorMessage fields are the old way of passing error, there is only a few service that still uses it to signal error. We will migrate everything to using ServiceError.
func CopySessionActors ¶
CopySessionActors copies over the actor and emulator in Session. This is useful when copying actors from request to response.
func (Session) GetError ¶
GetError returns error type & msg. Note this is the old way of passing error from service to client. Deprecated: use GetServiceError instead.
func (Session) GetServiceError ¶
func (b Session) GetServiceError() CacaoError
GetServiceError returns the service error (which implements built-in error interface). This is the newer way to passing error from service to client.
func (Session) GetSessionEmulator ¶
GetSessionEmulator ...
func (*Session) SetSessionEmulator ¶
SetSessionEmulator ...
type SessionContext ¶
type SessionContext interface { GetSessionActor() string // username of the person making requests GetSessionEmulator() string // set if the Actor's is being emulated by another user, presumably an admin SetSessionActor(string) SetSessionEmulator(string) GetError() (string, string) // gets the error type and message GetServiceError() CacaoError }
SessionContext is the base interface for objects for microservices, it enables actor, emulator and error information to be passed around between service and its client as part of the object.
type SortByField ¶
type SortByField string
SortByField is the field to sort the results by
const ( SortByID SortByField = "id" SortByWorkspace SortByField = "workspace" SortByTemplate SortByField = "template" SortByPrimaryCloud SortByField = "primary_cloud" SortByStatus SortByField = "status" SortByStateUpdatedAt SortByField = "state_updated_at" )
Fields to sort by
type SortDirection ¶
type SortDirection int
SortDirection is the sort direction in the list result, this is used for deployment list and user list(to be implemented)
const ( AscendingSort SortDirection = 1 // This should be the default if omitted DescendingSort SortDirection = -1 )
SortDirection constants
type StanDependencyMediatorClient ¶
type StanDependencyMediatorClient struct {
// contains filtered or unexported fields
}
StanDependencyMediatorClient is an implementation of DependencyMediatorClient over STAN
func (StanDependencyMediatorClient) DeleteCredential ¶
func (dm StanDependencyMediatorClient) DeleteCredential(ctx context.Context, session Session, credID string) (DepCheckDeletionResult, error)
DeleteCredential attempts to delete a credential while ensuring the dependency integrity. Deletion will not succeed if there is any other objects (deployments, templates) that depends on this credential.
func (StanDependencyMediatorClient) DeleteProvider ¶
func (dm StanDependencyMediatorClient) DeleteProvider(ctx context.Context, session Session, provider common.ID) (DepCheckDeletionResult, error)
DeleteProvider attempts to delete a provider while ensuring the dependency integrity. FIXME provider currently will mostly likely always has deployments depend on it. But there is no way to check if deployments of other user(not the owner/creator of the provider) are using the provider, so it is not possible to do a thorough check on dependents.
func (StanDependencyMediatorClient) DeleteTemplate ¶
func (dm StanDependencyMediatorClient) DeleteTemplate(ctx context.Context, session Session, template common.ID) (DepCheckDeletionResult, error)
DeleteTemplate attempts to delete a template while ensuring the dependency integrity. Deletion will not succeed if there is any other objects (deployments, providers) that depends on this template.
func (StanDependencyMediatorClient) DeleteWorkspace ¶
func (dm StanDependencyMediatorClient) DeleteWorkspace(ctx context.Context, session Session, workspace common.ID) (DepCheckDeletionResult, error)
DeleteWorkspace attempts to delete a workspace while ensuring the dependency integrity. Deletion will not succeed if there is any other objects (deployments) that depends on this template.
type Template ¶
type Template interface { SessionContext GetPrimaryID() common.ID // points to ID GetID() common.ID GetOwner() string GetName() string GetDescription() string IsPublic() bool IsDeleted() bool GetSource() TemplateSource GetMetadata() TemplateMetadata GetUIMetadata() TemplateUIMetadata GetCreatedAt() time.Time GetUpdatedAt() time.Time GetUpdateFieldNames() []string GetCredentialID() string GetIncludeCacaoReservedPurposes() bool GetLatestVersionID() common.ID SetPrimaryID(id common.ID) SetID(id common.ID) SetName(name string) SetDescription(description string) SetPublic(isPublic bool) SetSource(source TemplateSource) SetUpdateFieldNames(fieldNames []string) SetCredentialID(credentialID string) SetIncludeCacaoReservedPurposes(include bool) }
Template is the standard interface for all Template implementations
type TemplateCacaoTask ¶
type TemplateCacaoTask struct { Type TemplateCacaoTaskType `json:"type,omitempty"` Location string `json:"location,omitempty"` ExecuteOn TemplateCacaoTaskExecuteOn `json:"execute_on,omitempty"` Arguments []string `json:"args,omitempty"` EnvironmentVariables []TemplateCacaoTaskKeyVal `json:"env,omitempty"` RunAction TemplateCacaoTaskRunAction `json:"run_action,omitempty"` RunParams []TemplateCacaoTaskKeyVal `json:"run_params,omitempty"` }
TemplateCacaoTask is a struct for a pre/post task in metadata
type TemplateCacaoTaskExecuteOn ¶
type TemplateCacaoTaskExecuteOn struct { Type TemplateCacaoTaskExecuteOnType NodeID int // only used when Type is 'TemplateCacaoTaskExecuteOnTypeParticular' }
TemplateCacaoTaskExecuteOn indicates where a task to perform.
func (TemplateCacaoTaskExecuteOn) MarshalBSONValue ¶
func (t TemplateCacaoTaskExecuteOn) MarshalBSONValue() (bsontype.Type, []byte, error)
MarshalBSONValue returns the BSON representation of a TemplateCacaoTaskExecuteOn.
func (TemplateCacaoTaskExecuteOn) MarshalJSON ¶
func (t TemplateCacaoTaskExecuteOn) MarshalJSON() ([]byte, error)
MarshalJSON returns the JSON representation of a TemplateCacaoTaskExecuteOn.
func (TemplateCacaoTaskExecuteOn) String ¶
func (t TemplateCacaoTaskExecuteOn) String() string
String returns the string representation of a TemplateCacaoTaskExecuteOn.
func (*TemplateCacaoTaskExecuteOn) UnmarshalBSONValue ¶
func (t *TemplateCacaoTaskExecuteOn) UnmarshalBSONValue(bt bsontype.Type, b []byte) error
UnmarshalBSONValue converts the BSON representation of a TemplateCacaoTaskExecuteOn to the appropriate enumeration constant.
func (*TemplateCacaoTaskExecuteOn) UnmarshalJSON ¶
func (t *TemplateCacaoTaskExecuteOn) UnmarshalJSON(b []byte) error
UnmarshalJSON converts the JSON representation of a TemplateCacaoTaskExecuteOn to the appropriate enumeration constant.
type TemplateCacaoTaskExecuteOnType ¶
type TemplateCacaoTaskExecuteOnType string
TemplateCacaoTaskExecuteOnType indicates where a task to perform.
const ( // TemplateCacaoTaskExecuteOnTypeUnknown indicates that the type of the task execution is unspecified. TemplateCacaoTaskExecuteOnTypeUnknown TemplateCacaoTaskExecuteOnType = "" // TemplateCacaoTaskExecuteOnTypeAll indicates that the task will be performed on all instances TemplateCacaoTaskExecuteOnTypeAll TemplateCacaoTaskExecuteOnType = "all" // TemplateCacaoTaskExecuteOnTypeAllButFirst indicates that the task will be performed on all but the first instance TemplateCacaoTaskExecuteOnTypeAllButFirst TemplateCacaoTaskExecuteOnType = "all_but_first" // TemplateCacaoTaskExecuteOnTypeParticular indicates that the task will be performed on a particular instance TemplateCacaoTaskExecuteOnTypeParticular TemplateCacaoTaskExecuteOnType = "particular" )
Enumeration constants for TemplateCacaoTaskExecuteOnType.
type TemplateCacaoTaskKeyVal ¶
type TemplateCacaoTaskKeyVal struct { Key string `json:"key,omitempty"` Value string `json:"value,omitempty"` }
TemplateCacaoTaskKeyVal is a struct for representing key-value formatted values.
func (*TemplateCacaoTaskKeyVal) UnmarshalJSON ¶
func (t *TemplateCacaoTaskKeyVal) UnmarshalJSON(b []byte) error
UnmarshalJSON converts the JSON representation of a TemplateCacaoTaskKeyVal to the object form.
type TemplateCacaoTaskRunAction ¶
type TemplateCacaoTaskRunAction string
TemplateCacaoTaskRunAction indicates what to do when the task type is `run_deployment_action`.
const ( // TemplateCacaoTaskRunActionUnknown indicates that the run action of the task is unspecified. TemplateCacaoTaskRunActionUnknown TemplateCacaoTaskRunAction = "" // TemplateCacaoTaskRunActionRunDelete indicates that it deletes run at the step. TemplateCacaoTaskRunActionRunDelete TemplateCacaoTaskRunAction = "run_delete" // TemplateCacaoTaskRunActionRunParamUpdate indicates that it updates parameters of a run at the step. TemplateCacaoTaskRunActionRunParamUpdate TemplateCacaoTaskRunAction = "run_param_update" )
Enumeration constants for TemplateCacaoTaskRunAction.
func (TemplateCacaoTaskRunAction) MarshalJSON ¶
func (t TemplateCacaoTaskRunAction) MarshalJSON() ([]byte, error)
MarshalJSON returns the JSON representation of a TemplateCacaoTaskRunAction.
func (TemplateCacaoTaskRunAction) String ¶
func (t TemplateCacaoTaskRunAction) String() string
String returns the string representation of a TemplateCacaoTaskRunAction.
func (*TemplateCacaoTaskRunAction) UnmarshalJSON ¶
func (t *TemplateCacaoTaskRunAction) UnmarshalJSON(b []byte) error
UnmarshalJSON converts the JSON representation of a TemplateCacaoTaskRunAction to the appropriate enumeration constant.
type TemplateCacaoTaskType ¶
type TemplateCacaoTaskType string
TemplateCacaoTaskType indicates the type of a task to perform. For example, if the task is to run an ansible script then the type would be `ansible`.
const ( // TemplateCacaoTaskTypeUnknown indicates that the type of the task is unspecified. TemplateCacaoTaskTypeUnknown TemplateCacaoTaskType = "" // TemplateCacaoTaskTypeCacaoAtmosphereLegacy indicates that the task is used to run a command via atmosphere TemplateCacaoTaskTypeCacaoAtmosphereLegacy TemplateCacaoTaskType = "cacao_atmosphere_legacy" // TemplateCacaoTaskTypeAnsible indicates that the task is used to run a command via ansible TemplateCacaoTaskTypeAnsible TemplateCacaoTaskType = "ansible" // TemplateCacaoTaskTypeScriptRemote indicates that the task is used to run a command via a remote script TemplateCacaoTaskTypeScriptRemote TemplateCacaoTaskType = "script_remote" // TemplateCacaoTaskTypeScriptLocal indicates that the task is used to run a command via a local script TemplateCacaoTaskTypeScriptLocal TemplateCacaoTaskType = "script_local" // TemplateCacaoTaskTypeDocker indicates that the task is used to run a docker instance TemplateCacaoTaskTypeDocker TemplateCacaoTaskType = "docker" // TemplateCacaoTaskTypeDeploymentRunAction indicates that the task is used to run a deployment run action TemplateCacaoTaskTypeDeploymentRunAction TemplateCacaoTaskType = "deployment_run_action" )
Enumeration constants for TemplateCacaoTaskType.
func (TemplateCacaoTaskType) MarshalJSON ¶
func (t TemplateCacaoTaskType) MarshalJSON() ([]byte, error)
MarshalJSON returns the JSON representation of a TemplateCacaoTaskType.
func (TemplateCacaoTaskType) String ¶
func (t TemplateCacaoTaskType) String() string
String returns the string representation of a TemplateCacaoTaskType.
func (*TemplateCacaoTaskType) UnmarshalJSON ¶
func (t *TemplateCacaoTaskType) UnmarshalJSON(b []byte) error
UnmarshalJSON converts the JSON representation of a TemplateCacaoTaskType to the appropriate enumeration constant.
type TemplateClient ¶
type TemplateClient interface { // Source Types ListSourceTypes(ctx context.Context, actor Actor) ([]TemplateSourceType, error) // Types GetType(ctx context.Context, actor Actor, templateTypeName TemplateTypeName) (TemplateType, error) ListTypes(ctx context.Context, actor Actor) ([]TemplateType, error) ListTypesForProviderType(ctx context.Context, actor Actor, providerType TemplateProviderType) ([]TemplateType, error) CreateType(ctx context.Context, actor Actor, templateType TemplateType) error UpdateType(ctx context.Context, actor Actor, templateType TemplateType) error UpdateTypeFields(ctx context.Context, actor Actor, templateType TemplateType, updateFieldNames []string) error DeleteType(ctx context.Context, actor Actor, templateTypeName TemplateTypeName) error // Custom Field Type ListCustomFieldTypes(ctx context.Context, actor Actor) ([]TemplateCustomFieldType, error) GetCustomFieldType(ctx context.Context, actor Actor, customFieldTypeName string) (TemplateCustomFieldType, error) QueryCustomFieldType(ctx context.Context, actor Actor, customFieldTypeName string, queryParams map[string]string) (TemplateCustomFieldTypeQueryResult, error) CreateCustomFieldType(ctx context.Context, actor Actor, customFieldType TemplateCustomFieldType) error UpdateCustomFieldType(ctx context.Context, actor Actor, customFieldType TemplateCustomFieldType) error UpdateCustomFieldTypeFields(ctx context.Context, actor Actor, customFieldType TemplateCustomFieldType, updateFieldNames []string) error DeleteCustomFieldType(ctx context.Context, actor Actor, customFieldTypeName string) error // Template List(ctx context.Context, actor Actor, includeCacaoReservedPurposes bool) ([]Template, error) Get(ctx context.Context, actor Actor, templateID common.ID) (Template, error) Import(ctx context.Context, actor Actor, template Template, credentialID string) (common.ID, error) Update(ctx context.Context, actor Actor, template Template) error UpdateFields(ctx context.Context, actor Actor, template Template, updateFieldNames []string) error Sync(ctx context.Context, actor Actor, templateID common.ID, credentialID string) error Delete(ctx context.Context, actor Actor, templateID common.ID) error // TemplateVersion ListTemplateVersions(ctx context.Context, actor Actor, templateID common.ID) ([]TemplateVersion, error) GetTemplateVersion(ctx context.Context, actor Actor, versionID common.ID) (*TemplateVersion, error) DisableTemplateVersion(ctx context.Context, actor Actor, versionID common.ID) error }
TemplateClient is the client for Template
func NewNatsTemplateClientFromConn ¶
func NewNatsTemplateClientFromConn(queryConn messaging2.QueryConnection, eventConn messaging2.EventConnection) (TemplateClient, error)
NewNatsTemplateClientFromConn creates a new client from existing connections.
Note, if you only need query functionality, then only supply queryConn, same for event functionality and eventConn.
type TemplateCustomFieldType ¶
type TemplateCustomFieldType interface { SessionContext GetPrimaryID() string // points to Name GetName() string GetDescription() string GetQueryMethod() TemplateCustomFieldTypeQueryMethod GetQueryTarget() string GetQueryData() string GetQueryResultJSONPathFilter() string GetUpdateFieldNames() []string SetPrimaryID(name string) SetName(name string) SetDescription(description string) SetQueryMethod(method TemplateCustomFieldTypeQueryMethod) SetQueryTarget(target string) SetQueryData(data string) SetQueryResultJSONPathFilter(jsonpath string) SetUpdateFieldNames(fieldNames []string) }
TemplateCustomFieldType is the standard interface for all Template Custom Field Type implementations
type TemplateCustomFieldTypeListItemModel ¶
type TemplateCustomFieldTypeListItemModel struct { Name string `json:"name"` Description string `json:"description,omitempty"` QueryMethod TemplateCustomFieldTypeQueryMethod `json:"query_method"` QueryTarget string `json:"query_target"` QueryData string `json:"query_data,omitempty"` QueryResultJSONPathFilter string `json:"query_result_jsonpath_filter,omitempty"` }
TemplateCustomFieldTypeListItemModel is the element type in TemplateCustomFieldTypeModel
type TemplateCustomFieldTypeListModel ¶
type TemplateCustomFieldTypeListModel struct { Session TemplateCustomFieldTypes []TemplateCustomFieldTypeListItemModel `json:"template_custom_field_types"` }
TemplateCustomFieldTypeListModel is the Template Custom Field Type list model
func (*TemplateCustomFieldTypeListModel) GetTemplateCustomFieldTypes ¶
func (t *TemplateCustomFieldTypeListModel) GetTemplateCustomFieldTypes() []TemplateCustomFieldType
GetTemplateCustomFieldTypes returns template custom field types
type TemplateCustomFieldTypeModel ¶
type TemplateCustomFieldTypeModel struct { Session Name string `json:"name"` Description string `json:"description,omitempty"` QueryMethod TemplateCustomFieldTypeQueryMethod `json:"query_method"` QueryTarget string `json:"query_target"` QueryData string `json:"query_data,omitempty"` QueryResultJSONPathFilter string `json:"query_result_jsonpath_filter,omitempty"` UpdateFieldNames []string `json:"update_field_names,omitempty"` QueryParams map[string]string `json:"query_params,omitempty"` }
TemplateCustomFieldTypeModel is the Template Custom Field Type model
func (*TemplateCustomFieldTypeModel) GetDescription ¶
func (t *TemplateCustomFieldTypeModel) GetDescription() string
GetDescription returns the description of the Template Custom Field Type
func (*TemplateCustomFieldTypeModel) GetName ¶
func (t *TemplateCustomFieldTypeModel) GetName() string
GetName returns the name of the Template Custom Field Type
func (*TemplateCustomFieldTypeModel) GetPrimaryID ¶
func (t *TemplateCustomFieldTypeModel) GetPrimaryID() string
GetPrimaryID returns the primary ID of the Template Custom Field Type
func (*TemplateCustomFieldTypeModel) GetQueryData ¶
func (t *TemplateCustomFieldTypeModel) GetQueryData() string
GetQueryData returns the query data of the Template Custom Field Type
func (*TemplateCustomFieldTypeModel) GetQueryMethod ¶
func (t *TemplateCustomFieldTypeModel) GetQueryMethod() TemplateCustomFieldTypeQueryMethod
GetQueryMethod returns the query method of the Template Custom Field Type
func (*TemplateCustomFieldTypeModel) GetQueryParams ¶
func (t *TemplateCustomFieldTypeModel) GetQueryParams() map[string]string
GetQueryParams returns the query params for query API
func (*TemplateCustomFieldTypeModel) GetQueryResultJSONPathFilter ¶
func (t *TemplateCustomFieldTypeModel) GetQueryResultJSONPathFilter() string
GetQueryResultJSONPathFilter returns the JSONPath filter that filters query result data
func (*TemplateCustomFieldTypeModel) GetQueryTarget ¶
func (t *TemplateCustomFieldTypeModel) GetQueryTarget() string
GetQueryTarget returns the query target of the Template Custom Field Type
func (*TemplateCustomFieldTypeModel) GetUpdateFieldNames ¶
func (t *TemplateCustomFieldTypeModel) GetUpdateFieldNames() []string
GetUpdateFieldNames returns the field names to be updated
func (*TemplateCustomFieldTypeModel) SetDescription ¶
func (t *TemplateCustomFieldTypeModel) SetDescription(description string)
SetDescription sets the description of the Template Custom Field Type
func (*TemplateCustomFieldTypeModel) SetName ¶
func (t *TemplateCustomFieldTypeModel) SetName(name string)
SetName sets the name of the Template Custom Field Type
func (*TemplateCustomFieldTypeModel) SetPrimaryID ¶
func (t *TemplateCustomFieldTypeModel) SetPrimaryID(name string)
SetPrimaryID sets the primary ID of the Template Custom Field Type
func (*TemplateCustomFieldTypeModel) SetQueryData ¶
func (t *TemplateCustomFieldTypeModel) SetQueryData(data string)
SetQueryData sets the data of the Template Custom Field Type
func (*TemplateCustomFieldTypeModel) SetQueryMethod ¶
func (t *TemplateCustomFieldTypeModel) SetQueryMethod(queryMethod TemplateCustomFieldTypeQueryMethod)
SetQueryMethod sets the query method of the Template Custom Field Type data
func (*TemplateCustomFieldTypeModel) SetQueryParams ¶
func (t *TemplateCustomFieldTypeModel) SetQueryParams(queryParams map[string]string)
SetQueryParams sets the query params
func (*TemplateCustomFieldTypeModel) SetQueryResultJSONPathFilter ¶
func (t *TemplateCustomFieldTypeModel) SetQueryResultJSONPathFilter(jsonpath string)
SetQueryResultJSONPathFilter sets the JSONPath filter that filters query result data
func (*TemplateCustomFieldTypeModel) SetQueryTarget ¶
func (t *TemplateCustomFieldTypeModel) SetQueryTarget(target string)
SetQueryTarget sets the query target of the Template Custom Field Type
func (*TemplateCustomFieldTypeModel) SetUpdateFieldNames ¶
func (t *TemplateCustomFieldTypeModel) SetUpdateFieldNames(fieldNames []string)
SetUpdateFieldNames sets the field names to be updated
type TemplateCustomFieldTypeQueryMethod ¶
type TemplateCustomFieldTypeQueryMethod string
TemplateCustomFieldTypeQueryMethod is the type of a template custom field type query method
const ( // TemplateCustomFieldTypeQueryMethodUnknown is for an unknown query method TemplateCustomFieldTypeQueryMethodUnknown TemplateCustomFieldTypeQueryMethod = "" // TemplateCustomFieldTypeQueryMethodREST is for an api endpoint query method TemplateCustomFieldTypeQueryMethodREST TemplateCustomFieldTypeQueryMethod = "rest" // TemplateCustomFieldTypeQueryMethodNATS is for a NATS message channel query method TemplateCustomFieldTypeQueryMethodNATS TemplateCustomFieldTypeQueryMethod = "nats" )
func (TemplateCustomFieldTypeQueryMethod) MarshalJSON ¶
func (t TemplateCustomFieldTypeQueryMethod) MarshalJSON() ([]byte, error)
MarshalJSON returns the JSON representation of a TemplateCustomFieldTypeQueryTargetType.
func (TemplateCustomFieldTypeQueryMethod) String ¶
func (t TemplateCustomFieldTypeQueryMethod) String() string
String returns the string representation of a TemplateCustomFieldTypeQueryTargetType.
func (*TemplateCustomFieldTypeQueryMethod) UnmarshalJSON ¶
func (t *TemplateCustomFieldTypeQueryMethod) UnmarshalJSON(b []byte) error
UnmarshalJSON converts the JSON representation of a TemplateCustomFieldTypeQueryTargetType to the appropriate enumeration constant.
type TemplateCustomFieldTypeQueryResult ¶
type TemplateCustomFieldTypeQueryResult interface { SessionContext GetName() string GetDataType() string GetValue() interface{} }
TemplateCustomFieldTypeQueryResult is the standard interface for all Template Custom Field Type Query Result implementations
type TemplateCustomFieldTypeQueryResultModel ¶
type TemplateCustomFieldTypeQueryResultModel struct { Session Name string `json:"name"` DataType string `json:"data_type"` Value interface{} `json:"value"` }
TemplateCustomFieldTypeQueryResultModel is the Template Custom Field Type query result model
func (*TemplateCustomFieldTypeQueryResultModel) GetDataType ¶
func (t *TemplateCustomFieldTypeQueryResultModel) GetDataType() string
GetDataType returns the data type of the template custom field type
func (*TemplateCustomFieldTypeQueryResultModel) GetName ¶
func (t *TemplateCustomFieldTypeQueryResultModel) GetName() string
GetName returns the name of the template custom field type
func (*TemplateCustomFieldTypeQueryResultModel) GetValue ¶
func (t *TemplateCustomFieldTypeQueryResultModel) GetValue() interface{}
GetValue returns the values of the template custom field type
type TemplateEngine ¶
type TemplateEngine string
TemplateEngine is the type of a template engine
const ( // TemplateEngineUnknown is for an unknown template engine TemplateEngineUnknown TemplateEngine = "" // TemplateEngineTerraform is for terraform template engine TemplateEngineTerraform TemplateEngine = "terraform" // TemplateEngineKubernetes is for kuberntes template engine, this refers raw manifest (no parameterization) TemplateEngineKubernetes TemplateEngine = "kubernetes" )
func (TemplateEngine) MarshalJSON ¶
func (t TemplateEngine) MarshalJSON() ([]byte, error)
MarshalJSON returns the JSON representation of a TemplateEngine.
func (TemplateEngine) String ¶
func (t TemplateEngine) String() string
String returns the string representation of a TemplateEngine.
func (*TemplateEngine) UnmarshalJSON ¶
func (t *TemplateEngine) UnmarshalJSON(b []byte) error
UnmarshalJSON converts the JSON representation of a TemplateEngine to the appropriate enumeration constant.
type TemplateFilter ¶
type TemplateFilter struct { Key TemplateFilterKey `json:"key,omitempty"` Value interface{} `json:"value,omitempty"` }
TemplateFilter is a struct for a filter in metadata
type TemplateFilterKey ¶
type TemplateFilterKey string
TemplateFilterKey indicates the type of a filter key.
const ( // TemplateFilterKeyUnknown indicates that the value is unknown TemplateFilterKeyUnknown TemplateFilterKey = "" // TemplateFilterKeyImageAllowed indicates that the value is a list of images allowed TemplateFilterKeyImageAllowed TemplateFilterKey = "images_allowed" // TemplateFilterKeyImageBlocked indicates that the value is a list of images blocked TemplateFilterKeyImageBlocked TemplateFilterKey = "images_blocked" )
Enumeration constants for TemplateFilterType.
func (TemplateFilterKey) MarshalJSON ¶
func (t TemplateFilterKey) MarshalJSON() ([]byte, error)
MarshalJSON returns the JSON representation of a TemplateFilterKey.
func (TemplateFilterKey) String ¶
func (t TemplateFilterKey) String() string
String returns the string representation of a TemplateFilterKey.
func (*TemplateFilterKey) UnmarshalJSON ¶
func (t *TemplateFilterKey) UnmarshalJSON(b []byte) error
UnmarshalJSON converts the JSON representation of a TemplateFilterKey to the appropriate enumeration constant.
type TemplateFormat ¶
type TemplateFormat string
TemplateFormat is the format of a template
const ( // TemplateFormatUnknown is for a template in unkonwn format TemplateFormatUnknown TemplateFormat = "" // TemplateFormatYAML is for a template in yaml format TemplateFormatYAML TemplateFormat = "yaml" // TemplateFormatJSON is for a template in json format TemplateFormatJSON TemplateFormat = "json" // TemplateFormatHCL is for a template in hcl format, the format used by Terraform for *.tf files TemplateFormatHCL TemplateFormat = "hcl" )
func (TemplateFormat) MarshalJSON ¶
func (t TemplateFormat) MarshalJSON() ([]byte, error)
MarshalJSON returns the JSON representation of a TemplateFormat.
func (TemplateFormat) String ¶
func (t TemplateFormat) String() string
String returns the string representation of a TemplateFormat.
func (*TemplateFormat) UnmarshalJSON ¶
func (t *TemplateFormat) UnmarshalJSON(b []byte) error
UnmarshalJSON converts the JSON representation of a TemplateFormat to the appropriate enumeration constant.
type TemplateGithubWebhook ¶
type TemplateGithubWebhook struct { // Key is only exposed in creation response Key string `json:"key"` }
TemplateGithubWebhook ...
type TemplateGitlabWebhook ¶
type TemplateGitlabWebhook struct { // Token is only exposed in creation response Token string `json:"token"` }
TemplateGitlabWebhook ...
type TemplateListItemModel ¶
type TemplateListItemModel struct { ID common.ID `json:"id"` Owner string `json:"owner"` Name string `json:"name"` Description string `json:"description"` Public bool `json:"public"` Deleted bool `json:"deleted"` Source TemplateSource `json:"source"` LatestVersionID common.ID `json:"latest_version_id"` Metadata TemplateMetadata `json:"metadata"` UIMetadata TemplateUIMetadata `json:"ui_metadata"` CreatedAt time.Time `json:"created_at"` UpdatedAt time.Time `json:"updated_at"` }
TemplateListItemModel is the element type in TemplateListModel
type TemplateListModel ¶
type TemplateListModel struct { Session Templates []TemplateListItemModel `json:"templates"` }
TemplateListModel is the template list model
func (*TemplateListModel) GetTemplates ¶
func (t *TemplateListModel) GetTemplates() []Template
GetTemplates returns templates
type TemplateMetadata ¶
type TemplateMetadata struct { SchemaURL string `json:"schema_url,omitempty"` SchemaVersion string `json:"schema_version,omitempty"` Name string `json:"name,omitempty"` Author string `json:"author,omitempty"` AuthorEmail string `json:"author_email,omitempty"` Description string `json:"description,omitempty"` DocURL string `json:"doc_url,omitempty"` TemplateType TemplateTypeName `json:"template_type,omitempty"` Purpose TemplatePurpose `json:"purpose,omitempty"` PublishedVersions []string `json:"published_versions,omitempty"` CacaoPreTasks []TemplateCacaoTask `json:"cacao_pre_tasks,omitempty"` CacaoPostTasks []TemplateCacaoTask `json:"cacao_post_tasks,omitempty"` // Parameters stores template parameters // e.g., // [ // {"name": "instance_count", "default": 1, "type": "integer"}, // {"name": "instance_name", "type": "string"} // ] Parameters []TemplateParameter `json:"parameters,omitempty"` // Filters add filters to screen out field values // e.g., // [ // {"Key": "images_allowed", "value": "xxxxx"} //] Filters []TemplateFilter `json:"filters,omitempty"` }
TemplateMetadata is a struct for template metadata The struct is generated from a metadata file (e.g., https://github.com/cyverse/tf-openstack-single-image/blob/master/metadata.json)
func (*TemplateMetadata) GetFilter ¶
func (meta *TemplateMetadata) GetFilter(key TemplateFilterKey) *TemplateFilter
GetFilter returns TemplateFilter with the given key If the filter with the given key does not exist, returns nil
func (*TemplateMetadata) GetFilterValueStrArr ¶
func (meta *TemplateMetadata) GetFilterValueStrArr(key TemplateFilterKey) []string
GetFilterValueStrArr returns TemplateFilter value with the given key
func (*TemplateMetadata) GetImagesAllowed ¶
func (meta *TemplateMetadata) GetImagesAllowed() []string
GetImagesAllowed returns images allowed
func (*TemplateMetadata) GetImagesBlocked ¶
func (meta *TemplateMetadata) GetImagesBlocked() []string
GetImagesBlocked returns images blocked
func (*TemplateMetadata) GetParameter ¶
func (meta *TemplateMetadata) GetParameter(name string) *TemplateParameter
GetParameter returns TemplateParameter with the given name If the parameter with the given name does not exist, returns nil
type TemplateModel ¶
type TemplateModel struct { Session ID common.ID `json:"id"` Owner string `json:"owner"` Name string `json:"name"` Description string `json:"description"` Public bool `json:"public"` Deleted bool `json:"deleted"` Source TemplateSource `json:"source"` LatestVersionID common.ID `json:"latest_version_id"` Metadata TemplateMetadata `json:"metadata"` UIMetadata TemplateUIMetadata `json:"ui_metadata"` CreatedAt time.Time `json:"created_at"` UpdatedAt time.Time `json:"updated_at"` UpdateFieldNames []string `json:"update_field_names,omitempty"` CredentialID string `json:"credential_id,omitempty"` // for import and sync IncludeCacaoReservedPurposes bool `json:"include_cacao_reserved_purposes,omitempty"` // for list }
TemplateModel is the template model. Implements Template.
func (TemplateModel) GetCreatedAt ¶
func (t TemplateModel) GetCreatedAt() time.Time
GetCreatedAt returns the creation time of the Template
func (TemplateModel) GetCredentialID ¶
func (t TemplateModel) GetCredentialID() string
GetCredentialID returns the credential id of the Template
func (*TemplateModel) GetDescription ¶
func (t *TemplateModel) GetDescription() string
GetDescription returns the description of the Template
func (*TemplateModel) GetID ¶
func (t *TemplateModel) GetID() common.ID
GetID returns the ID of the Template
func (TemplateModel) GetIncludeCacaoReservedPurposes ¶
func (t TemplateModel) GetIncludeCacaoReservedPurposes() bool
GetIncludeCacaoReservedPurposes returns if it include Templates having cacao reserved purposes
func (TemplateModel) GetLatestVersionID ¶
func (t TemplateModel) GetLatestVersionID() common.ID
GetLatestVersionID returns the ID of latest version of the template
func (*TemplateModel) GetMetadata ¶
func (t *TemplateModel) GetMetadata() TemplateMetadata
GetMetadata returns the metadata of the Template
func (*TemplateModel) GetName ¶
func (t *TemplateModel) GetName() string
GetName returns the name of the Template
func (*TemplateModel) GetOwner ¶
func (t *TemplateModel) GetOwner() string
GetOwner returns the owner of the Template
func (*TemplateModel) GetPrimaryID ¶
func (t *TemplateModel) GetPrimaryID() common.ID
GetPrimaryID returns the primary ID of the Template
func (*TemplateModel) GetSource ¶
func (t *TemplateModel) GetSource() TemplateSource
GetSource returns the source of the Template
func (*TemplateModel) GetUIMetadata ¶
func (t *TemplateModel) GetUIMetadata() TemplateUIMetadata
GetUIMetadata returns the ui metadata of the Template
func (*TemplateModel) GetUpdateFieldNames ¶
func (t *TemplateModel) GetUpdateFieldNames() []string
GetUpdateFieldNames returns the field names to be updated
func (TemplateModel) GetUpdatedAt ¶
func (t TemplateModel) GetUpdatedAt() time.Time
GetUpdatedAt returns the modified time of the Template
func (*TemplateModel) IsDeleted ¶
func (t *TemplateModel) IsDeleted() bool
IsDeleted returns the true if the template is deleted.
func (*TemplateModel) IsPublic ¶
func (t *TemplateModel) IsPublic() bool
IsPublic returns the accessibility of the Template, returns True if it is publically accessible
func (*TemplateModel) SetCredentialID ¶
func (t *TemplateModel) SetCredentialID(credentialID string)
SetCredentialID sets the credential id of the Template
func (*TemplateModel) SetDescription ¶
func (t *TemplateModel) SetDescription(description string)
SetDescription sets the description of the Template
func (*TemplateModel) SetID ¶
func (t *TemplateModel) SetID(id common.ID)
SetID sets the ID of the Template
func (*TemplateModel) SetIncludeCacaoReservedPurposes ¶
func (t *TemplateModel) SetIncludeCacaoReservedPurposes(include bool)
SetIncludeCacaoReservedPurposes sets to include Templates having cacao reserved purposes
func (*TemplateModel) SetName ¶
func (t *TemplateModel) SetName(name string)
SetName sets the name of the Template
func (*TemplateModel) SetPrimaryID ¶
func (t *TemplateModel) SetPrimaryID(id common.ID)
SetPrimaryID sets the primary ID of the Template
func (*TemplateModel) SetPublic ¶
func (t *TemplateModel) SetPublic(isPublic bool)
SetPublic sets the accessibility of the Template
func (*TemplateModel) SetSource ¶
func (t *TemplateModel) SetSource(source TemplateSource)
SetSource sets the source of the Template
func (*TemplateModel) SetUpdateFieldNames ¶
func (t *TemplateModel) SetUpdateFieldNames(fieldNames []string)
SetUpdateFieldNames sets the field names to be updated
type TemplateParameter ¶
type TemplateParameter struct { Name string `json:"name,omitempty"` Type string `json:"type,omitempty"` Description string `json:"description,omitempty"` Default interface{} `json:"default,omitempty"` Enum []interface{} `json:"enum,omitempty"` // DataValidationType can have something like "ip_address" or "username" to validate data value // application can determine how to use this DataValidationType string `json:"data_validation_type,omitempty"` Required bool `json:"required,omitempty"` Editable bool `json:"editable,omitempty"` Base64 bool `json:"base64,omitempty"` }
TemplateParameter is a struct for a parameter in metadata
func (*TemplateParameter) CheckValue ¶
func (param *TemplateParameter) CheckValue(value interface{}) (typeName string, resultValue interface{}, err error)
CheckValue checks value against parameter type and correct the format. nil is allowed and used to indicate that no value is provided for the parameter, and should use default value instead.
func (*TemplateParameter) CheckValueFromString ¶
func (param *TemplateParameter) CheckValueFromString(value string) (string, interface{}, error)
CheckValueFromString checks value in string format against parameter type and correct the format. When default is defined for the parameter, empty string ("") is treated as lack of value.
func (*TemplateParameter) CorrectDataType ¶
func (param *TemplateParameter) CorrectDataType() error
CorrectDataType corrects data type Updates Default and Enum fields to have correct data types
func (*TemplateParameter) UnmarshalJSON ¶
func (param *TemplateParameter) UnmarshalJSON(b []byte) error
UnmarshalJSON converts the JSON representation of a TemplateParameter to the object form.
type TemplateProviderType ¶
type TemplateProviderType string
TemplateProviderType is the type of a template provider
const ( // TemplateProviderTypeUnknown is for a template for unknown provider TemplateProviderTypeUnknown TemplateProviderType = "" // TemplateProviderTypeOpenStack is for a template for Openstack provider TemplateProviderTypeOpenStack TemplateProviderType = "openstack" // TemplateProviderTypeAWS is for a template for AWS provider TemplateProviderTypeAWS TemplateProviderType = "aws" // TemplateProviderTypeGCP is for a template for GCP provider TemplateProviderTypeGCP TemplateProviderType = "gcp" // TemplateProviderTypeAzure is for a template for Azure provider TemplateProviderTypeAzure TemplateProviderType = "azure" // TemplateProviderTypeKubernetes is for a template for Kubernetes provider TemplateProviderTypeKubernetes TemplateProviderType = "kubernetes" )
func (TemplateProviderType) MarshalJSON ¶
func (t TemplateProviderType) MarshalJSON() ([]byte, error)
MarshalJSON returns the JSON representation of a TemplateProviderType.
func (TemplateProviderType) String ¶
func (t TemplateProviderType) String() string
String returns the string representation of a TemplateProviderType.
func (*TemplateProviderType) UnmarshalJSON ¶
func (t *TemplateProviderType) UnmarshalJSON(b []byte) error
UnmarshalJSON converts the JSON representation of a TemplateProviderType to the appropriate enumeration constant.
type TemplatePurpose ¶
type TemplatePurpose string
TemplatePurpose indicates the reason that a template exists. For example, if the template is intended to be used to spin up compute instances then the template purpose would be `compute`. Similarly, if the template is intended to be used to provision storage then the template purpose would be `storage`. Templates used for all other purposes can be classified as `general`.
const ( // TemplatePurposeUnknown indicates that the purpose of the template is unspecified. TemplatePurposeUnknown TemplatePurpose = "" // for V1 // TemplatePurposeCompute indicates that the template is used to spin up a compute instance. TemplatePurposeCompute TemplatePurpose = "compute" // TemplatePurposeStorage indicates that the template is used to provision storage. TemplatePurposeStorage TemplatePurpose = "storage" // for V2 // TemplatePurposeOpenStackCompute indicates that the template is used to provision an openstack compute instance. TemplatePurposeOpenStackCompute TemplatePurpose = "openstack_compute" // TemplatePurposeOpenstackStorage indicates that the template is used to provision an openstack (unspecified) storage. TemplatePurposeOpenStackStorage TemplatePurpose = "openstack_storage" TemplatePurposeOpenStackShareStorage TemplatePurpose = "openstack_share_storage" // TemplatePurposeOpenstackStorage indicates that the template is used to provision an openstack volume storage. TemplatePurposeOpenStackVolumeStorage TemplatePurpose = "openstack_volume_storage" // TemplatePurposeGeneral indicates that the template is used to provision a general compute instance. TemplatePurposeGeneral TemplatePurpose = "general" // TemplatePurposeAWSCompute indicates that the template is used to provision an aws compute instance. TemplatePurposeAWSCompute TemplatePurpose = "aws_compute" // TemplatePurposeAWSStorage indicates that the template is used to provision an aws (unspecified) storage. TemplatePurposeAWSStorage TemplatePurpose = "aws_storage" // TemplatePurposeAWSStorage indicates that the template is used to provision an aws EBS storage. TemplatePurposeAWSEbsStorage TemplatePurpose = "aws_ebs_storage" // TemplatePurposeAWSStorage indicates that the template is used to provision an aws EBS storage. TemplatePurposeAWSS3Storage TemplatePurpose = "aws_s3_storage" // TemplatePurposeBareSystem indicates that the template is used to provision a bare system. TemplatePurposeBareSystem TemplatePurpose = "bare_system" // TemplatePurposeNextflow indicates that the template is used to provision a nextflow workflow. TemplatePurposeNextflow TemplatePurpose = "nextflow" // TemplatePurposeKubernetes indicates that the template is used to provision a kubernetes cluster. TemplatePurposeKubernetes TemplatePurpose = "kubernetes" // TemplatePurposeMultiCloud indicates that the template is used to provision a multi-cloud cluster. TemplatePurposeMultiCloud TemplatePurpose = "multi_cloud" // TemplatePurposeCacaoPrerequisite indicates that the template is cacao reserved for prerequisite. TemplatePurposeCacaoPrerequisite TemplatePurpose = "cacao_prerequisite" )
Enumeration constants for TemplatePurpose.
func (TemplatePurpose) MarshalJSON ¶
func (t TemplatePurpose) MarshalJSON() ([]byte, error)
MarshalJSON returns the JSON representation of a TemplatePurpose.
func (TemplatePurpose) String ¶
func (t TemplatePurpose) String() string
String returns the string representation of a TemplatePurpose.
func (*TemplatePurpose) UnmarshalJSON ¶
func (t *TemplatePurpose) UnmarshalJSON(b []byte) error
UnmarshalJSON converts the JSON representation of a TemplatePurpose to the appropriate enumeration constant.
type TemplateSource ¶
type TemplateSource struct { Type TemplateSourceType `json:"type"` URI string `json:"uri"` // e.g., 'github.com/cyverse/sometemplate' // AccessParameters is used to pass additional parameters for accessing source (e.g., git branch name ...) // e.g., for git, // "branch": "master" // "tag": "tag_test" // "path": "/sub_dir_to_template_in_repo" AccessParameters map[string]interface{} `json:"access_parameters"` Visibility TemplateSourceVisibility `json:"source_visibility"` // e.g., 'public' or 'private' }
TemplateSource is a struct for template source information
func (TemplateSource) Git ¶
func (ts TemplateSource) Git() *GitTemplateSource
Git convert to GitTemplateSource. If TemplateSource is not type git, then return nil.
type TemplateSourceCredential ¶
type TemplateSourceCredential struct { Username string `json:"GIT_USERNAME,omitempty"` Password string `json:"GIT_PASSWORD,omitempty"` SSHKey string `json:"GIT_SSH_KEY,omitempty"` }
TemplateSourceCredential is a struct for storing credentials to access template source
type TemplateSourceType ¶
type TemplateSourceType string
TemplateSourceType is the type of a template source
const ( // TemplateSourceTypeUnknown is for a template source from unknown TemplateSourceTypeUnknown TemplateSourceType = "" // TemplateSourceTypeGit is for a template source from git TemplateSourceTypeGit TemplateSourceType = "git" )
func (TemplateSourceType) MarshalJSON ¶
func (t TemplateSourceType) MarshalJSON() ([]byte, error)
MarshalJSON returns the JSON representation of a TemplateSourceType.
func (TemplateSourceType) String ¶
func (t TemplateSourceType) String() string
String returns the string representation of a TemplateSourceType.
func (*TemplateSourceType) UnmarshalJSON ¶
func (t *TemplateSourceType) UnmarshalJSON(b []byte) error
UnmarshalJSON converts the JSON representation of a TemplateSourceType to the appropriate enumeration constant.
type TemplateSourceTypeListModel ¶
type TemplateSourceTypeListModel struct { Session TemplateSourceTypes []TemplateSourceType `json:"template_source_types"` }
TemplateSourceTypeListModel is the template type list model
func (*TemplateSourceTypeListModel) GetTemplateSourceTypes ¶
func (t *TemplateSourceTypeListModel) GetTemplateSourceTypes() []TemplateSourceType
GetTemplateSourceTypes returns template source types
type TemplateSourceVisibility ¶
type TemplateSourceVisibility string
TemplateSourceVisibility is the visibility of a template source
const ( // TemplateSourceVisibilityUnknown is for an unknown template source TemplateSourceVisibilityUnknown TemplateSourceVisibility = "" // TemplateSourceVisibilityPublic is for a public template source, no authentication is required to access the source TemplateSourceVisibilityPublic TemplateSourceVisibility = "public" // TemplateSourceVisibilityPrivate is for a private template source, the user’s credentials must be used to access the source TemplateSourceVisibilityPrivate TemplateSourceVisibility = "private" )
func (TemplateSourceVisibility) MarshalJSON ¶
func (t TemplateSourceVisibility) MarshalJSON() ([]byte, error)
MarshalJSON returns the JSON representation of a TemplateSourceVisibility.
func (TemplateSourceVisibility) String ¶
func (t TemplateSourceVisibility) String() string
String returns the string representation of a TemplateSourceVisibility.
func (*TemplateSourceVisibility) UnmarshalJSON ¶
func (t *TemplateSourceVisibility) UnmarshalJSON(b []byte) error
UnmarshalJSON converts the JSON representation of a TemplateSourceVisibility to the appropriate enumeration constant.
type TemplateType ¶
type TemplateType interface { SessionContext GetPrimaryID() TemplateTypeName // points to Name GetName() TemplateTypeName GetFormats() []TemplateFormat GetEngine() TemplateEngine GetProviderTypes() []TemplateProviderType GetUpdateFieldNames() []string SetPrimaryID(id TemplateTypeName) SetName(name TemplateTypeName) SetFormats(formats []TemplateFormat) SetEngine(engine TemplateEngine) SetProviderTypes(providerTypes []TemplateProviderType) SetUpdateFieldNames(fieldNames []string) }
TemplateType is the standard interface for all TemplateType implementations
type TemplateTypeListItemModel ¶
type TemplateTypeListItemModel struct { Name TemplateTypeName `json:"name"` Formats []TemplateFormat `json:"formats,omitempty"` // e.g., {'yaml', 'json'} Engine TemplateEngine `json:"engine"` // e.g., 'terraform' ProviderTypes []TemplateProviderType `json:"provider_types,omitempty"` // e.g., {'openstack', 'aws', `kubernetes`} }
TemplateTypeListItemModel is the element type in TemplateTypeListModel
type TemplateTypeListModel ¶
type TemplateTypeListModel struct { Session TemplateTypes []TemplateTypeListItemModel `json:"template_types"` }
TemplateTypeListModel is the template type list model
func (*TemplateTypeListModel) GetTemplateTypes ¶
func (t *TemplateTypeListModel) GetTemplateTypes() []TemplateType
GetTemplateTypes returns template types
type TemplateTypeModel ¶
type TemplateTypeModel struct { Session Name TemplateTypeName `json:"name"` Formats []TemplateFormat `json:"formats,omitempty"` // e.g., {'yaml', 'json'} Engine TemplateEngine `json:"engine,omitempty"` // e.g., 'terraform' ProviderTypes []TemplateProviderType `json:"provider_types,omitempty"` // e.g., {'openstack', 'aws', `kubernetes`} UpdateFieldNames []string `json:"update_field_names,omitempty"` }
TemplateTypeModel is the type of template and is only compatible to certain cloud providers. Implements TemplateType.
func (*TemplateTypeModel) GetEngine ¶
func (t *TemplateTypeModel) GetEngine() TemplateEngine
GetEngine returns the engine for the TemplateType
func (*TemplateTypeModel) GetFormats ¶
func (t *TemplateTypeModel) GetFormats() []TemplateFormat
GetFormats returns the formats supported by the TemplateType
func (*TemplateTypeModel) GetName ¶
func (t *TemplateTypeModel) GetName() TemplateTypeName
GetName returns the name of the TemplateType
func (*TemplateTypeModel) GetPrimaryID ¶
func (t *TemplateTypeModel) GetPrimaryID() TemplateTypeName
GetPrimaryID returns the primary ID of the TemplateType
func (*TemplateTypeModel) GetProviderTypes ¶
func (t *TemplateTypeModel) GetProviderTypes() []TemplateProviderType
GetProviderTypes returns the provider types supported by the TemplateType
func (*TemplateTypeModel) GetUpdateFieldNames ¶
func (t *TemplateTypeModel) GetUpdateFieldNames() []string
GetUpdateFieldNames returns the field names to be updated
func (*TemplateTypeModel) SetEngine ¶
func (t *TemplateTypeModel) SetEngine(engine TemplateEngine)
SetEngine sets the engine for the TemplateType
func (*TemplateTypeModel) SetFormats ¶
func (t *TemplateTypeModel) SetFormats(formats []TemplateFormat)
SetFormats sets the formats supported by the TemplateType
func (*TemplateTypeModel) SetName ¶
func (t *TemplateTypeModel) SetName(name TemplateTypeName)
SetName sets the name of the TemplateType
func (*TemplateTypeModel) SetPrimaryID ¶
func (t *TemplateTypeModel) SetPrimaryID(id TemplateTypeName)
SetPrimaryID sets the primary ID of the TemplateType
func (*TemplateTypeModel) SetProviderTypes ¶
func (t *TemplateTypeModel) SetProviderTypes(providerTypes []TemplateProviderType)
SetProviderTypes sets the provider types supported by the TemplateType
func (*TemplateTypeModel) SetUpdateFieldNames ¶
func (t *TemplateTypeModel) SetUpdateFieldNames(fieldNames []string)
SetUpdateFieldNames sets the field names to be updated
type TemplateTypeName ¶
type TemplateTypeName string
TemplateTypeName is name (primary identifier) of template type
type TemplateUIField ¶
type TemplateUIField struct { Name string `json:"name,omitempty"` FieldType string `json:"field_type,omitempty"` UILabel string `json:"ui_label,omitempty"` HelpText string `json:"help_text,omitempty"` Parameters []TemplateUIKeyVal `json:"parameters,omitempty"` }
TemplateUIField is a struct for a ui wizard field in UI metadata
func (TemplateUIField) GetParametersMap ¶
func (field TemplateUIField) GetParametersMap() map[string]interface{}
GetParametersMap returns a map for Parameters array
type TemplateUIGroup ¶
type TemplateUIGroup struct { Type TemplateUIGroupType `json:"type,omitempty"` Title string `json:"title,omitempty"` HelpText string `json:"help_text,omitempty"` Collapsible bool `json:"collapsible,omitempty"` Toggleable bool `json:"toggleable,omitempty"` Items []TemplateUIGroupItem `json:"items,omitempty"` }
TemplateUIGroup is a struct for a ui wizard group in UI metadata
type TemplateUIGroupItem ¶
type TemplateUIGroupItem struct {
// contains filtered or unexported fields
}
TemplateUIGroupItem is one of TemplateUIField, TemplateUIGroup, or TemplateUIRow
func (*TemplateUIGroupItem) GetField ¶
func (item *TemplateUIGroupItem) GetField() *TemplateUIField
GetField returns group item as *TemplateUIField type
func (*TemplateUIGroupItem) GetGroup ¶
func (item *TemplateUIGroupItem) GetGroup() *TemplateUIGroup
GetGroup returns group item as *TemplateUIGroup type
func (*TemplateUIGroupItem) GetRow ¶
func (item *TemplateUIGroupItem) GetRow() *TemplateUIRow
GetRow returns group item as *TemplateUIRow type
func (*TemplateUIGroupItem) IsField ¶
func (item *TemplateUIGroupItem) IsField() bool
IsField returns true if the group item is field type
func (*TemplateUIGroupItem) IsGroup ¶
func (item *TemplateUIGroupItem) IsGroup() bool
IsGroup returns true if the group item is group type
func (*TemplateUIGroupItem) IsRow ¶
func (item *TemplateUIGroupItem) IsRow() bool
IsRow returns true if the group item is row type
func (TemplateUIGroupItem) MarshalBSON ¶
func (item TemplateUIGroupItem) MarshalBSON() ([]byte, error)
MarshalBSON returns the BSON representation of a TemplateUIGroupItem.
func (*TemplateUIGroupItem) MarshalJSON ¶
func (item *TemplateUIGroupItem) MarshalJSON() ([]byte, error)
MarshalJSON returns the JSON representation of a TemplateUIGroupItem.
func (*TemplateUIGroupItem) UnmarshalBSON ¶
func (item *TemplateUIGroupItem) UnmarshalBSON(b []byte) error
UnmarshalBSON converts the BSON representation of a TemplateUIGroupItem to the appropriate object.
func (*TemplateUIGroupItem) UnmarshalJSON ¶
func (item *TemplateUIGroupItem) UnmarshalJSON(b []byte) error
UnmarshalJSON converts the JSON representation of a TemplateUIGroupItem to the appropriate object.
type TemplateUIGroupType ¶
type TemplateUIGroupType string
TemplateUIGroupType defines group type.
const ( // TemplateUIGroupTypeUnknown indicates that the group type is unspecified. TemplateUIGroupTypeUnknown TemplateUIGroupType = "" // TemplateUIGroupTypeGroup indicates that the group is a simple group. TemplateUIGroupTypeGroup TemplateUIGroupType = "group" // TemplateUIGroupTypeAdvancedSettings indicates that the group is an advanced settings. TemplateUIGroupTypeAdvancedSettings TemplateUIGroupType = "advanced_settings" // TemplateUIGroupTypeRow indicates that the group is a row. TemplateUIGroupTypeRow TemplateUIGroupType = "row" )
Enumeration constants for TemplateUIGroupType.
func (TemplateUIGroupType) MarshalJSON ¶
func (t TemplateUIGroupType) MarshalJSON() ([]byte, error)
MarshalJSON returns the JSON representation of a TemplateUIGroupType.
func (TemplateUIGroupType) String ¶
func (t TemplateUIGroupType) String() string
String returns the string representation of a TemplateUIGroupType.
func (*TemplateUIGroupType) UnmarshalJSON ¶
func (t *TemplateUIGroupType) UnmarshalJSON(b []byte) error
UnmarshalJSON converts the JSON representation of a TemplateUIGroupType to the appropriate enumeration constant.
type TemplateUIKeyVal ¶
type TemplateUIKeyVal struct { Key string `json:"key,omitempty"` Value interface{} `json:"value,omitempty"` }
TemplateUIKeyVal is a struct for representing key-value formatted values.
type TemplateUIMetadata ¶
type TemplateUIMetadata struct { SchemaURL string `json:"schema_url,omitempty"` SchemaVersion string `json:"schema_version,omitempty"` Author string `json:"author,omitempty"` AuthorEmail string `json:"author_email,omitempty"` Description string `json:"description,omitempty"` DocURL string `json:"doc_url,omitempty"` Steps []TemplateUIStep `json:"steps,omitempty"` }
TemplateUIMetadata is a struct for template UI metadata
type TemplateUIRow ¶
type TemplateUIRow struct { Type TemplateUIRowType `json:"type,omitempty"` Fields []TemplateUIField `json:"fields,omitempty"` }
TemplateUIRow is a struct for a ui wizard row in UI metadata
type TemplateUIRowType ¶
type TemplateUIRowType string
TemplateUIRowType defines row type.
const ( // TemplateUIRowTypeUnknown indicates that the row type is unspecified. TemplateUIRowTypeUnknown TemplateUIRowType = "" // TemplateUIRowTypeRow indicates that the row is a simple row. TemplateUIRowTypeRow TemplateUIRowType = "row" )
Enumeration constants for TemplateUIRowType.
func (TemplateUIRowType) MarshalJSON ¶
func (t TemplateUIRowType) MarshalJSON() ([]byte, error)
MarshalJSON returns the JSON representation of a TemplateUIRowType.
func (TemplateUIRowType) String ¶
func (t TemplateUIRowType) String() string
String returns the string representation of a TemplateUIRowType.
func (*TemplateUIRowType) UnmarshalJSON ¶
func (t *TemplateUIRowType) UnmarshalJSON(b []byte) error
UnmarshalJSON converts the JSON representation of a TemplateUIRowType to the appropriate enumeration constant.
type TemplateUIStep ¶
type TemplateUIStep struct { Title string `json:"title,omitempty"` HelpText string `json:"help_text,omitempty"` Items []TemplateUIGroupItem `json:"items,omitempty"` }
TemplateUIStep is a struct for a ui wizard step in UI metadata
type TemplateVersion ¶
type TemplateVersion struct { ID common.ID `json:"id"` TemplateID common.ID `json:"template_id"` Source TemplateSource `json:"source"` Disabled bool `json:"disabled"` DisabledAt time.Time `json:"disabled_at"` // Credential that is needed to get the template from source, empty if not needed CredentialID string `json:"credential_id"` Metadata TemplateMetadata `json:"metadata"` UIMetadata TemplateUIMetadata `json:"ui_metadata"` CreatedAt time.Time `json:"created_at"` }
TemplateVersion is a version of a template, it captures the template metadata at a specific checkpoint (e.g. git commit).
type TemplateVersionDisableRequest ¶
TemplateVersionDisableRequest is the event body for events related to template version
type TemplateVersionDisableResponse ¶
type TemplateVersionDisableResponse = TemplateVersionModel
TemplateVersionDisableResponse is the response event of TemplateVersionDisableRequest
type TemplateVersionListModel ¶
type TemplateVersionListModel struct { Session Versions []TemplateVersion `json:"versions"` }
TemplateVersionListModel is the body of reply for listing versions
type TemplateVersionModel ¶
type TemplateVersionModel struct { Session TemplateVersion }
TemplateVersionModel is the body of the query/reply for getting a single version, and query for listing versions
type TemplateWebhook ¶
type TemplateWebhook struct { TemplateID common.ID `json:"template_id"` Platform TemplateWebhookPlatformType `json:"platform"` Gitlab TemplateGitlabWebhook `json:"gitlab,omitempty"` Github TemplateGithubWebhook `json:"github,omitempty"` CreatedAt time.Time `json:"created_at"` LastExecutedAt time.Time `json:"last_executed_at,omitempty"` }
TemplateWebhook is the service representation of a template webhook.
type TemplateWebhookClient ¶
type TemplateWebhookClient interface { List(ctx context.Context, actor Actor, user string, platform TemplateWebhookPlatformType) ([]TemplateWebhook, error) Create(ctx context.Context, actor Actor, webhook TemplateWebhook) (TemplateWebhook, error) Delete(ctx context.Context, actor Actor, templateID common.ID) error }
TemplateWebhookClient is interface for client that interact with TemplateWebhookService
func NewNatsTemplateWebhookClientFromConn ¶
func NewNatsTemplateWebhookClientFromConn(queryConn messaging2.QueryConnection, eventConn messaging2.EventConnection) (TemplateWebhookClient, error)
NewNatsTemplateWebhookClientFromConn creates a new client from existing connections.
Note, if you only need query functionality, then only supply queryConn, same for event functionality and eventConn.
type TemplateWebhookCreationRequest ¶
type TemplateWebhookCreationRequest struct { Session `json:",inline"` TemplateWebhook `json:"template_webhook"` }
TemplateWebhookCreationRequest is the cloudevent payload for webhook creation request
type TemplateWebhookCreationResponse ¶
type TemplateWebhookCreationResponse = TemplateWebhookCreationRequest
TemplateWebhookCreationResponse is the cloudevent payload for webhook creation response
type TemplateWebhookDeletionRequest ¶
type TemplateWebhookDeletionRequest = TemplateWebhookCreationRequest
TemplateWebhookDeletionRequest is the cloudevent payload for webhook deletion request
type TemplateWebhookDeletionResponse ¶
type TemplateWebhookDeletionResponse = TemplateWebhookCreationRequest
TemplateWebhookDeletionResponse is the cloudevent payload for webhook deletion response
type TemplateWebhookListReply ¶
type TemplateWebhookListReply struct { Session `json:",inline"` Webhooks []TemplateWebhook `json:"webhooks"` }
TemplateWebhookListReply is the cloudevent payload for list reply
type TemplateWebhookListRequest ¶
type TemplateWebhookListRequest struct { Session `json:",inline"` Owner string `json:"owner"` Template common.ID `json:"template_id"` Platform TemplateWebhookPlatformType `json:"platform"` }
TemplateWebhookListRequest is the cloudevent payload for list query
type TemplateWebhookPlatformType ¶
type TemplateWebhookPlatformType string
TemplateWebhookPlatformType represents the platform type of template webhook (e.g. gitlab, github)
const ( TemplateWebhookGithubPlatform TemplateWebhookPlatformType = "github" TemplateWebhookGitlabPlatform TemplateWebhookPlatformType = "gitlab" )
Constants for TemplateWebhookPlatformType
type TerraformWorkflowData ¶
type TerraformWorkflowData struct { // ID of the Terraform template to be applied. This will be used to name // the Terraform workspace used when appling the template, and keyed the // Terraform State in the Terraform backend TemplateID string `mapstructure:"template_id"` // name of the terraform module to execute as child module TfModuleName string `mapstructure:"module_name"` Username string `mapstructure:"username"` // ID of the cloud credential to use CloudCredID string `mapstructure:"cloud_cred_id"` AnsibleVars map[string]interface{} `mapstructure:"ansible_vars"` // Encrypted cloud credential encoded in base64 CloudCredentialBase64 string `mapstructure:"cloud_cred"` }
TerraformWorkflowData is the parameter to required to create a Terraform workflow. Corresponds to WfDat in WorkflowCreate
type TokenAuthCheckRequest ¶
TokenAuthCheckRequest is the request to check authN and authZ of a token on an operation.
type TokenClient ¶
type TokenClient interface { // AuthCheck checks for authN and authZ of a token on an operation, and resolve to username of owner if successful. // TODO pass operation identifier to this to check authZ. AuthCheck(ctx context.Context, actor Actor, token common.TokenID) (*TokenModel, error) Get(ctx context.Context, actor Actor, tokenID common.ID) (*TokenModel, error) List(ctx context.Context, actor Actor) ([]TokenModel, error) ListTypes(ctx context.Context, actor Actor) ([]TokenType, error) Create(ctx context.Context, actor Actor, token TokenCreateModel) (common.TokenID, error) Update(ctx context.Context, actor Actor, token TokenModel) error UpdateFields(ctx context.Context, actor Actor, token TokenModel, updateFieldNames []string) error Delete(ctx context.Context, actor Actor, tokenID common.ID) error Revoke(ctx context.Context, actor Actor, tokenID common.ID) error }
TokenClient is the client for Token
func NewNatsTokenClientFromConn ¶
func NewNatsTokenClientFromConn(queryConn messaging2.QueryConnection, eventConn messaging2.EventConnection) (TokenClient, error)
NewNatsTokenClientFromConn creates a new client from existing connections.
Note, if you only need query functionality, then only supply queryConn, same for event functionality and eventConn.
type TokenCreateBulkModel ¶
type TokenCreateBulkModel struct { Owner string `json:"owner"` Name string `json:"name"` Description string `json:"description,omitempty"` DelegatedContexts string `json:"DelegatedContexts"` Public bool `json:"public"` Expiration time.Time `json:"expiration"` Start *time.Time `json:"start,omitempty"` Scopes string `json:"scopes"` DelegatedContext string `json:"delegated_context,omitempty"` Tags map[string]string `json:"tags"` Tokens []TokenModel `json:"tokens"` }
TokenCreateBulkModel is the Token model for creating bulk tokens from an email/DelegatedContexts list. TODO implement
type TokenCreateModel ¶
type TokenCreateModel struct { Session ID common.ID `json:"id"` Owner string `json:"owner"` Name string `json:"name"` Description string `json:"description,omitempty"` Public bool `json:"public"` Expiration time.Time `json:"expiration"` Start *time.Time `json:"start,omitempty"` Scopes string `json:"scopes"` DelegatedContext string `json:"delegated_context,omitempty"` Type TokenType `json:"type"` Tags map[string]string `json:"tags"` CreatedAt time.Time `json:"created_at"` UpdatedAt time.Time `json:"updated_at"` Token string `json:"token"` }
TokenCreateModel is the Token model for exposing extra Token secret only on create
type TokenListModel ¶
type TokenListModel struct { Session Tokens []TokenModel `json:"tokens"` }
TokenListModel is the representation of a list of Tokens
type TokenModel ¶
type TokenModel struct { Session ID common.ID `json:"id"` Owner string `json:"owner"` Name string `json:"name"` Description string `json:"description,omitempty"` Public bool `json:"public"` Expiration time.Time `json:"expiration"` Start *time.Time `json:"start,omitempty"` Scopes string `json:"scopes"` DelegatedContext string `json:"delegated_context,omitempty"` Type TokenType `json:"type"` Tags map[string]string `json:"tags"` LastAccessed *time.Time `json:"last_accessed"` CreatedAt time.Time `json:"created_at"` UpdatedAt time.Time `json:"updated_at"` UpdateFieldNames []string `json:"update_field_names,omitempty"` }
TokenModel is the token model
func (*TokenModel) Verify ¶
func (t *TokenModel) Verify() (bool, error)
Verify verifies that the token is correctly formed and valid
type TokenType ¶
type TokenType string
TokenType is the type of token
const ( // PersonalTokenType is a token for personal use PersonalTokenType TokenType = "personal" // DelegatedTokenType is a token for delegated account / api access DelegatedTokenType TokenType = "delegated" // InternalDeployType is a token for internal use by cacao InternalDeployType TokenType = "internal-deploy" )
func (TokenType) MarshalJSON ¶
MarshalJSON returns the JSON representation of a TokenType
func (*TokenType) UnmarshalJSON ¶
UnmarshalJSON converts JSON/string into the appropriate TokenType enum
type TokenTypeListModel ¶
TokenTypeListModel is the representation of the list of token types
type UserActionClient ¶
type UserActionClient interface { // UserAction Get(ctx context.Context, actor Actor, userActionID common.ID) (*UserActionModel, error) List(ctx context.Context, actor Actor) ([]UserActionModel, error) Create(ctx context.Context, actor Actor, userAction UserActionModel) (common.ID, error) Update(ctx context.Context, actor Actor, userAction UserActionModel) error UpdateFields(ctx context.Context, actor Actor, userAction UserActionModel, updateFieldNames []string) error Delete(ctx context.Context, actor Actor, userActionID common.ID) error }
UserActionClient is the client for UserAction
func NewNatsUserActionClientFromConn ¶
func NewNatsUserActionClientFromConn(queryConn messaging2.QueryConnection, eventConn messaging2.EventConnection) (UserActionClient, error)
NewNatsUserActionClientFromConn creates a new client from existing connections.
Note, if you only need query functionality, then only supply queryConn, same for event functionality and eventConn.
type UserActionItem ¶
type UserActionItem struct {
// contains filtered or unexported fields
}
UserActionItem is a struct for user action item
func NewUserActionItemForScriptAction ¶
func NewUserActionItemForScriptAction(sourceType UserActionScriptSourceType, dataType UserActionScriptDataType, data string) UserActionItem
NewUserActionItemForScriptAction creates UserActionItem for script action
func (*UserActionItem) GetScriptAction ¶
func (item *UserActionItem) GetScriptAction() *UserScriptActionItem
GetScriptAction returns user action item as *UserScriptActionItem type
func (*UserActionItem) IsScriptAction ¶
func (item *UserActionItem) IsScriptAction() bool
IsScriptAction returns true if the user action item is script action
func (UserActionItem) MarshalBSON ¶
func (item UserActionItem) MarshalBSON() ([]byte, error)
MarshalBSON returns the BSON representation of a UserActionItem.
func (UserActionItem) MarshalJSON ¶
func (item UserActionItem) MarshalJSON() ([]byte, error)
MarshalJSON returns the JSON representation of a UserActionItem.
func (*UserActionItem) SetScriptAction ¶
func (item *UserActionItem) SetScriptAction(scriptAction *UserScriptActionItem)
SetScriptAction sets user script action item
func (*UserActionItem) UnmarshalBSON ¶
func (item *UserActionItem) UnmarshalBSON(b []byte) error
UnmarshalBSON converts the BSON representation of a UserActionItem to the appropriate object.
func (*UserActionItem) UnmarshalJSON ¶
func (item *UserActionItem) UnmarshalJSON(b []byte) error
UnmarshalJSON converts the JSON representation of a UserActionItem to the appropriate item.
type UserActionListModel ¶
type UserActionListModel struct { Session UserActions []UserActionModel `json:"user_actions"` }
UserActionListModel is the user action list model
type UserActionMethod ¶
type UserActionMethod string
UserActionMethod is the method of user action
const ( // UserActionMethodUnknown is for an unknown action UserActionMethodUnknown UserActionMethod = "" // UserActionMethodScript is for a script action UserActionMethodScript UserActionMethod = "script" )
func (UserActionMethod) MarshalJSON ¶
func (u UserActionMethod) MarshalJSON() ([]byte, error)
MarshalJSON returns the JSON representation of a UserActionMethod.
func (UserActionMethod) String ¶
func (u UserActionMethod) String() string
String returns the string representation of a UserActionMethod.
func (*UserActionMethod) UnmarshalJSON ¶
func (u *UserActionMethod) UnmarshalJSON(b []byte) error
UnmarshalJSON converts the JSON representation of a UserActionMethod to the appropriate enumeration constant.
type UserActionModel ¶
type UserActionModel struct { Session ID common.ID `json:"id"` Owner string `json:"owner"` Name string `json:"name"` Description string `json:"description,omitempty"` Public bool `json:"public"` Type UserActionType `json:"type"` // e.g., instance_execution Action UserActionItem `json:"action"` CreatedAt time.Time `json:"created_at"` UpdatedAt time.Time `json:"updated_at"` UpdateFieldNames []string `json:"update_field_names,omitempty"` }
UserActionModel is the user action model
func (*UserActionModel) GetPrimaryID ¶
func (u *UserActionModel) GetPrimaryID() common.ID
GetPrimaryID returns the primary ID of the UserAction
type UserActionScriptDataType ¶
type UserActionScriptDataType string
UserActionScriptDataType is the type of user action script data
const ( // UserActionScriptDataTypeUnknown is for an unknown user action script data UserActionScriptDataTypeUnknown UserActionScriptDataType = "" // UserActionScriptDataTypePython is for a python user action script data UserActionScriptDataTypePython UserActionScriptDataType = "text/x-python" // UserActionScriptDataTypeShellScript is for a shell script user action script data UserActionScriptDataTypeShellScript UserActionScriptDataType = "text/x-shellscript" // UserActionScriptDataTypePerl is for a perl user action script data UserActionScriptDataTypePerl UserActionScriptDataType = "application/x-perl" )
func (UserActionScriptDataType) MarshalJSON ¶
func (u UserActionScriptDataType) MarshalJSON() ([]byte, error)
MarshalJSON returns the JSON representation of a UserActionScriptDataType.
func (UserActionScriptDataType) String ¶
func (u UserActionScriptDataType) String() string
String returns the string representation of a UserActionScriptDataType.
func (*UserActionScriptDataType) UnmarshalJSON ¶
func (u *UserActionScriptDataType) UnmarshalJSON(b []byte) error
UnmarshalJSON converts the JSON representation of a UserActionScriptDataType to the appropriate enumeration constant.
type UserActionScriptSourceType ¶
type UserActionScriptSourceType string
UserActionScriptSourceType is the type of user action script source
const ( // UserActionScriptSourceTypeUnknown is for an unknown user action script source UserActionScriptSourceTypeUnknown UserActionScriptSourceType = "" // UserActionScriptSourceTypeURL is for an URL user action script source UserActionScriptSourceTypeURL UserActionScriptSourceType = "url" // UserActionScriptSourceTypeRaw is for a raw user action script source UserActionScriptSourceTypeRaw UserActionScriptSourceType = "raw" )
func (UserActionScriptSourceType) MarshalJSON ¶
func (u UserActionScriptSourceType) MarshalJSON() ([]byte, error)
MarshalJSON returns the JSON representation of a UserActionScriptSourceType.
func (UserActionScriptSourceType) String ¶
func (u UserActionScriptSourceType) String() string
String returns the string representation of a UserActionScriptSourceType.
func (*UserActionScriptSourceType) UnmarshalJSON ¶
func (u *UserActionScriptSourceType) UnmarshalJSON(b []byte) error
UnmarshalJSON converts the JSON representation of a UserActionScriptSourceType to the appropriate enumeration constant.
type UserActionType ¶
type UserActionType string
UserActionType is the type of user action
const ( // UserActionTypeUnknown is for an unknown action UserActionTypeUnknown UserActionType = "" // UserActionTypeInstanceExecution is for an action that executes on instances UserActionTypeInstanceExecution UserActionType = "instance_execution" )
func (UserActionType) MarshalJSON ¶
func (u UserActionType) MarshalJSON() ([]byte, error)
MarshalJSON returns the JSON representation of a UserActionType.
func (UserActionType) String ¶
func (u UserActionType) String() string
String returns the string representation of a UserActionType.
func (*UserActionType) UnmarshalJSON ¶
func (u *UserActionType) UnmarshalJSON(b []byte) error
UnmarshalJSON converts the JSON representation of a UserActionType to the appropriate enumeration constant.
type UserClient ¶
type UserClient interface { Add(ctx context.Context, actor Actor, user UserModel) error Update(ctx context.Context, actor Actor, user UserModel) error Get(ctx context.Context, actor Actor, username string, withSettings bool) (*UserModel, error) // get a user based on username Delete(ctx context.Context, actor Actor, user UserModel) error // UserHasLoggedIn will publish a notification event that notify relevant services that a user has logged in. UserHasLoggedIn(ctx context.Context, actor Actor, user UserModel) error GetSettings(ctx context.Context, actor Actor, username string) (*common.UserSettings, error) GetConfigs(ctx context.Context, actor Actor, username string) (*map[string]string, error) GetFavorites(ctx context.Context, actor Actor, username string) (*map[string][]string, error) GetRecents(ctx context.Context, actor Actor, username string) (*map[string]string, error) SetConfig(ctx context.Context, actor Actor, username string, key string, value string) error AddFavorite(ctx context.Context, actor Actor, username string, key string, value string) error DeleteFavorite(ctx context.Context, actor Actor, username string, key string, value string) error SetRecent(ctx context.Context, actor Actor, username string, key string, value string) error Search(ctx context.Context, actor Actor, filter UserListFilter) (UserList, error) // Given a filter, return a user list up to DefaultUserListItemsMax SearchNext(ctx context.Context, actor Actor, userlist UserList) error // load the next in a search, given the original UserList }
UserClient is client for user microservice.
func NewNatsUserClientFromConn ¶
func NewNatsUserClientFromConn(queryConn messaging2.QueryConnection, eventConn messaging2.EventConnection) (UserClient, error)
NewNatsUserClientFromConn creates a new client from existing connections.
Note, if you only need query functionality, then only supply queryConn, same for event functionality and eventConn.
type UserList ¶
type UserList interface { SessionContext GetFilter() UserListFilter GetUsers() []UserModel GetStart() int // index of start of current list, -1 if no results or error, available after successful Load() GetSize() int // size of the current list, 0 if nothing is found, -1 if error, available after successful Load() GetTotalFilterSize() int // total size of filter, 0 if nothing is found, -1 if error GetNextStart() int // index of next partition to retrieve, -1 if error is found, set to TotalFilterSize if all results returned }
UserList is the interface that defines objects that can retrieve lists of users TODO - currently not implemented
type UserListFilter ¶
type UserListFilter struct { Field FilterField `json:"field"` Value string `json:"value"` // if not set, defaults to all SortBy SortDirection `json:"sort_direction,omitempty"` // default is AscendingSort MaxItems int `json:"max_items,omitempty"` // requested max items to return in the list, defaults to DefaultUserListItemsMax Start int `json:"start_index"` // start index to retrieve from total list, default 0 IncludeDisabled bool `json:"include_disabled"` // if true, then disabled users will also be included in the filter (not yet implemented) }
UserListFilter is the struct that defines the filter for a UserList
type UserListModel ¶
type UserListModel struct { Session Filter UserListFilter Users []UserModel StartIndex int `json:"start_index"` TotalSize int `json:"total_size"` NextStart int `json:"next_start"` }
UserListModel implements UserList.
func (*UserListModel) GetTotalFilterSize ¶
func (ul *UserListModel) GetTotalFilterSize() int
GetTotalFilterSize ...
type UserModel ¶
type UserModel struct { Session Username string `json:"username"` FirstName string `json:"first_name,omitempty"` LastName string `json:"last_name,omitempty"` PrimaryEmail string `json:"primary_email,omitempty"` IsAdmin bool `json:"is_admin,omitempty"` DisabledAt time.Time `json:"disabled_at,omitempty"` WithSettings bool `json:"with_settings,omitempty"` UserSettings common.UserSettings `json:"settings,omitempty"` CreatedAt time.Time `json:"created_at"` UpdatedAt time.Time `json:"updated_at"` UpdatedBy string `json:"updated_by"` UpdatedEmulatorBy string `json:"updated_emulator_by"` }
UserModel represents one user
func (UserModel) GetPrimaryID ¶
GetPrimaryID returns the username of user.
type UserScriptActionItem ¶
type UserScriptActionItem struct { Method UserActionMethod `json:"method"` // this should be script SourceType UserActionScriptSourceType `json:"source_type"` DataType UserActionScriptDataType `json:"data_type"` Data string `json:"data"` }
UserScriptActionItem is a struct for user script action item
type UserSettingsReply ¶
type UserSettingsReply struct { Session common.UserSettings `json:",inline"` }
UserSettingsReply is used to receiving query reply over nats
type UserSettingsRequest ¶
type UserSettingsRequest struct { Session Username string `json:"username"` Key string `json:"key"` Value string `json:"value"` }
UserSettingsRequest is used to pass requests (query & event) over nats
type UserUpdate ¶
type UserUpdate struct { FirstName *string `json:"first_name,omitempty"` LastName *string `json:"last_name,omitempty"` PrimaryEmail *string `json:"primary_email,omitempty"` IsAdmin *bool `json:"is_admin,omitempty"` Disabled *bool `json:"disabled,omitempty"` UserSettings *common.UserSettings `json:"settings,omitempty"` }
UserUpdate ...
type UserUpdateRequest ¶
type UserUpdateRequest struct { Session Username string `json:"username"` Update UserUpdate `json:",inline"` }
UserUpdateRequest ...
type VisibilityType ¶
type VisibilityType string
VisibilityType is the visibility of credential, this is not currently used
type WorkflowCreate ¶
type WorkflowCreate struct { // cloud provider that the workflow operates on, this determines which Argo Cluster to dispatch the workflow to Provider AWMProvider `json:"provider"` // username of the user, null if not user specific Username *string `json:"username"` // filename of the workflow definition WorkflowFilename string `json:"workflow_filename"` // workflow data, parameters and other metadata used to create the workflow WfDat map[string]interface{} `json:"workflow_data"` }
WorkflowCreate is an event that request the creation of a workflow.
type WorkflowCreateFailed ¶
type WorkflowCreateFailed struct { // ID of the request event (WorkflowCreate) that caused this event RequestID common.EventID `json:"req_id"` // The provider that the workflow is attempted to be created in Provider AWMProvider `json:"provider"` // Type of the error occurred that cause the creation to fail Error string `json:"error"` // Extra error message Msg string `json:"msg"` }
WorkflowCreateFailed is an event emitted when failure occurred during workflow creation. This event is emitted in response to a WorkflowCreate event.
type WorkflowCreated ¶
type WorkflowCreated struct { // ID of the request event (WorkflowCreate) that caused this event RequestID common.EventID `json:"req_id"` // The provider of which the workflow is created in Provider AWMProvider `json:"provider"` // Name of the created workflow WorkflowName string `json:"workflow_name"` }
WorkflowCreated is an event emitted when a Workflow is created.
type WorkflowResubmit ¶
type WorkflowResubmit struct { // cloud provider that the workflow operates on, this determines which Argo Cluster to dispatch the workflow to Provider AWMProvider `json:"provider"` // name of the workflow WorkflowName string `json:"workflow_name"` }
WorkflowResubmit is an event that request the resubmission of a workflow.
type WorkflowResubmitFailed ¶
type WorkflowResubmitFailed struct { // ID of the request event (WorkflowTerminate) that caused this event RequestID common.EventID `json:"req_id"` // cloud provider that the workflow operates on, this determines which Argo Cluster to dispatch the workflow to Provider AWMProvider `json:"provider"` // name of the workflow that is requested to be resubmitted WorkflowName string `json:"workflow_name"` // Type of the error occurred that cause the resubmission to fail Error string `json:"error"` // Extra error message Msg string `json:"msg"` }
WorkflowResubmitFailed is an event that is emitted when workflow resubmission failed.
type WorkflowResubmitted ¶
type WorkflowResubmitted struct { // ID of the request event (WorkflowResubmit) that caused this event RequestID common.EventID `json:"req_id"` // cloud provider that the workflow operates on, this determines which Argo Cluster to dispatch the workflow to Provider AWMProvider `json:"provider"` // name of the workflow that is requested to be resubmitted WorkflowName string `json:"workflow_name"` // name of the newly created workflow as the result of the resubmission NewWorkflowName string `json:"new_workflow_name"` }
WorkflowResubmitted is an event that is emitted when workflow resubmission succeeded.
type WorkflowTerminate ¶
type WorkflowTerminate struct { // cloud provider that the workflow operates on, this determines which Argo Cluster to dispatch the workflow to Provider AWMProvider `json:"provider"` // name of the workflow WorkflowName string `json:"workflow_name"` }
WorkflowTerminate is an event that request the terminatation of a workflow.
type WorkflowTerminateFailed ¶
type WorkflowTerminateFailed struct { // ID of the request event (WorkflowTerminate) that caused this event RequestID common.EventID `json:"req_id"` // cloud provider that the workflow operates on, this determines which Argo Cluster to dispatch the workflow to Provider AWMProvider `json:"provider"` // name of the workflow WorkflowName string `json:"workflow_name"` // Type of the error occurred that cause the termination to fail Error string `json:"error"` // Extra error message Msg string `json:"msg"` }
WorkflowTerminateFailed is an event emitted when fail to terminate a workflow.
type WorkflowTerminated ¶
type WorkflowTerminated struct { // ID of the request event (WorkflowTerminate) that caused this event RequestID common.EventID `json:"req_id"` // cloud provider that the workflow operates on, this determines which Argo Cluster to dispatch the workflow to Provider AWMProvider `json:"provider"` // name of the workflow WorkflowName string `json:"workflow_name"` // status of the workflow WorkflowStatus string `json:"workflow_status"` }
WorkflowTerminated is an event emitted when a workflow is terminated via a WorkflowTerminateCmd event.
type WorkspaceClient ¶
type WorkspaceClient interface { Get(ctx context.Context, actor Actor, workspaceID common.ID) (*WorkspaceModel, error) List(ctx context.Context, actor Actor) ([]WorkspaceModel, error) Create(ctx context.Context, actor Actor, workspace WorkspaceModel) (common.ID, error) CreateAsync(ctx context.Context, actor Actor, workspace WorkspaceModel) (messaging2.EventResponsePromise, error) CreateAsyncResponse(ctx context.Context, promise messaging2.EventResponsePromise) (WorkspaceModel, error) Update(ctx context.Context, actor Actor, workspace WorkspaceModel) error UpdateFields(ctx context.Context, actor Actor, workspace WorkspaceModel, updateFieldNames []string) error Delete(ctx context.Context, actor Actor, workspaceID common.ID) error }
WorkspaceClient is the client for Workspace
func NewNatsWorkspaceClientFromConn ¶
func NewNatsWorkspaceClientFromConn(queryConn messaging2.QueryConnection, eventConn messaging2.EventConnection) (WorkspaceClient, error)
NewNatsWorkspaceClientFromConn creates a new client from existing connections.
Note, if you only need query functionality, then only supply queryConn, same for event functionality and eventConn.
type WorkspaceListModel ¶
type WorkspaceListModel struct { Session Workspaces []WorkspaceModel `json:"workspaces"` }
WorkspaceListModel is the workspace list model
type WorkspaceModel ¶
type WorkspaceModel struct { Session ID common.ID `json:"id"` Owner string `json:"owner"` Name string `json:"name"` Description string `json:"description,omitempty"` DefaultProviderID common.ID `json:"default_provider_id,omitempty"` CreatedAt time.Time `json:"created_at"` UpdatedAt time.Time `json:"updated_at"` UpdateFieldNames []string `json:"update_field_names,omitempty"` }
WorkspaceModel is the workspace model
func (*WorkspaceModel) GetPrimaryID ¶
func (w *WorkspaceModel) GetPrimaryID() common.ID
GetPrimaryID returns the primary ID of the Workspace
Source Files ¶
- argo-workflow-mediator.go
- base_service.go
- credential.go
- credential_nats.go
- credential_nats_client.go
- dependency_mediator.go
- dependency_mediator_nats_client.go
- deployment.go
- deployment_nats.go
- deployment_nats_client.go
- deployment_state_view.go
- errors.go
- interactive_session.go
- interactive_session_nats_client.go
- js2allocation.go
- js2allocation_nats_client.go
- provider.go
- provider_nats_client.go
- template.go
- template_custom_field_type.go
- template_metadata.go
- template_nats_client.go
- template_ui_metadata.go
- template_webhook.go
- template_webhook_nats_client.go
- token.go
- token_nats_client.go
- user.go
- user_action.go
- user_action_nats_client.go
- user_nats_client.go
- user_settings_nats_client.go
- workspace.go
- workspace_nats_client.go