| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145 |
- package ecs
- import (
- "context"
- "fmt"
- "os"
- "os/signal"
- "syscall"
- "github.com/compose-spec/compose-go/cli"
- "github.com/compose-spec/compose-go/types"
- )
- func (b *ecsAPIService) Up(ctx context.Context, options *cli.ProjectOptions) error {
- project, err := cli.ProjectFromOptions(options)
- if err != nil {
- return err
- }
- err = b.SDK.CheckRequirements(ctx, b.Region)
- if err != nil {
- return err
- }
- cluster, err := b.GetCluster(ctx, project)
- if err != nil {
- return err
- }
- template, err := b.convert(project)
- if err != nil {
- return err
- }
- vpc, err := b.GetVPC(ctx, project)
- if err != nil {
- return err
- }
- subNets, err := b.SDK.GetSubNets(ctx, vpc)
- if err != nil {
- return err
- }
- if len(subNets) < 2 {
- return fmt.Errorf("VPC %s should have at least 2 associated subnets in different availability zones", vpc)
- }
- lb, err := b.GetLoadBalancer(ctx, project)
- if err != nil {
- return err
- }
- parameters := map[string]string{
- ParameterClusterName: cluster,
- ParameterVPCId: vpc,
- ParameterSubnet1Id: subNets[0],
- ParameterSubnet2Id: subNets[1],
- ParameterLoadBalancerARN: lb,
- }
- update, err := b.SDK.StackExists(ctx, project.Name)
- if err != nil {
- return err
- }
- operation := StackCreate
- if update {
- operation = StackUpdate
- changeset, err := b.SDK.CreateChangeSet(ctx, project.Name, template, parameters)
- if err != nil {
- return err
- }
- err = b.SDK.UpdateStack(ctx, changeset)
- if err != nil {
- return err
- }
- } else {
- err = b.SDK.CreateStack(ctx, project.Name, template, parameters)
- if err != nil {
- return err
- }
- }
- signalChan := make(chan os.Signal, 1)
- signal.Notify(signalChan, syscall.SIGINT, syscall.SIGTERM)
- go func() {
- <-signalChan
- fmt.Println("user interrupted deployment. Deleting stack...")
- b.Down(ctx, options)
- }()
- err = b.WaitStackCompletion(ctx, project.Name, operation)
- return err
- }
- func (b ecsAPIService) GetVPC(ctx context.Context, project *types.Project) (string, error) {
- //check compose file for custom VPC selected
- if vpc, ok := project.Extensions[ExtensionVPC]; ok {
- vpcID := vpc.(string)
- ok, err := b.SDK.VpcExists(ctx, vpcID)
- if err != nil {
- return "", err
- }
- if !ok {
- return "", fmt.Errorf("VPC does not exist: %s", vpc)
- }
- return vpcID, nil
- }
- defaultVPC, err := b.SDK.GetDefaultVPC(ctx)
- if err != nil {
- return "", err
- }
- return defaultVPC, nil
- }
- func (b ecsAPIService) GetLoadBalancer(ctx context.Context, project *types.Project) (string, error) {
- //check compose file for custom VPC selected
- if ext, ok := project.Extensions[ExtensionLB]; ok {
- lb := ext.(string)
- ok, err := b.SDK.LoadBalancerExists(ctx, lb)
- if err != nil {
- return "", err
- }
- if !ok {
- return "", fmt.Errorf("load balancer does not exist: %s", lb)
- }
- return lb, nil
- }
- return "", nil
- }
- func (b ecsAPIService) GetCluster(ctx context.Context, project *types.Project) (string, error) {
- //check compose file for custom VPC selected
- if ext, ok := project.Extensions[ExtensionCluster]; ok {
- cluster := ext.(string)
- ok, err := b.SDK.ClusterExists(ctx, cluster)
- if err != nil {
- return "", err
- }
- if !ok {
- return "", fmt.Errorf("cluster does not exist: %s", cluster)
- }
- return cluster, nil
- }
- return "", nil
- }
|