 Documentation
      ¶
      Documentation
      ¶
    
    
  
    
  
    Overview ¶
Package deploy holds the structures to deploy infrastructure resources. This file defines application deployment resources.
Package deploy holds the structures to deploy infrastructure resources.
Package deploy holds the structures to deploy infrastructure resources. This file defines environment deployment resources.
Package deploy holds the structures to deploy infrastructure resources. This file defines pipeline deployment resources.
Package deploy holds the structures to deploy infrastructure resources. This file defines workload deployment resources.
Package deploy holds the structures to deploy infrastructure resources. This file defines service deployment resources.
Package deploy holds the structures to deploy infrastructure resources. This file defines workload deployment resources.
Index ¶
- Constants
- func DNSDelegationRoleName(appName string) string
- func PipelineSourceFromManifest(mfSource *manifest.Source) (source interface{}, shouldPrompt bool, err error)
- type AppInformation
- type ArtifactBucket
- type BitbucketSource
- type Build
- type CodeCommitSource
- type ConfigStoreClient
- type CreateAppInput
- type CreateEnvironmentInput
- type CreateEnvironmentResponse
- type CreatePipelineInput
- type CreateTaskResourcesInput
- type DeleteWorkloadInput
- type DeployAction
- type GitHubSource
- type GitHubURL
- type GitHubV1Source
- type ManualApprovalAction
- type Pipeline
- type PipelineStage
- func (stg *PipelineStage) Approval() *ManualApprovalAction
- func (stg *PipelineStage) Deployments() ([]DeployAction, error)
- func (stg *PipelineStage) EnvManagerRoleARN() string
- func (stg *PipelineStage) ExecRoleARN() string
- func (stg *PipelineStage) Init(env *config.Environment, mftStage *manifest.PipelineStage, workloads []string)
- func (stg *PipelineStage) Name() string
- func (stg *PipelineStage) Region() string
- func (stg *PipelineStage) Test() (*TestCommandsAction, error)
 
- type PipelineStore
- type ResourceGetter
- type SessionProvider
- type Store
- func (s *Store) IsJobDeployed(appName, envName, jobName string) (bool, error)
- func (s *Store) IsServiceDeployed(appName string, envName string, svcName string) (bool, error)
- func (s *Store) ListDeployedJobs(appName string, envName string) ([]string, error)
- func (s *Store) ListDeployedServices(appName string, envName string) ([]string, error)
- func (s *Store) ListEnvironmentsDeployedTo(appName string, svcName string) ([]string, error)
- func (s *Store) ListSNSTopics(appName string, envName string) ([]Topic, error)
 
