mirror of https://github.com/pulumi/pulumi.git
176 lines
9.8 KiB
Go
176 lines
9.8 KiB
Go
// Copyright 2016-2020, Pulumi Corporation.
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
package auto
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/pulumi/pulumi/sdk/v3/go/auto/optremove"
|
|
"github.com/pulumi/pulumi/sdk/v3/go/common/apitype"
|
|
"github.com/pulumi/pulumi/sdk/v3/go/common/workspace"
|
|
|
|
"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
|
|
)
|
|
|
|
// Workspace is the execution context containing a single Pulumi project, a program, and multiple stacks.
|
|
// Workspaces are used to manage the execution environment, providing various utilities such as plugin
|
|
// installation, environment configuration ($PULUMI_HOME), and creation, deletion, and listing of Stacks.
|
|
type Workspace interface {
|
|
// ProjectSettings returns the settings object for the current project if any.
|
|
ProjectSettings(context.Context) (*workspace.Project, error)
|
|
// SaveProjectSettings overwrites the settings object in the current project.
|
|
// There can only be a single project per workspace. Fails is new project name does not match old.
|
|
SaveProjectSettings(context.Context, *workspace.Project) error
|
|
// StackSettings returns the settings object for the stack matching the specified stack name if any.
|
|
StackSettings(context.Context, string) (*workspace.ProjectStack, error)
|
|
// SaveStackSettings overwrites the settings object for the stack matching the specified stack name.
|
|
SaveStackSettings(context.Context, string, *workspace.ProjectStack) error
|
|
// SerializeArgsForOp is hook to provide additional args to every CLI commands before they are executed.
|
|
// Provided with stack name,
|
|
// returns a list of args to append to an invoked command ["--config=...", ].
|
|
SerializeArgsForOp(context.Context, string) ([]string, error)
|
|
// PostCommandCallback is a hook executed after every command. Called with the stack name.
|
|
// An extensibility point to perform workspace cleanup (CLI operations may create/modify a Pulumi.stack.yaml).
|
|
PostCommandCallback(context.Context, string) error
|
|
// GetConfig returns the value associated with the specified stack name and key,
|
|
// scoped to the current workspace.
|
|
GetConfig(context.Context, string, string) (ConfigValue, error)
|
|
// GetConfigWithOptions returns the value associated with the specified stack name and key
|
|
// using the optional ConfigOptions,
|
|
// scoped to the current workspace.
|
|
GetConfigWithOptions(context.Context, string, string, *ConfigOptions) (ConfigValue, error)
|
|
// GetAllConfig returns the config map for the specified stack name, scoped to the current workspace.
|
|
GetAllConfig(context.Context, string) (ConfigMap, error)
|
|
// SetConfig sets the specified key-value pair on the provided stack name.
|
|
SetConfig(context.Context, string, string, ConfigValue) error
|
|
// SetConfigWithOptions sets the specified key-value pair on the provided stack name
|
|
// using the optional ConfigOptions.
|
|
SetConfigWithOptions(context.Context, string, string, ConfigValue, *ConfigOptions) error
|
|
// SetAllConfig sets all values in the provided config map for the specified stack name.
|
|
SetAllConfig(context.Context, string, ConfigMap) error
|
|
// SetAllConfigWithOptions sets all values in the provided config map for the specified stack name
|
|
// using the optional ConfigOptions.
|
|
SetAllConfigWithOptions(context.Context, string, ConfigMap, *ConfigOptions) error
|
|
// RemoveConfig removes the specified key-value pair on the provided stack name.
|
|
RemoveConfig(context.Context, string, string) error
|
|
// RemoveConfigWithOptions removes the specified key-value pair on the provided stack name
|
|
// using the optional ConfigOptions.
|
|
RemoveConfigWithOptions(context.Context, string, string, *ConfigOptions) error
|
|
// RemoveAllConfig removes all values in the provided key list for the specified stack name.
|
|
RemoveAllConfig(context.Context, string, []string) error
|
|
// RemoveAllConfigWithOptions removes all values in the provided key list for the specified stack name
|
|
// using the optional ConfigOptions.
|
|
RemoveAllConfigWithOptions(context.Context, string, []string, *ConfigOptions) error
|
|
// RefreshConfig gets and sets the config map used with the last Update for Stack matching stack name.
|
|
RefreshConfig(context.Context, string) (ConfigMap, error)
|
|
// GetTag returns the value associated with the specified stack name and key.
|
|
GetTag(context.Context, string, string) (string, error)
|
|
// SetTag sets the specified key-value pair on the provided stack name.
|
|
SetTag(context.Context, string, string, string) error
|
|
// RemoveTag removes the specified key-value pair on the provided stack name.
|
|
RemoveTag(context.Context, string, string) error
|
|
// ListTags returns the tag map for the specified stack name.
|
|
ListTags(context.Context, string) (map[string]string, error)
|
|
// GetEnvVars returns the environment values scoped to the current workspace.
|
|
GetEnvVars() map[string]string
|
|
// SetEnvVars sets the specified map of environment values scoped to the current workspace.
|
|
// These values will be passed to all Workspace and Stack level commands.
|
|
SetEnvVars(map[string]string) error
|
|
// SetEnvVar sets the specified environment value scoped to the current workspace.
|
|
// This value will be passed to all Workspace and Stack level commands.
|
|
SetEnvVar(string, string)
|
|
// UnsetEnvVar unsets the specified environment value scoped to the current workspace.
|
|
// This value will be removed from all Workspace and Stack level commands.
|
|
UnsetEnvVar(string)
|
|
// WorkDir returns the working directory to run Pulumi CLI commands.
|
|
WorkDir() string
|
|
// PulumiHome returns the directory override for CLI metadata if set.
|
|
// This customizes the location of $PULUMI_HOME where metadata is stored and plugins are installed.
|
|
PulumiHome() string
|
|
// PulumiVersion returns the version of the underlying Pulumi CLI/Engine.
|
|
PulumiVersion() string
|
|
// WhoAmI returns the currently authenticated user.
|
|
WhoAmI(context.Context) (string, error)
|
|
// WhoAmIDetails returns detailed information about the currently
|
|
// logged-in Pulumi identity.
|
|
WhoAmIDetails(ctx context.Context) (WhoAmIResult, error)
|
|
// Stack returns a summary of the currently selected stack, if any.
|
|
Stack(context.Context) (*StackSummary, error)
|
|
// CreateStack creates and sets a new stack with the stack name, failing if one already exists.
|
|
CreateStack(context.Context, string) error
|
|
// SelectStack selects and sets an existing stack matching the stack name, failing if none exists.
|
|
SelectStack(context.Context, string) error
|
|
// RemoveStack deletes the stack and all associated configuration and history.
|
|
RemoveStack(context.Context, string, ...optremove.Option) error
|
|
// ListStacks returns all Stacks created under the current Project.
|
|
// This queries underlying backend and may return stacks not present in the Workspace.
|
|
ListStacks(context.Context) ([]StackSummary, error)
|
|
// InstallPlugin acquires the plugin matching the specified name and version.
|
|
InstallPlugin(context.Context, string, string) error
|
|
// InstallPluginFromServer acquires the plugin matching the specified name and version.
|
|
InstallPluginFromServer(context.Context, string, string, string) error
|
|
// RemovePlugin deletes the plugin matching the specified name and version.
|
|
RemovePlugin(context.Context, string, string) error
|
|
// ListPlugins lists all installed plugins.
|
|
ListPlugins(context.Context) ([]workspace.PluginInfo, error)
|
|
// Program returns the program `pulumi.RunFunc` to be used for Preview/Update if any.
|
|
// If none is specified, the stack will refer to ProjectSettings for this information.
|
|
Program() pulumi.RunFunc
|
|
// SetProgram sets the program associated with the Workspace to the specified `pulumi.RunFunc`.
|
|
SetProgram(pulumi.RunFunc)
|
|
// ExportStack exports the deployment state of the stack matching the given name.
|
|
// This can be combined with ImportStack to edit a stack's state (such as recovery from failed deployments).
|
|
ExportStack(context.Context, string) (apitype.UntypedDeployment, error)
|
|
// ImportStack imports the specified deployment state into a pre-existing stack.
|
|
// This can be combined with ExportStack to edit a stack's state (such as recovery from failed deployments).
|
|
ImportStack(context.Context, string, apitype.UntypedDeployment) error
|
|
// StackOutputs gets the current set of Stack outputs from the last Stack.Up().
|
|
StackOutputs(context.Context, string) (OutputMap, error)
|
|
}
|
|
|
|
// ConfigValue is a configuration value used by a Pulumi program.
|
|
// Allows differentiating between secret and plaintext values by setting the `Secret` property.
|
|
type ConfigValue struct {
|
|
Value string
|
|
Secret bool
|
|
}
|
|
|
|
// ConfigOptions is a configuration option used by a Pulumi program.
|
|
// Allows to use the path flag while getting/setting the configuration.
|
|
type ConfigOptions struct {
|
|
Path bool
|
|
}
|
|
|
|
// ConfigMap is a map of ConfigValue used by Pulumi programs.
|
|
// Allows differentiating between secret and plaintext values.
|
|
type ConfigMap map[string]ConfigValue
|
|
|
|
// StackSummary is a description of a stack and its current status.
|
|
type StackSummary struct {
|
|
Name string `json:"name"`
|
|
Current bool `json:"current"`
|
|
LastUpdate string `json:"lastUpdate,omitempty"`
|
|
UpdateInProgress bool `json:"updateInProgress"`
|
|
ResourceCount *int `json:"resourceCount,omitempty"`
|
|
URL string `json:"url,omitempty"`
|
|
}
|
|
|
|
// WhoAmIResult contains detailed information about the currently logged-in Pulumi identity.
|
|
type WhoAmIResult struct {
|
|
User string `json:"user"`
|
|
Organizations []string `json:"organizations,omitempty"`
|
|
URL string `json:"url"`
|
|
}
|