func getServiceInfo()

in cmd/service_info.go [49:188]


func getServiceInfo(operation *ServiceInfoOperation) {
	var eniIds []string

	acm := ACM.New(sess)
	ecs := ECS.New(sess, clusterName)
	ec2 := EC2.New(sess)
	elbv2 := ELBV2.New(sess)
	service := ecs.DescribeService(operation.ServiceName)
	tasks := ecs.DescribeTasksForService(operation.ServiceName)

	if service.Status != statusActive {
		console.InfoExit("Service not found")
	}

	console.KeyValue("Service Name", "%s\n", operation.ServiceName)
	console.KeyValue("Status", "\n")
	console.KeyValue("  Desired", "%d\n", service.DesiredCount)
	console.KeyValue("  Running", "%d\n", service.RunningCount)
	console.KeyValue("  Pending", "%d\n", service.PendingCount)
	console.KeyValue("Image", "%s\n", service.Image)
	console.KeyValue("Cpu", "%s\n", service.Cpu)
	console.KeyValue("Memory", "%s\n", service.Memory)

	if service.TaskRole != "" {
		console.KeyValue("Task Role", "%s\n", service.TaskRole)
	}

	console.KeyValue("Subnets", "%s\n", strings.Join(service.SubnetIds, ", "))
	console.KeyValue("Security Groups", "%s\n", strings.Join(service.SecurityGroupIds, ", "))

	if service.TargetGroupArn != "" {
		if loadBalancerArn := elbv2.GetTargetGroupLoadBalancerArn(service.TargetGroupArn); loadBalancerArn != "" {
			loadBalancer := elbv2.DescribeLoadBalancerByARN(loadBalancerArn)
			listeners := elbv2.GetListeners(loadBalancerArn)

			console.KeyValue("Load Balancer", "\n")
			console.KeyValue("  Name", "%s\n", loadBalancer.Name)
			console.KeyValue("  DNS Name", "%s\n", loadBalancer.DNSName)

			if len(listeners) > 0 {
				console.KeyValue("  Ports", "\n")
			}

			for _, listener := range listeners {
				var ruleOutput []string

				rules := elbv2.DescribeRules(listener.ARN)

				sort.Slice(rules, func(i, j int) bool { return rules[i].Priority > rules[j].Priority })

				for _, rule := range rules {
					if rule.TargetGroupARN == service.TargetGroupArn {
						ruleOutput = append(ruleOutput, rule.String())
					}
				}

				console.KeyValue("    "+listener.String(), "\n")
				console.KeyValue("      Rules", "%s\n", strings.Join(ruleOutput, ", "))

				if len(listener.CertificateARNs) > 0 {
					certificateDomains := acm.ListCertificateDomainNames(listener.CertificateARNs)
					console.KeyValue("      Certificates", "%s\n", strings.Join(certificateDomains, ", "))
				}
			}
		}

		if len(service.EnvVars) > 0 {
			console.KeyValue("Environment Variables", "\n")

			for _, envVar := range service.EnvVars {
				fmt.Printf("   %s=%s\n", envVar.Key, envVar.Value)
			}
		}
	}

	if len(tasks) > 0 {
		console.Header("Tasks")

		for _, task := range tasks {
			if task.EniId != "" {
				eniIds = append(eniIds, task.EniId)
			}
		}

		enis := ec2.DescribeNetworkInterfaces(eniIds)
		w := new(tabwriter.Writer)

		w.Init(os.Stdout, 0, 8, 1, '\t', 0)
		fmt.Fprintln(w, "ID\tIMAGE\tSTATUS\tRUNNING\tIP\tCPU\tMEMORY\tDEPLOYMENT\t")

		for _, t := range tasks {
			fmt.Fprintf(w, "%s\t%s\t%s\t%s\t%s\t%s\t%s\t%s\n",
				t.TaskId,
				t.Image,
				Humanize(t.LastStatus),
				t.RunningFor(),
				enis[t.EniId].PublicIpAddress,
				t.Cpu,
				t.Memory,
				t.DeploymentId,
			)
		}

		w.Flush()
	}

	if len(service.Deployments) > 0 {
		console.Header("Deployments")

		w := new(tabwriter.Writer)
		w.Init(os.Stdout, 0, 8, 1, '\t', 0)
		fmt.Fprintln(w, "ID\tIMAGE\tSTATUS\tCREATED\tDESIRED\tRUNNING\tPENDING")

		for _, d := range service.Deployments {
			fmt.Fprintf(w, "%s\t%s\t%s\t%s\t%d\t%d\t%d\n",
				d.Id,
				d.Image,
				Humanize(d.Status),
				d.CreatedAt,
				d.DesiredCount,
				d.RunningCount,
				d.PendingCount,
			)
		}

		w.Flush()
	}

	if len(service.Events) > 0 {
		console.Header("Events")

		for i, event := range service.Events {
			fmt.Printf("[%s] %s\n", event.CreatedAt, event.Message)

			if i == 10 && !verbose {
				break
			}
		}
	}
}