- type TaskStackInfo
- type TestCommandsAction
- type Topic
Constants ¶
const ( // LegacyAppTemplateVersion is the version associated with the application template before we started versioning. LegacyAppTemplateVersion = "v0.0.0" // LatestAppTemplateVersion is the latest version number available for application templates. LatestAppTemplateVersion = "v1.0.2" // AliasLeastAppTemplateVersion is the least version number available for HTTPS alias. AliasLeastAppTemplateVersion = "v1.0.0" )
const ( // AppTagKey is tag key for Copilot app. AppTagKey = "copilot-application" // EnvTagKey is tag key for Copilot env. EnvTagKey = "copilot-environment" // ServiceTagKey is tag key for Copilot service. ServiceTagKey = "copilot-service" // PipelineTagKey is tag key for Copilot pipeline. PipelineTagKey = "copilot-pipeline" // TaskTagKey is tag key for Copilot task. TaskTagKey = "copilot-task" )
const ( // LegacyEnvTemplateVersion is the version associated with the environment template before we started versioning. LegacyEnvTemplateVersion = "v0.0.0" // LatestEnvTemplateVersion is the latest version number available for environment templates. LatestEnvTemplateVersion = "v1.12.1" )
const ( // WorkloadCfnTemplateNameFormat is the base output file name when `service package` // or `job package` is called. This is also used to render the pipeline CFN template. WorkloadCfnTemplateNameFormat = "%s-%s.stack.yml" // WorkloadCfnTemplateConfigurationNameFormat is the base output configuration // file name when `service package` or `job package is called. It's also used to // render the pipeline CFN template. WorkloadCfnTemplateConfigurationNameFormat = "%s-%s.params.json" // AddonsCfnTemplateNameFormat is the addons output file name when `service package` // is called. AddonsCfnTemplateNameFormat = "%s.addons.stack.yml" )
const (
	DefaultPipelineArtifactsDir = "infrastructure"
)
    const DefaultPipelineBranch = "main"
    DefaultPipelineBranch is the default repository branch to use for pipeline.
const FmtTaskECRRepoName = "copilot-%s"
    FmtTaskECRRepoName is the pattern used to generate the ECR repository's name
Variables ¶
This section is empty.
Functions ¶
func DNSDelegationRoleName ¶ added in v1.9.0
DNSDelegationRoleName returns the DNSDelegation role name of the app.
func PipelineSourceFromManifest ¶ added in v1.4.0
func PipelineSourceFromManifest(mfSource *manifest.Source) (source interface{}, shouldPrompt bool, err error)
PipelineSourceFromManifest processes manifest info about the source based on provider type. The return boolean is true for CodeStar Connections sources that require a polling prompt.
Types ¶
type AppInformation ¶ added in v1.9.0
AppInformation holds information about the application that need to be propagated to the env stacks and workload stacks.
func (*AppInformation) DNSDelegationRole ¶ added in v1.9.0
func (a *AppInformation) DNSDelegationRole() string
DNSDelegationRole returns the ARN of the app's DNS delegation role.
type ArtifactBucket ¶
type ArtifactBucket struct {
	// The name of the S3 bucket.
	BucketName string
	// The ARN of the KMS key used to en/decrypt artifacts stored in this bucket.
	KeyArn string
}
    ArtifactBucket represents an S3 bucket used by the CodePipeline to store intermediate artifacts produced by the pipeline.
func (*ArtifactBucket) Region ¶
func (a *ArtifactBucket) Region() (string, error)
Region parses out the region from the ARN of the KMS key associated with the artifact bucket.
type BitbucketSource ¶ added in v1.3.0
type BitbucketSource struct {
	ProviderName         string
	Branch               string
	RepositoryURL        string
	ConnectionARN        string
	OutputArtifactFormat string
}
    BitbucketSource defines the (BB) source of the artifacts to be built and deployed.
func (*BitbucketSource) Connection ¶ added in v1.5.0
func (s *BitbucketSource) Connection() string
Connection returns the ARN correlated with a ConnectionName in the pipeline manifest.
func (*BitbucketSource) ConnectionName ¶ added in v1.3.0
func (s *BitbucketSource) ConnectionName() (string, error)
ConnectionName generates a recognizable string by which the connection may be identified.
func (*BitbucketSource) Repository ¶ added in v1.3.0
func (s *BitbucketSource) Repository() (string, error)
Repository returns the repository portion. For CodeStar Connections, this needs to be in the format "some-user/my-repo."
type Build ¶ added in v1.6.0
type Build struct {
	// The URI that identifies the Docker image to use for this build project.
	Image                    string
	EnvironmentType          string
	BuildspecPath            string
	AdditionalPolicyDocument string
}
    Build represents CodeBuild project used in the CodePipeline to build and test Docker image.
type CodeCommitSource ¶ added in v1.1.0
type CodeCommitSource struct {
	ProviderName         string
	Branch               string
	RepositoryURL        string
	OutputArtifactFormat string
}
    CodeCommitSource defines the (CC) source of the artifacts to be built and deployed.
func (*CodeCommitSource) Repository ¶ added in v1.1.0
func (s *CodeCommitSource) Repository() (string, error)
Repository returns the repository portion. For example, given "aws/amazon-copilot", this function returns "amazon-copilot".
type ConfigStoreClient ¶
type ConfigStoreClient interface {
	GetEnvironment(appName string, environmentName string) (*config.Environment, error)
	ListEnvironments(appName string) ([]*config.Environment, error)
	ListWorkloads(appName string) ([]*config.Workload, error)
	GetService(appName, svcName string) (*config.Workload, error)
	GetJob(appName, jobname string) (*config.Workload, error)
}
    ConfigStoreClient wraps config store methods utilized by deploy store.
type CreateAppInput ¶
type CreateAppInput struct {
	Name                  string            // Name of the application that needs to be created.
	AccountID             string            // AWS account ID to administrate the application.
	DNSDelegationAccounts []string          // Accounts to grant DNS access to for this application.
	DomainName            string            // DNS Name used for this application.
	DomainHostedZoneID    string            // Hosted Zone ID for the domain.
	AdditionalTags        map[string]string // AdditionalTags are labels applied to resources under the application.
	Version               string            // The version of the application template to create the stack/stackset. If empty, creates the legacy stack/stackset.
}
    CreateAppInput holds the fields required to create an application stack set.
type CreateEnvironmentInput ¶
type CreateEnvironmentInput struct {
	// The version of the environment template to create the stack. If empty, creates the legacy stack.
	Version string
	// Application regional configurations.
	App                  AppInformation    // Information about the application that the environment belongs to, include app name, DNS name, the principal ARN of the account.
	Name                 string            // Name of the environment, must be unique within an application.
	AdditionalTags       map[string]string // AdditionalTags are labels applied to resources under the application.
	ArtifactBucketARN    string            // ARN of the regional application bucket.
	ArtifactBucketKeyARN string            // ARN of the KMS key used to encrypt the contents in the regional application bucket.
	// Runtime configurations.
	CustomResourcesURLs map[string]string //  Mapping of Custom Resource Function Name to the S3 URL where the function zip file is stored.
	// User inputs.
	ImportVPCConfig    *config.ImportVPC     // Optional configuration if users have an existing VPC.
	AdjustVPCConfig    *config.AdjustVPC     // Optional configuration if users want to override default VPC configuration.
	ImportCertARNs     []string              // Optional configuration if users want to import certificates.
	InternalALBSubnets []string              // Optional configuration if users want to specify internal ALB placement.
	AllowVPCIngress    bool                  // Optional configuration to allow access to internal ALB from ports 80/443.
	CIDRPrefixListIDs  []string              // Optional configuration to specify public security group ingress based on prefix lists.
	Telemetry          *config.Telemetry     // Optional observability and monitoring configuration.
	Mft                *manifest.Environment // Unmarshaled and interpolated manifest object.
	RawMft             []byte                // Content of the environment manifest without any modifications.
	ForceUpdate        bool
	CFNServiceRoleARN string // Optional. A service role ARN that CloudFormation should use to make calls to resources in the stack.
}
    CreateEnvironmentInput holds the fields required to deploy an environment.
type CreateEnvironmentResponse ¶
type CreateEnvironmentResponse struct {
	Env *config.Environment
	Err error
}
    CreateEnvironmentResponse holds the created environment on successful deployment. Otherwise, the environment is set to nil and a descriptive error is returned.
type CreatePipelineInput ¶
type CreatePipelineInput struct {
	// Name of the application this pipeline belongs to
	AppName string
	// Name of the pipeline
	Name string
	// IsLegacy should be set to true if the pipeline has been deployed using a legacy non-namespaced name; otherwise it is false.
	IsLegacy bool
	// The source code provider for this pipeline
	Source interface{}
	// The build project settings for this pipeline
	Build *Build
	// The stages of the pipeline. The order of stages in this list
	// will be the order we deploy to.
	Stages []PipelineStage
	// A list of artifact buckets and corresponding KMS keys that will
	// be used in this pipeline.
	ArtifactBuckets []ArtifactBucket
	// AdditionalTags are labels applied to resources under the application.
	AdditionalTags map[string]string
}
    CreatePipelineInput represents the fields required to deploy a pipeline.
type CreateTaskResourcesInput ¶
type CreateTaskResourcesInput struct {
	Name   string
	CPU    int
	Memory int
	Image                 string
	TaskRole              string
	ExecutionRole         string
	Command               []string
	EntryPoint            []string
	EnvVars               map[string]string
	EnvFileARN            string
	SSMParamSecrets       map[string]string
	SecretsManagerSecrets map[string]string
	OS   string
	Arch string
	App string
	Env string
	AdditionalTags map[string]string
}
    CreateTaskResourcesInput holds the fields required to create a task stack.
type DeleteWorkloadInput ¶ added in v0.5.0
type DeleteWorkloadInput struct {
	Name    string // Name of the workload that needs to be deleted.
	EnvName string // Name of the environment the service is deployed in.
	AppName string // Name of the application the service belongs to.
}
    DeleteWorkloadInput holds the fields required to delete a workload.
type DeployAction ¶ added in v1.18.0
type DeployAction struct {
	// contains filtered or unexported fields
}
    DeployAction represents a CodePipeline action of category "Deploy" for a cloudformation stack.
func (*DeployAction) Name ¶ added in v1.18.0
func (a *DeployAction) Name() string
Name returns the name of the CodePipeline deploy action for a workload.
func (*DeployAction) RunOrder ¶ added in v1.18.0
func (a *DeployAction) RunOrder() int
RunOrder returns the order in which the action should run.
func (*DeployAction) StackName ¶ added in v1.18.0
func (a *DeployAction) StackName() string
StackName returns the name of the workload stack to create or update.
func (*DeployAction) TemplateConfigPath ¶ added in v1.18.0
func (a *DeployAction) TemplateConfigPath() string
TemplateConfigPath returns the path of the CloudFormation template config file generated during the build phase.
func (*DeployAction) TemplatePath ¶ added in v1.18.0
func (a *DeployAction) TemplatePath() string
TemplatePath returns the path of the CloudFormation template file generated during the build phase.
type GitHubSource ¶ added in v1.1.0
type GitHubSource struct {
	ProviderName         string
	Branch               string
	RepositoryURL        GitHubURL
	ConnectionARN        string
	OutputArtifactFormat string
}
    GitHubSource (version 2) defines the source of the artifacts to be built and deployed. This version uses CodeStar Connections to authenticate access to the remote repo.
func (*GitHubSource) Connection ¶ added in v1.5.0
func (s *GitHubSource) Connection() string
Connection returns the ARN correlated with a ConnectionName in the pipeline manifest.
func (*GitHubSource) ConnectionName ¶ added in v1.4.0
func (s *GitHubSource) ConnectionName() (string, error)
ConnectionName generates a recognizable string by which the connection may be identified.
func (*GitHubSource) Owner ¶ added in v1.1.0
func (s *GitHubSource) Owner() (string, error)
Owner returns the repository owner portion. For example, given "aws/amazon-copilot", this function returns "aws".
func (*GitHubSource) Repository ¶ added in v1.1.0
func (s *GitHubSource) Repository() (string, error)
Repository returns the repository portion. For CodeStar Connections, this needs to be in the format "some-user/my-repo."
type GitHubURL ¶ added in v1.4.0
type GitHubURL string
GitHubURL is the common type for repo URLs for both GitHubSource versions: GitHubV1 (w/ access tokens) and GitHub (V2 w CodeStar Connections).
type GitHubV1Source ¶ added in v1.4.0
type GitHubV1Source struct {
	ProviderName                string
	Branch                      string
	RepositoryURL               GitHubURL
	PersonalAccessTokenSecretID string
}
    GitHubV1Source defines the source of the artifacts to be built and deployed. This version uses personal access tokens and is not recommended. https://docs.aws.amazon.com/codepipeline/latest/userguide/update-github-action-connections.html
func (*GitHubV1Source) GitHubPersonalAccessTokenSecretID ¶ added in v1.4.0
func (s *GitHubV1Source) GitHubPersonalAccessTokenSecretID() (string, error)
GitHubPersonalAccessTokenSecretID returns the ID of the secret in the Secrets manager, which stores the GitHub Personal Access token if the provider is "GitHubV1".
func (*GitHubV1Source) Owner ¶ added in v1.4.0
func (s *GitHubV1Source) Owner() (string, error)
Owner returns the repository owner portion. For example, given "aws/amazon-copilot", this function returns "aws".
func (*GitHubV1Source) Repository ¶ added in v1.4.0
func (s *GitHubV1Source) Repository() (string, error)
Repository returns the repository portion. For example, given "aws/amazon-copilot", this function returns "amazon-copilot".
type ManualApprovalAction ¶ added in v1.18.0
type ManualApprovalAction struct {
	// contains filtered or unexported fields
}
    ManualApprovalAction represents a stage approval action.
func (*ManualApprovalAction) Name ¶ added in v1.18.0
func (a *ManualApprovalAction) Name() string
Name returns the name of the CodePipeline approval action for the stage.
type Pipeline ¶ added in v1.16.0
type Pipeline struct {
	// The name of the application that the pipeline is associated with.
	AppName string
	// The pipeline resource name (physical resource ID) generated by CloudFormation.
	ResourceName string
	// The name given by user in the pipeline manifest.
	Name string
	// Whether the pipeline follows legacy-naming, i.e. not namespaced with "pipeline-app-".
	IsLegacy bool
}
    Pipeline is a deployed pipeline.
type PipelineStage ¶
type PipelineStage struct {
	// contains filtered or unexported fields
}
    PipelineStage represents configuration for each deployment stage of a workspace. A stage consists of the Config Environment the pipeline is deploying to, the containerized services that will be deployed, and test commands, if the user has opted to add any.
func (*PipelineStage) Approval ¶ added in v1.18.0
func (stg *PipelineStage) Approval() *ManualApprovalAction
Approval returns a manual approval action for the stage. If the stage does not require approval, then returns nil.
func (*PipelineStage) Deployments ¶ added in v1.18.0
func (stg *PipelineStage) Deployments() ([]DeployAction, error)
Deployments returns a list of deploy actions for the pipeline.
func (*PipelineStage) EnvManagerRoleARN ¶ added in v1.18.0
func (stg *PipelineStage) EnvManagerRoleARN() string
EnvManagerRoleARN returns the IAM role used to create or update CloudFormation stacks in an environment.
func (*PipelineStage) ExecRoleARN ¶ added in v1.18.0
func (stg *PipelineStage) ExecRoleARN() string
ExecRoleARN returns the IAM role assumed by CloudFormation to create or update resources defined in a template.
func (*PipelineStage) Init ¶ added in v1.18.0
func (stg *PipelineStage) Init(env *config.Environment, mftStage *manifest.PipelineStage, workloads []string)
Init populates the fields in PipelineStage against a target environment, the user's manifest config, and any local workload names.
func (*PipelineStage) Name ¶ added in v1.18.0
func (stg *PipelineStage) Name() string
Name returns the stage's name.
func (*PipelineStage) Region ¶ added in v1.18.0
func (stg *PipelineStage) Region() string
Region returns the AWS region name, such as "us-west-2", where the deployments will occur.
func (*PipelineStage) Test ¶ added in v1.18.0
func (stg *PipelineStage) Test() (*TestCommandsAction, error)
Test returns a test for the stage. If the stage does not have any test commands, then returns nil.
type PipelineStore ¶ added in v1.16.0
type PipelineStore struct {
	// contains filtered or unexported fields
}
    PipelineStore fetches information on deployed pipelines.
func NewPipelineStore ¶ added in v1.16.0
func NewPipelineStore(getter ResourceGetter) *PipelineStore
NewPipelineStore returns a new PipelineStore.
func (*PipelineStore) ListDeployedPipelines ¶ added in v1.16.0
func (p *PipelineStore) ListDeployedPipelines(appName string) ([]Pipeline, error)
ListDeployedPipelines returns a list of names of deployed pipelines by looking up pipeline resources with tags.
type ResourceGetter ¶ added in v1.16.0
type ResourceGetter interface {
	GetResourcesByTags(resourceType string, tags map[string]string) ([]*rg.Resource, error)
}
    ResourceGetter retrieves a group of resources that satisfy certain conditions, such as tags.
type SessionProvider ¶ added in v1.16.0
SessionProvider is the interface to provide configuration for the AWS SDK's service clients.
type Store ¶
type Store struct {
	// contains filtered or unexported fields
}
    Store fetches information on deployed services.
func NewStore ¶
func NewStore(sessProvider SessionProvider, store ConfigStoreClient) (*Store, error)
NewStore returns a new store.
func (*Store) IsJobDeployed ¶ added in v1.7.0
IsJobDeployed returns whether a job is deployed in an environment or not by checking for a state machine.
func (*Store) IsServiceDeployed ¶
IsServiceDeployed returns whether a service is deployed in an environment or not.
func (*Store) ListDeployedJobs ¶ added in v1.7.0
ListDeployedJobs returns the names of deployed jobs in an environment.
func (*Store) ListDeployedServices ¶
ListDeployedServices returns the names of deployed services in an environment.
func (*Store) ListEnvironmentsDeployedTo ¶
ListEnvironmentsDeployedTo returns all the environment that a service is deployed in.
type TaskStackInfo ¶ added in v1.1.0
type TaskStackInfo struct {
	StackName string
	App       string
	Env       string
	RoleARN string
	BucketName string
}
    TaskStackInfo contains essential information about a Copilot task stack
func (TaskStackInfo) ECRRepoName ¶ added in v1.1.0
func (t TaskStackInfo) ECRRepoName() string
ECRRepoName returns the name of the ECR repo for the one-off task.
func (TaskStackInfo) TaskName ¶ added in v1.1.0
func (t TaskStackInfo) TaskName() string
TaskName returns the name of the one-off task. This is the same as the value of the copilot-task tag. For example, a stack called "task-db-migrate" will have the TaskName "db-migrate"
type TestCommandsAction ¶ added in v1.18.0
type TestCommandsAction struct {
	// contains filtered or unexported fields
}
    TestCommandsAction represents a CodePipeline action of category "Test" to validate deployments.
func (*TestCommandsAction) Commands ¶ added in v1.18.0
func (a *TestCommandsAction) Commands() []string
Commands returns the list commands to run part of the test action.
func (*TestCommandsAction) Name ¶ added in v1.18.0
func (a *TestCommandsAction) Name() string
Name returns the name of the test action.
type Topic ¶ added in v1.10.0
type Topic struct {
	// contains filtered or unexported fields
}
    Topic holds information about a Copilot SNS topic and its ARN, ID, and Name.
func NewTopic ¶ added in v1.10.0
NewTopic creates a new Topic struct, validating the ARN as a Copilot-managed SNS topic. This function will
       Directories
      ¶
      Directories
      ¶
    
    | Path | Synopsis | 
|---|---|
| Package cloudformation provides functionality to deploy CLI concepts with AWS CloudFormation. | Package cloudformation provides functionality to deploy CLI concepts with AWS CloudFormation. | 
| 
          
            mocks
            
            
          
           Package mocks is a generated GoMock package. | Package mocks is a generated GoMock package. | 
| 
          
            stack
            
            
          
           Package stack provides functionality to transform manifest files and additional runtime configuration into CloudFormation stacks. | Package stack provides functionality to transform manifest files and additional runtime configuration into CloudFormation stacks. | 
| 
          
            stack/mocks
            
            
          
           Package mocks is a generated GoMock package. | Package mocks is a generated GoMock package. | 
| Package mocks is a generated GoMock package. | Package mocks is a generated GoMock package. | 
| upload
       | |
| 
          
            customresource
            
            
          
           Package customresource provides functionality to upload Copilot custom resources. | Package customresource provides functionality to upload Copilot custom resources. |