workspace

package
v1.24.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Nov 28, 2022 License: Apache-2.0 Imports: 12 Imported by: 0

Documentation

Overview

Package workspace contains functionality to manage a user's local workspace. This includes creating an application directory, reading and writing a summary file to associate the workspace with the application, and managing infrastructure-as-code files. The typical workspace will be structured like:

.
├── copilot                        (application directory)
│   ├── .workspace                 (workspace summary)
│   ├── my-service
│   │   └── manifest.yml           (service manifest)
|   |   environments
|   |   └── test
│   │       └── manifest.yml       (environment manifest for the environment test)
│   ├── buildspec.yml              (legacy buildspec for the pipeline's build stage)
│   ├── pipeline.yml               (legacy pipeline manifest)
│   ├── pipelines
│   │   ├── pipeline-app-beta
│   │   │   ├── buildspec.yml      (buildspec for the pipeline 'pipeline-app-beta')
│   ┴   ┴   └── manifest.yml       (pipeline manifest for the pipeline 'pipeline-app-beta')
└── my-service-src                 (customer service code)

Index

Constants

View Source
const (
	// CopilotDirName is the name of the directory where generated infrastructure code for an application will be stored.
	CopilotDirName = "copilot"
	// SummaryFileName is the name of the file that is associated with the application.
	SummaryFileName = ".workspace"
)

Variables

View Source
var ErrNoPipelineInWorkspace = errors.New("no pipeline manifest found in the workspace")

ErrNoPipelineInWorkspace means there was no pipeline manifest in the workspace dir.

Functions

func IsEmptyErr added in v1.24.0

func IsEmptyErr(err error) bool

IsEmptyErr returns true if the error is related to an empty workspace.

func IsInGitRepository added in v0.3.0

func IsInGitRepository(fs FileStat) bool

IsInGitRepository returns true if the current working directory is a git repository.

Types

type EnvironmentManifest added in v1.19.0

type EnvironmentManifest []byte

EnvironmentManifest represents raw local environment manifest.

type ErrFileExists

type ErrFileExists struct {
	FileName string
}

ErrFileExists means we tried to create an existing file.

func (*ErrFileExists) Error

func (e *ErrFileExists) Error() string

type ErrFileNotExists added in v1.13.0

type ErrFileNotExists struct {
	FileName string
}

ErrFileNotExists means we tried to read a non-existing file.

func (*ErrFileNotExists) Error added in v1.13.0

func (e *ErrFileNotExists) Error() string

type ErrNoAssociatedApplication added in v1.24.0

type ErrNoAssociatedApplication struct{}

ErrNoAssociatedApplication means we couldn't locate a workspace summary file.

func (*ErrNoAssociatedApplication) Error added in v1.24.0

func (*ErrNoAssociatedApplication) RecommendActions added in v1.24.0

func (_ *ErrNoAssociatedApplication) RecommendActions() string

RecommendActions suggests steps clients can take to mitigate the .workspace file not found error.

type ErrWorkspaceNotFound added in v1.13.0

type ErrWorkspaceNotFound struct {
	CurrentDirectory      string
	ManifestDirectoryName string
	NumberOfLevelsChecked int
}

ErrWorkspaceNotFound means we couldn't locate a workspace root.

func (*ErrWorkspaceNotFound) Error added in v1.13.0

func (e *ErrWorkspaceNotFound) Error() string

func (*ErrWorkspaceNotFound) RecommendActions added in v1.24.0

func (_ *ErrWorkspaceNotFound) RecommendActions() string

RecommendActions suggests steps clients can take to mitigate the copilot/ directory not found error.

type FileStat added in v0.3.0

type FileStat interface {
	Stat(name string) (os.FileInfo, error)
}

FileStat wraps the os.Stat function.

type PipelineManifest added in v1.16.0

type PipelineManifest struct {
	Name string // Name of the pipeline inside the manifest file.
	Path string // Absolute path to the manifest file for the pipeline.
}

PipelineManifest holds identifying information about a pipeline manifest file.

type Summary

type Summary struct {
	Application string `yaml:"application"` // Name of the application.
	Path        string `yaml:"-"`           // absolute path to the summary file.
}

Summary is a description of what's associated with this workspace.

type WorkloadManifest added in v1.13.0

type WorkloadManifest []byte

WorkloadManifest represents raw local workload manifest.

func (WorkloadManifest) WorkloadType added in v1.13.0

func (w WorkloadManifest) WorkloadType() (string, error)

WorkloadType returns the workload type of the manifest.

type Workspace

type Workspace struct {
	// contains filtered or unexported fields
}

Workspace typically represents a Git repository where the user has its infrastructure-as-code files as well as source files.

func Create added in v1.24.0

func Create(appName string, fs afero.Fs) (*Workspace, error)

Create creates a new Workspace in the current working directory for appName with summary if it doesn't already exist.

func Use added in v1.24.0

func Use(fs afero.Fs) (*Workspace, error)

Use returns an existing workspace, searching for a copilot/ directory from the current wd, up to 5 levels above. It returns ErrWorkspaceNotFound if no copilot/ directory is found.

func (*Workspace) DeleteWorkspaceFile

func (ws *Workspace) DeleteWorkspaceFile() error

DeleteWorkspaceFile removes the .workspace file under copilot/ directory. This will be called during app delete, we do not want to delete any other generated files.

func (*Workspace) EnvAddonFilePath added in v1.24.0

func (ws *Workspace) EnvAddonFilePath(fName string) string

EnvAddonFilePath returns the path of an addon file for environments.

func (*Workspace) EnvAddonsPath added in v1.24.0

func (ws *Workspace) EnvAddonsPath() string

EnvAddonsPath returns the addons/ directory file path for environments.

func (*Workspace) ListEnvironments added in v1.19.0

func (ws *Workspace) ListEnvironments() ([]string, error)

ListEnvironments returns the name of the environments in the workspace.

func (*Workspace) ListFiles added in v1.24.0

func (ws *Workspace) ListFiles(dirPath string) ([]string, error)

ListFiles returns a list of file paths to all the files under the dir.

func (*Workspace) ListJobs added in v1.13.0

func (ws *Workspace) ListJobs() ([]string, error)

ListJobs returns the names of all jobs in the workspace.

func (*Workspace) ListPipelines added in v1.16.0

func (ws *Workspace) ListPipelines() ([]PipelineManifest, error)

ListPipelines returns all pipelines in the workspace.

func (*Workspace) ListServices added in v1.13.0

func (ws *Workspace) ListServices() ([]string, error)

ListServices returns the names of the services in the workspace.

func (*Workspace) ListWorkloads added in v1.13.0

func (ws *Workspace) ListWorkloads() ([]string, error)

ListWorkloads returns the name of all the workloads in the workspace (could be unregistered in SSM).

func (*Workspace) Path added in v1.14.0

func (ws *Workspace) Path() string

Path returns the absolute path to the workspace.

func (*Workspace) ReadEnvironmentManifest added in v1.19.0

func (ws *Workspace) ReadEnvironmentManifest(mftDirName string) (EnvironmentManifest, error)

ReadEnvironmentManifest returns the contents of the environment's manifest under copilot/environments/{name}/manifest.yml.

func (*Workspace) ReadFile added in v1.24.0

func (ws *Workspace) ReadFile(fPath string) ([]byte, error)

ReadFile returns the content of a file.

func (*Workspace) ReadPipelineManifest

func (ws *Workspace) ReadPipelineManifest(path string) (*manifest.Pipeline, error)

ReadPipelineManifest returns the contents of the pipeline manifest under the given path.

func (*Workspace) ReadWorkloadManifest added in v0.4.0

func (ws *Workspace) ReadWorkloadManifest(mftDirName string) (WorkloadManifest, error)

ReadWorkloadManifest returns the contents of the workload's manifest under copilot/{name}/manifest.yml.

func (*Workspace) Rel added in v1.16.0

func (ws *Workspace) Rel(path string) (string, error)

func (*Workspace) Summary

func (ws *Workspace) Summary() (*Summary, error)

Summary returns a summary of the workspace. The method assumes that the workspace exists and the path is known.

func (*Workspace) WorkloadAddonFilePath added in v1.24.0

func (ws *Workspace) WorkloadAddonFilePath(wkldName, fName string) string

WorkloadAddonFilePath returns the path of an addon file for a given workload.

func (*Workspace) WorkloadAddonsPath added in v1.24.0

func (ws *Workspace) WorkloadAddonsPath(name string) string

WorkloadAddonsPath returns the addons/ directory file path for a given workload.

func (*Workspace) WriteAddon

func (ws *Workspace) WriteAddon(content encoding.BinaryMarshaler, svc, name string) (string, error)

WriteAddon writes the content of an addon file under "{svc}/addons/{name}.yml". If successful returns the full path of the file, otherwise an empty string and an error.

func (*Workspace) WriteEnvironmentManifest added in v1.20.0

func (ws *Workspace) WriteEnvironmentManifest(marshaler encoding.BinaryMarshaler, name string) (string, error)

WriteEnvironmentManifest writes the environment manifest under the copilot/environments/{name}/ directory. If successful returns the full path of the file, otherwise returns an empty string and the error.

func (*Workspace) WriteJobManifest added in v0.5.0

func (ws *Workspace) WriteJobManifest(marshaler encoding.BinaryMarshaler, name string) (string, error)

WriteJobManifest writes the job's manifest under the copilot/{name}/ directory.

func (*Workspace) WritePipelineBuildspec

func (ws *Workspace) WritePipelineBuildspec(marshaler encoding.BinaryMarshaler, name string) (string, error)

WritePipelineBuildspec writes the pipeline buildspec under the copilot/pipelines/{name}/ directory. If successful returns the full path of the file, otherwise returns an empty string and the error.

func (*Workspace) WritePipelineManifest

func (ws *Workspace) WritePipelineManifest(marshaler encoding.BinaryMarshaler, name string) (string, error)

WritePipelineManifest writes the pipeline manifest under the copilot/pipelines/{name}/ directory. If successful returns the full path of the file, otherwise returns an empty string and the error.

func (*Workspace) WriteServiceManifest

func (ws *Workspace) WriteServiceManifest(marshaler encoding.BinaryMarshaler, name string) (string, error)

WriteServiceManifest writes the service's manifest under the copilot/{name}/ directory.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL