mirror of https://github.com/docker/compose.git
handle API pagination
Signed-off-by: Nicolas De Loof <nicolas.deloof@gmail.com>
This commit is contained in:
parent
6e8975db79
commit
59d17a45a0
98
ecs/sdk.go
98
ecs/sdk.go
|
@ -181,7 +181,7 @@ func (s sdk) GetDefaultVPC(ctx context.Context) (string, error) {
|
||||||
|
|
||||||
func (s sdk) GetSubNets(ctx context.Context, vpcID string) ([]awsResource, error) {
|
func (s sdk) GetSubNets(ctx context.Context, vpcID string) ([]awsResource, error) {
|
||||||
logrus.Debug("Retrieve SubNets")
|
logrus.Debug("Retrieve SubNets")
|
||||||
ids := []awsResource{}
|
var ids []awsResource
|
||||||
var token *string
|
var token *string
|
||||||
for {
|
for {
|
||||||
subnets, err := s.EC2.DescribeSubnetsWithContext(ctx, &ec2.DescribeSubnetsInput{
|
subnets, err := s.EC2.DescribeSubnetsWithContext(ctx, &ec2.DescribeSubnetsInput{
|
||||||
|
@ -453,12 +453,14 @@ func (s sdk) ListStacks(ctx context.Context, name string) ([]compose.Stack, erro
|
||||||
if name != "" {
|
if name != "" {
|
||||||
params.StackName = &name
|
params.StackName = &name
|
||||||
}
|
}
|
||||||
cfStacks, err := s.CF.DescribeStacksWithContext(ctx, ¶ms)
|
var token *string
|
||||||
|
var stacks []compose.Stack
|
||||||
|
for {
|
||||||
|
response, err := s.CF.DescribeStacksWithContext(ctx, ¶ms)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
stacks := []compose.Stack{}
|
for _, stack := range response.Stacks {
|
||||||
for _, stack := range cfStacks.Stacks {
|
|
||||||
for _, t := range stack.Tags {
|
for _, t := range stack.Tags {
|
||||||
if *t.Key == compose.ProjectTag {
|
if *t.Key == compose.ProjectTag {
|
||||||
status := compose.RUNNING
|
status := compose.RUNNING
|
||||||
|
@ -480,22 +482,33 @@ func (s sdk) ListStacks(ctx context.Context, name string) ([]compose.Stack, erro
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if token == response.NextToken {
|
||||||
return stacks, nil
|
return stacks, nil
|
||||||
}
|
}
|
||||||
|
token = response.NextToken
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func (s sdk) GetStackClusterID(ctx context.Context, stack string) (string, error) {
|
func (s sdk) GetStackClusterID(ctx context.Context, stack string) (string, error) {
|
||||||
// Note: could use DescribeStackResource but we only can detect `does not exist` case by matching string error message
|
// Note: could use DescribeStackResource but we only can detect `does not exist` case by matching string error message
|
||||||
resources, err := s.CF.ListStackResourcesWithContext(ctx, &cloudformation.ListStackResourcesInput{
|
var token *string
|
||||||
|
for {
|
||||||
|
response, err := s.CF.ListStackResourcesWithContext(ctx, &cloudformation.ListStackResourcesInput{
|
||||||
StackName: aws.String(stack),
|
StackName: aws.String(stack),
|
||||||
})
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", err
|
return "", err
|
||||||
}
|
}
|
||||||
for _, r := range resources.StackResourceSummaries {
|
for _, r := range response.StackResourceSummaries {
|
||||||
if aws.StringValue(r.ResourceType) == "AWS::ECS::Cluster" {
|
if aws.StringValue(r.ResourceType) == "AWS::ECS::Cluster" {
|
||||||
return aws.StringValue(r.PhysicalResourceId), nil
|
return aws.StringValue(r.PhysicalResourceId), nil
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if token == response.NextToken {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
token = response.NextToken
|
||||||
|
}
|
||||||
// stack is using user-provided cluster
|
// stack is using user-provided cluster
|
||||||
res, err := s.CF.GetTemplateSummaryWithContext(ctx, &cloudformation.GetTemplateSummaryInput{
|
res, err := s.CF.GetTemplateSummaryWithContext(ctx, &cloudformation.GetTemplateSummaryInput{
|
||||||
StackName: aws.String(stack),
|
StackName: aws.String(stack),
|
||||||
|
@ -522,13 +535,20 @@ type templateMetadata struct {
|
||||||
|
|
||||||
func (s sdk) GetServiceTaskDefinition(ctx context.Context, cluster string, serviceArns []string) (map[string]string, error) {
|
func (s sdk) GetServiceTaskDefinition(ctx context.Context, cluster string, serviceArns []string) (map[string]string, error) {
|
||||||
defs := map[string]string{}
|
defs := map[string]string{}
|
||||||
|
|
||||||
svc := []*string{}
|
svc := []*string{}
|
||||||
for _, s := range serviceArns {
|
for _, s := range serviceArns {
|
||||||
svc = append(svc, aws.String(s))
|
svc = append(svc, aws.String(s))
|
||||||
}
|
}
|
||||||
|
for i := 0; i < len(svc); i += 10 {
|
||||||
|
end := i + 10
|
||||||
|
if end > len(svc) {
|
||||||
|
end = len(svc)
|
||||||
|
}
|
||||||
|
chunk := svc[i:end]
|
||||||
services, err := s.ECS.DescribeServicesWithContext(ctx, &ecs.DescribeServicesInput{
|
services, err := s.ECS.DescribeServicesWithContext(ctx, &ecs.DescribeServicesInput{
|
||||||
Cluster: aws.String(cluster),
|
Cluster: aws.String(cluster),
|
||||||
Services: svc,
|
Services: chunk,
|
||||||
})
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
|
@ -536,6 +556,7 @@ func (s sdk) GetServiceTaskDefinition(ctx context.Context, cluster string, servi
|
||||||
for _, s := range services.Services {
|
for _, s := range services.Services {
|
||||||
defs[aws.StringValue(s.ServiceArn)] = aws.StringValue(s.TaskDefinition)
|
defs[aws.StringValue(s.ServiceArn)] = aws.StringValue(s.TaskDefinition)
|
||||||
}
|
}
|
||||||
|
}
|
||||||
return defs, nil
|
return defs, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -570,7 +591,10 @@ func (s sdk) GetServiceTasks(ctx context.Context, cluster string, service string
|
||||||
if stopped {
|
if stopped {
|
||||||
state = "STOPPED"
|
state = "STOPPED"
|
||||||
}
|
}
|
||||||
tasks, err := s.ECS.ListTasksWithContext(ctx, &ecs.ListTasksInput{
|
var token *string
|
||||||
|
var tasks []*ecs.Task
|
||||||
|
for {
|
||||||
|
response, err := s.ECS.ListTasksWithContext(ctx, &ecs.ListTasksInput{
|
||||||
Cluster: aws.String(cluster),
|
Cluster: aws.String(cluster),
|
||||||
ServiceName: aws.String(service),
|
ServiceName: aws.String(service),
|
||||||
DesiredStatus: aws.String(state),
|
DesiredStatus: aws.String(state),
|
||||||
|
@ -578,17 +602,21 @@ func (s sdk) GetServiceTasks(ctx context.Context, cluster string, service string
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
if len(tasks.TaskArns) > 0 {
|
if len(response.TaskArns) > 0 {
|
||||||
taskDescriptions, err := s.ECS.DescribeTasksWithContext(ctx, &ecs.DescribeTasksInput{
|
taskDescriptions, err := s.ECS.DescribeTasksWithContext(ctx, &ecs.DescribeTasksInput{
|
||||||
Cluster: aws.String(cluster),
|
Cluster: aws.String(cluster),
|
||||||
Tasks: tasks.TaskArns,
|
Tasks: response.TaskArns,
|
||||||
})
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
return taskDescriptions.Tasks, nil
|
tasks = append(tasks, taskDescriptions.Tasks...)
|
||||||
|
}
|
||||||
|
if token == response.NextToken {
|
||||||
|
return tasks, nil
|
||||||
|
}
|
||||||
|
token = response.NextToken
|
||||||
}
|
}
|
||||||
return nil, nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s sdk) GetTaskStoppedReason(ctx context.Context, cluster string, taskArn string) (string, error) {
|
func (s sdk) GetTaskStoppedReason(ctx context.Context, cluster string, taskArn string) (string, error) {
|
||||||
|
@ -671,16 +699,17 @@ func (resources stackResources) apply(awsType string, fn stackResourceFn) error
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s sdk) ListStackResources(ctx context.Context, name string) (stackResources, error) {
|
func (s sdk) ListStackResources(ctx context.Context, name string) (stackResources, error) {
|
||||||
// FIXME handle pagination
|
var token *string
|
||||||
res, err := s.CF.ListStackResourcesWithContext(ctx, &cloudformation.ListStackResourcesInput{
|
var resources stackResources
|
||||||
|
for {
|
||||||
|
response, err := s.CF.ListStackResourcesWithContext(ctx, &cloudformation.ListStackResourcesInput{
|
||||||
StackName: aws.String(name),
|
StackName: aws.String(name),
|
||||||
})
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
resources := stackResources{}
|
for _, r := range response.StackResourceSummaries {
|
||||||
for _, r := range res.StackResourceSummaries {
|
|
||||||
resources = append(resources, stackResource{
|
resources = append(resources, stackResource{
|
||||||
LogicalID: aws.StringValue(r.LogicalResourceId),
|
LogicalID: aws.StringValue(r.LogicalResourceId),
|
||||||
Type: aws.StringValue(r.ResourceType),
|
Type: aws.StringValue(r.ResourceType),
|
||||||
|
@ -688,8 +717,12 @@ func (s sdk) ListStackResources(ctx context.Context, name string) (stackResource
|
||||||
Status: aws.StringValue(r.ResourceStatus),
|
Status: aws.StringValue(r.ResourceStatus),
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
if token == response.NextToken {
|
||||||
return resources, nil
|
return resources, nil
|
||||||
}
|
}
|
||||||
|
token = response.NextToken
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func (s sdk) DeleteStack(ctx context.Context, name string) error {
|
func (s sdk) DeleteStack(ctx context.Context, name string) error {
|
||||||
logrus.Debug("Delete CloudFormation stack")
|
logrus.Debug("Delete CloudFormation stack")
|
||||||
|
@ -744,12 +777,14 @@ func (s sdk) InspectSecret(ctx context.Context, id string) (secrets.Secret, erro
|
||||||
|
|
||||||
func (s sdk) ListSecrets(ctx context.Context) ([]secrets.Secret, error) {
|
func (s sdk) ListSecrets(ctx context.Context) ([]secrets.Secret, error) {
|
||||||
logrus.Debug("List secrets ...")
|
logrus.Debug("List secrets ...")
|
||||||
|
var ls []secrets.Secret
|
||||||
|
var token *string
|
||||||
|
for {
|
||||||
response, err := s.SM.ListSecrets(&secretsmanager.ListSecretsInput{})
|
response, err := s.SM.ListSecrets(&secretsmanager.ListSecretsInput{})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
var ls []secrets.Secret
|
|
||||||
for _, sec := range response.SecretList {
|
for _, sec := range response.SecretList {
|
||||||
|
|
||||||
tags := map[string]string{}
|
tags := map[string]string{}
|
||||||
|
@ -762,8 +797,13 @@ func (s sdk) ListSecrets(ctx context.Context) ([]secrets.Secret, error) {
|
||||||
Labels: tags,
|
Labels: tags,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if token == response.NextToken {
|
||||||
return ls, nil
|
return ls, nil
|
||||||
}
|
}
|
||||||
|
token = response.NextToken
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func (s sdk) DeleteSecret(ctx context.Context, id string, recover bool) error {
|
func (s sdk) DeleteSecret(ctx context.Context, id string, recover bool) error {
|
||||||
logrus.Debug("List secrets ...")
|
logrus.Debug("List secrets ...")
|
||||||
|
@ -967,35 +1007,47 @@ func (s sdk) getURLWithPortMapping(ctx context.Context, targetGroupArns []string
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s sdk) ListTasks(ctx context.Context, cluster string, family string) ([]string, error) {
|
func (s sdk) ListTasks(ctx context.Context, cluster string, family string) ([]string, error) {
|
||||||
tasks, err := s.ECS.ListTasksWithContext(ctx, &ecs.ListTasksInput{
|
var token *string
|
||||||
|
var arns []string
|
||||||
|
for {
|
||||||
|
response, err := s.ECS.ListTasksWithContext(ctx, &ecs.ListTasksInput{
|
||||||
Cluster: aws.String(cluster),
|
Cluster: aws.String(cluster),
|
||||||
Family: aws.String(family),
|
Family: aws.String(family),
|
||||||
})
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
arns := []string{}
|
for _, arn := range response.TaskArns {
|
||||||
for _, arn := range tasks.TaskArns {
|
|
||||||
arns = append(arns, *arn)
|
arns = append(arns, *arn)
|
||||||
}
|
}
|
||||||
|
if token == response.NextToken {
|
||||||
return arns, nil
|
return arns, nil
|
||||||
}
|
}
|
||||||
|
token = response.NextToken
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func (s sdk) GetPublicIPs(ctx context.Context, interfaces ...string) (map[string]string, error) {
|
func (s sdk) GetPublicIPs(ctx context.Context, interfaces ...string) (map[string]string, error) {
|
||||||
desc, err := s.EC2.DescribeNetworkInterfaces(&ec2.DescribeNetworkInterfacesInput{
|
var token *string
|
||||||
|
publicIPs := map[string]string{}
|
||||||
|
for {
|
||||||
|
response, err := s.EC2.DescribeNetworkInterfaces(&ec2.DescribeNetworkInterfacesInput{
|
||||||
NetworkInterfaceIds: aws.StringSlice(interfaces),
|
NetworkInterfaceIds: aws.StringSlice(interfaces),
|
||||||
})
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
publicIPs := map[string]string{}
|
for _, interf := range response.NetworkInterfaces {
|
||||||
for _, interf := range desc.NetworkInterfaces {
|
|
||||||
if interf.Association != nil {
|
if interf.Association != nil {
|
||||||
publicIPs[aws.StringValue(interf.NetworkInterfaceId)] = aws.StringValue(interf.Association.PublicIp)
|
publicIPs[aws.StringValue(interf.NetworkInterfaceId)] = aws.StringValue(interf.Association.PublicIp)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if token == response.NextToken {
|
||||||
return publicIPs, nil
|
return publicIPs, nil
|
||||||
}
|
}
|
||||||
|
token = response.NextToken
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func (s sdk) ResolveLoadBalancer(ctx context.Context, nameOrarn string) (awsResource, string, error) {
|
func (s sdk) ResolveLoadBalancer(ctx context.Context, nameOrarn string) (awsResource, string, error) {
|
||||||
logrus.Debug("Check if LoadBalancer exists: ", nameOrarn)
|
logrus.Debug("Check if LoadBalancer exists: ", nameOrarn)
|
||||||
|
|
Loading…
Reference in New Issue