Documentation ¶
Overview ¶
Package workspace provides access to terraform workspaces
Index ¶
- Constants
- Variables
- func NewService(opts Options) *service
- type Client
- func (c *Client) GetWorkspace(ctx context.Context, workspaceID string) (*Workspace, error)
- func (c *Client) GetWorkspaceByName(ctx context.Context, organization, workspace string) (*Workspace, error)
- func (c *Client) ListWorkspaces(ctx context.Context, options ListOptions) (*resource.Page[*Workspace], error)
- func (c *Client) LockWorkspace(ctx context.Context, workspaceID string, runID *string) (*Workspace, error)
- func (c *Client) UnlockWorkspace(ctx context.Context, workspaceID string, runID *string, force bool) (*Workspace, error)
- func (c *Client) UpdateWorkspace(ctx context.Context, workspaceID string, options UpdateOptions) (*Workspace, error)
- type ConnectOptions
- type CreateOptions
- type ExecutionMode
- type LatestRun
- type ListOptions
- type ListTagsOptions
- type ListWorkspaceTagsOptions
- type Lock
- type LockButton
- type LockKind
- type LockService
- type Options
- type OrganizationService
- type PermissionsService
- type QualifiedName
- type Service
- type Tag
- type TagService
- type TagSpec
- type TagSpecs
- type UpdateOptions
- type VCSProviderService
- type Workspace
- func (ws *Workspace) Enlock(id string, kind LockKind) error
- func (ws *Workspace) ExecutionModes() []string
- func (ws *Workspace) Locked() bool
- func (ws *Workspace) LogValue() slog.Value
- func (ws *Workspace) QualifiedName() QualifiedName
- func (ws *Workspace) String() string
- func (ws *Workspace) Unlock(id string, kind LockKind, force bool) error
- func (ws *Workspace) Update(opts UpdateOptions) error
- type WorkspacePage
- type WorkspaceService
Constants ¶
const ( RemoteExecutionMode ExecutionMode = "remote" LocalExecutionMode ExecutionMode = "local" AgentExecutionMode ExecutionMode = "agent" DefaultAllowDestroyPlan = true DefaultFileTriggersEnabled = true MinTerraformVersion = "1.2.0" DefaultTerraformVersion = "1.5.2" )
Variables ¶
var ErrInvalidTagSpec = errors.New("invalid tag spec: must provide either an ID or a name")
var ErrNoVCSConnection = errors.New("workspace is not connected to a vcs repo")
Functions ¶
func NewService ¶
func NewService(opts Options) *service
Types ¶
type Client ¶
type Client struct {
internal.JSONAPIClient
}
func (*Client) GetWorkspace ¶
GetWorkspace retrieves a workspace by its ID
func (*Client) GetWorkspaceByName ¶
func (c *Client) GetWorkspaceByName(ctx context.Context, organization, workspace string) (*Workspace, error)
GetWorkspaceByName retrieves a workspace by organization and name.
func (*Client) ListWorkspaces ¶
func (*Client) LockWorkspace ¶
func (*Client) UnlockWorkspace ¶
func (*Client) UpdateWorkspace ¶
func (c *Client) UpdateWorkspace(ctx context.Context, workspaceID string, options UpdateOptions) (*Workspace, error)
UpdateWorkspace updates the settings of an existing workspace.
type ConnectOptions ¶
type CreateOptions ¶
type CreateOptions struct { AllowDestroyPlan *bool AutoApply *bool Branch *string Description *string ExecutionMode *ExecutionMode FileTriggersEnabled *bool GlobalRemoteState *bool MigrationEnvironment *string Name *string `schema:"name,required"` QueueAllRuns *bool SpeculativeEnabled *bool SourceName *string SourceURL *string StructuredRunOutputEnabled *bool Tags []TagSpec TerraformVersion *string TriggerPrefixes []string WorkingDirectory *string Organization *string `schema:"organization_name,required"` *ConnectOptions }
CreateOptions represents the options for creating a new workspace.
type ExecutionMode ¶
type ExecutionMode string
func ExecutionModePtr ¶
func ExecutionModePtr(m ExecutionMode) *ExecutionMode
ExecutionModePtr returns a pointer to an execution mode.
type ListOptions ¶
type ListOptions struct { Search string Tags []string Organization *string resource.PageOptions }
ListOptions are options for paginating and filtering a list of Workspaces
type ListTagsOptions ¶
type ListTagsOptions struct {
resource.PageOptions
}
ListTagsOptions are options for paginating and filtering a list of tags
type ListWorkspaceTagsOptions ¶
type ListWorkspaceTagsOptions struct {
resource.PageOptions
}
ListWorkspaceTagsOptions are options for paginating and filtering a list of workspace tags
type Lock ¶
type Lock struct { LockKind // kind of entity holding lock // contains filtered or unexported fields }
Lock is a workspace Lock, which blocks runs from running and prevents state from being uploaded.
https://developer.hashicorp.com/terraform/cloud-docs/workspaces/settings#locking
type LockButton ¶
type LockService ¶
type Options ¶
type Options struct { *sql.DB *pubsub.Broker html.Renderer organization.OrganizationService vcsprovider.VCSProviderService repo.RepoService auth.TeamService logr.Logger }
type OrganizationService ¶
type OrganizationService organization.Service
type PermissionsService ¶
type QualifiedName ¶
QualifiedName is the workspace's fully qualified name including the name of its organization
type Service ¶
type Service interface { CreateWorkspace(ctx context.Context, opts CreateOptions) (*Workspace, error) UpdateWorkspace(ctx context.Context, workspaceID string, opts UpdateOptions) (*Workspace, error) GetWorkspace(ctx context.Context, workspaceID string) (*Workspace, error) GetWorkspaceByName(ctx context.Context, organization, workspace string) (*Workspace, error) ListWorkspaces(ctx context.Context, opts ListOptions) (*resource.Page[*Workspace], error) // ListWorkspacesByWebhookID retrieves workspaces by webhook ID. // // TODO: rename to ListConnectedWorkspaces ListWorkspacesByRepoID(ctx context.Context, repoID uuid.UUID) ([]*Workspace, error) DeleteWorkspace(ctx context.Context, workspaceID string) (*Workspace, error) SetCurrentRun(ctx context.Context, workspaceID, runID string) (*Workspace, error) LockService PermissionsService TagService // contains filtered or unexported methods }
type Tag ¶
type Tag struct { ID string // ID of the form 'tag-*'. Globally unique. Name string // Meaningful symbol. Unique to an organization. InstanceCount int // Number of workspaces that have this tag Organization string // Organization this tag belongs to. }
Tag is a symbol associated with one or more workspaces. Helps searching and grouping workspaces.
type TagService ¶
type TagService interface { // ListTags lists tags within an organization ListTags(ctx context.Context, organization string, opts ListTagsOptions) (*resource.Page[*Tag], error) // DeleteTags deletes tags from an organization DeleteTags(ctx context.Context, organization string, tagIDs []string) error // TagWorkspaces adds an existing tag to a list of workspaces TagWorkspaces(ctx context.Context, tagID string, workspaceIDs []string) error // AddTags appends tags to a workspace. Any tag specified by ID must // exist. Any tag specified by name is created if it does not // exist. AddTags(ctx context.Context, workspaceID string, tags []TagSpec) error // RemoveTags removes tags from a workspace. The workspace must already // exist. Any tag specifying an ID must exist. Any tag specifying a name // need not exist and no action is taken. If a tag is no longer // associated with any workspaces it is removed. RemoveTags(ctx context.Context, workspaceID string, tags []TagSpec) error // ListWorkspaceTags lists the tags for a workspace. ListWorkspaceTags(ctx context.Context, workspaceID string, options ListWorkspaceTagsOptions) (*resource.Page[*Tag], error) }
type UpdateOptions ¶
type UpdateOptions struct { AllowDestroyPlan *bool AutoApply *bool Name *string Description *string ExecutionMode *ExecutionMode `schema:"execution_mode"` FileTriggersEnabled *bool GlobalRemoteState *bool Operations *bool QueueAllRuns *bool SpeculativeEnabled *bool StructuredRunOutputEnabled *bool TerraformVersion *string `schema:"terraform_version"` TriggerPrefixes []string WorkingDirectory *string }
type VCSProviderService ¶
type VCSProviderService vcsprovider.Service
type Workspace ¶
type Workspace struct { ID string `json:"id"` CreatedAt time.Time `json:"created_at"` UpdatedAt time.Time `json:"updated_at"` AllowDestroyPlan bool `json:"allow_destroy_plan"` AutoApply bool `json:"auto_apply"` Branch string `json:"branch"` CanQueueDestroyPlan bool `json:"can_queue_destroy_plan"` Description string `json:"description"` Environment string `json:"environment"` ExecutionMode ExecutionMode `json:"execution_mode"` FileTriggersEnabled bool `json:"file_triggers_enabled"` GlobalRemoteState bool `json:"global_remote_state"` MigrationEnvironment string `json:"migration_environment"` Name string `json:"name"` QueueAllRuns bool `json:"queue_all_runs"` SpeculativeEnabled bool `json:"speculative_enabled"` StructuredRunOutputEnabled bool `json:"structured_run_output_enabled"` SourceName string `json:"source_name"` SourceURL string `json:"source_url"` TerraformVersion string `json:"terraform_version"` TriggerPrefixes []string `json:"trigger_prefixes"` WorkingDirectory string `json:"working_directory"` Organization string `json:"organization"` Connection *repo.Connection `json:"connection"` LatestRun *LatestRun `json:"latest_run"` Tags []string `json:"tags"` Lock *Lock `json:"lock"` }
Workspace is a terraform workspace.
func NewWorkspace ¶
func NewWorkspace(opts CreateOptions) (*Workspace, error)
func (*Workspace) ExecutionModes ¶
ExecutionModes returns a list of possible execution modes
func (*Workspace) QualifiedName ¶
func (ws *Workspace) QualifiedName() QualifiedName
QualifiedName returns the workspace's qualified name including the name of its organization
func (*Workspace) Update ¶
func (ws *Workspace) Update(opts UpdateOptions) error
Update updates the workspace with the given options.
type WorkspacePage ¶
type WorkspacePage struct { organization.OrganizationPage Workspace *Workspace }
WorkspacePage contains data shared by all workspace-based pages.
type WorkspaceService ¶
type WorkspaceService = Service