From 0d3c3a73860113c953662472f70de0f5e24c33db Mon Sep 17 00:00:00 2001 From: Tiffany Wang Date: Tue, 10 Dec 2024 02:36:04 -0800 Subject: [PATCH] fix after rebase --- .../ecs-agent/ec2/ec2_client.go | 9 +- .../ecs-agent/ec2/mocks/ec2_mocks.go | 2 +- ecs-agent/ec2/ec2_client.go | 9 +- ecs-agent/ec2/mocks/ec2_mocks.go | 2 +- .../private/protocol/jsonrpc/jsonrpc.go | 87 ---------- .../protocol/jsonrpc/unmarshal_error.go | 160 ------------------ ecs-agent/vendor/modules.txt | 1 - 7 files changed, 12 insertions(+), 258 deletions(-) delete mode 100644 ecs-agent/vendor/github.com/aws/aws-sdk-go/private/protocol/jsonrpc/jsonrpc.go delete mode 100644 ecs-agent/vendor/github.com/aws/aws-sdk-go/private/protocol/jsonrpc/unmarshal_error.go diff --git a/agent/vendor/github.com/aws/amazon-ecs-agent/ecs-agent/ec2/ec2_client.go b/agent/vendor/github.com/aws/amazon-ecs-agent/ecs-agent/ec2/ec2_client.go index 5314ccef351..bfe97c109c1 100644 --- a/agent/vendor/github.com/aws/amazon-ecs-agent/ecs-agent/ec2/ec2_client.go +++ b/agent/vendor/github.com/aws/amazon-ecs-agent/ecs-agent/ec2/ec2_client.go @@ -25,6 +25,7 @@ import ( "github.com/aws/aws-sdk-go-v2/config" ec2sdk "github.com/aws/aws-sdk-go-v2/service/ec2" "github.com/aws/aws-sdk-go-v2/service/ec2/types" + ecstypes "github.com/aws/aws-sdk-go-v2/service/ecs/types" ) const ( @@ -41,7 +42,7 @@ const ( type Client interface { CreateTags(input *ec2sdk.CreateTagsInput) (*ec2sdk.CreateTagsOutput, error) - DescribeECSTagsForInstance(instanceID string) ([]types.Tag, error) + DescribeECSTagsForInstance(instanceID string) ([]ecstypes.Tag, error) } type ClientSDK interface { @@ -82,7 +83,7 @@ func (c *ClientImpl) SetClientSDK(sdk ClientSDK) { // DescribeECSTagsForInstance calls DescribeTags API to get the EC2 tags of the // instance id, and return it back as ECS tags -func (c *ClientImpl) DescribeECSTagsForInstance(instanceID string) ([]types.Tag, error) { +func (c *ClientImpl) DescribeECSTagsForInstance(instanceID string) ([]ecstypes.Tag, error) { describeTagsInput := ec2sdk.DescribeTagsInput{ Filters: []types.Filter{ { @@ -103,13 +104,13 @@ func (c *ClientImpl) DescribeECSTagsForInstance(instanceID string) ([]types.Tag, return nil, err } - var tags []types.Tag + var tags []ecstypes.Tag // Convert ec2 tags to ecs tags for _, ec2Tag := range res.Tags { // Filter out all tags "aws:" prefix if !strings.HasPrefix(strings.ToLower(aws.ToString(ec2Tag.Key)), awsTagPrefix) && !strings.HasPrefix(strings.ToLower(aws.ToString(ec2Tag.Value)), awsTagPrefix) { - tags = append(tags, types.Tag{ + tags = append(tags, ecstypes.Tag{ Key: ec2Tag.Key, Value: ec2Tag.Value, }) diff --git a/agent/vendor/github.com/aws/amazon-ecs-agent/ecs-agent/ec2/mocks/ec2_mocks.go b/agent/vendor/github.com/aws/amazon-ecs-agent/ecs-agent/ec2/mocks/ec2_mocks.go index 3c8ef7e9c10..2cf39bafba4 100644 --- a/agent/vendor/github.com/aws/amazon-ecs-agent/ecs-agent/ec2/mocks/ec2_mocks.go +++ b/agent/vendor/github.com/aws/amazon-ecs-agent/ecs-agent/ec2/mocks/ec2_mocks.go @@ -25,7 +25,7 @@ import ( ec2 "github.com/aws/amazon-ecs-agent/ecs-agent/ec2" imds "github.com/aws/aws-sdk-go-v2/feature/ec2/imds" ec20 "github.com/aws/aws-sdk-go-v2/service/ec2" - types "github.com/aws/aws-sdk-go-v2/service/ec2/types" + types "github.com/aws/aws-sdk-go-v2/service/ecs/types" gomock "github.com/golang/mock/gomock" ) diff --git a/ecs-agent/ec2/ec2_client.go b/ecs-agent/ec2/ec2_client.go index 5314ccef351..bfe97c109c1 100644 --- a/ecs-agent/ec2/ec2_client.go +++ b/ecs-agent/ec2/ec2_client.go @@ -25,6 +25,7 @@ import ( "github.com/aws/aws-sdk-go-v2/config" ec2sdk "github.com/aws/aws-sdk-go-v2/service/ec2" "github.com/aws/aws-sdk-go-v2/service/ec2/types" + ecstypes "github.com/aws/aws-sdk-go-v2/service/ecs/types" ) const ( @@ -41,7 +42,7 @@ const ( type Client interface { CreateTags(input *ec2sdk.CreateTagsInput) (*ec2sdk.CreateTagsOutput, error) - DescribeECSTagsForInstance(instanceID string) ([]types.Tag, error) + DescribeECSTagsForInstance(instanceID string) ([]ecstypes.Tag, error) } type ClientSDK interface { @@ -82,7 +83,7 @@ func (c *ClientImpl) SetClientSDK(sdk ClientSDK) { // DescribeECSTagsForInstance calls DescribeTags API to get the EC2 tags of the // instance id, and return it back as ECS tags -func (c *ClientImpl) DescribeECSTagsForInstance(instanceID string) ([]types.Tag, error) { +func (c *ClientImpl) DescribeECSTagsForInstance(instanceID string) ([]ecstypes.Tag, error) { describeTagsInput := ec2sdk.DescribeTagsInput{ Filters: []types.Filter{ { @@ -103,13 +104,13 @@ func (c *ClientImpl) DescribeECSTagsForInstance(instanceID string) ([]types.Tag, return nil, err } - var tags []types.Tag + var tags []ecstypes.Tag // Convert ec2 tags to ecs tags for _, ec2Tag := range res.Tags { // Filter out all tags "aws:" prefix if !strings.HasPrefix(strings.ToLower(aws.ToString(ec2Tag.Key)), awsTagPrefix) && !strings.HasPrefix(strings.ToLower(aws.ToString(ec2Tag.Value)), awsTagPrefix) { - tags = append(tags, types.Tag{ + tags = append(tags, ecstypes.Tag{ Key: ec2Tag.Key, Value: ec2Tag.Value, }) diff --git a/ecs-agent/ec2/mocks/ec2_mocks.go b/ecs-agent/ec2/mocks/ec2_mocks.go index 3c8ef7e9c10..2cf39bafba4 100644 --- a/ecs-agent/ec2/mocks/ec2_mocks.go +++ b/ecs-agent/ec2/mocks/ec2_mocks.go @@ -25,7 +25,7 @@ import ( ec2 "github.com/aws/amazon-ecs-agent/ecs-agent/ec2" imds "github.com/aws/aws-sdk-go-v2/feature/ec2/imds" ec20 "github.com/aws/aws-sdk-go-v2/service/ec2" - types "github.com/aws/aws-sdk-go-v2/service/ec2/types" + types "github.com/aws/aws-sdk-go-v2/service/ecs/types" gomock "github.com/golang/mock/gomock" ) diff --git a/ecs-agent/vendor/github.com/aws/aws-sdk-go/private/protocol/jsonrpc/jsonrpc.go b/ecs-agent/vendor/github.com/aws/aws-sdk-go/private/protocol/jsonrpc/jsonrpc.go deleted file mode 100644 index d9aa271148d..00000000000 --- a/ecs-agent/vendor/github.com/aws/aws-sdk-go/private/protocol/jsonrpc/jsonrpc.go +++ /dev/null @@ -1,87 +0,0 @@ -// Package jsonrpc provides JSON RPC utilities for serialization of AWS -// requests and responses. -package jsonrpc - -//go:generate go run -tags codegen ../../../private/model/cli/gen-protocol-tests ../../../models/protocol_tests/input/json.json build_test.go -//go:generate go run -tags codegen ../../../private/model/cli/gen-protocol-tests ../../../models/protocol_tests/output/json.json unmarshal_test.go - -import ( - "github.com/aws/aws-sdk-go/aws/awserr" - "github.com/aws/aws-sdk-go/aws/request" - "github.com/aws/aws-sdk-go/private/protocol/json/jsonutil" - "github.com/aws/aws-sdk-go/private/protocol/rest" -) - -var emptyJSON = []byte("{}") - -// BuildHandler is a named request handler for building jsonrpc protocol -// requests -var BuildHandler = request.NamedHandler{ - Name: "awssdk.jsonrpc.Build", - Fn: Build, -} - -// UnmarshalHandler is a named request handler for unmarshaling jsonrpc -// protocol requests -var UnmarshalHandler = request.NamedHandler{ - Name: "awssdk.jsonrpc.Unmarshal", - Fn: Unmarshal, -} - -// UnmarshalMetaHandler is a named request handler for unmarshaling jsonrpc -// protocol request metadata -var UnmarshalMetaHandler = request.NamedHandler{ - Name: "awssdk.jsonrpc.UnmarshalMeta", - Fn: UnmarshalMeta, -} - -// Build builds a JSON payload for a JSON RPC request. -func Build(req *request.Request) { - var buf []byte - var err error - if req.ParamsFilled() { - buf, err = jsonutil.BuildJSON(req.Params) - if err != nil { - req.Error = awserr.New(request.ErrCodeSerialization, "failed encoding JSON RPC request", err) - return - } - } else { - buf = emptyJSON - } - - // Always serialize the body, don't suppress it. - req.SetBufferBody(buf) - - if req.ClientInfo.TargetPrefix != "" { - target := req.ClientInfo.TargetPrefix + "." + req.Operation.Name - req.HTTPRequest.Header.Add("X-Amz-Target", target) - } - - // Only set the content type if one is not already specified and an - // JSONVersion is specified. - if ct, v := req.HTTPRequest.Header.Get("Content-Type"), req.ClientInfo.JSONVersion; len(ct) == 0 && len(v) != 0 { - jsonVersion := req.ClientInfo.JSONVersion - req.HTTPRequest.Header.Set("Content-Type", "application/x-amz-json-"+jsonVersion) - } -} - -// Unmarshal unmarshals a response for a JSON RPC service. -func Unmarshal(req *request.Request) { - defer req.HTTPResponse.Body.Close() - if req.DataFilled() { - err := jsonutil.UnmarshalJSON(req.Data, req.HTTPResponse.Body) - if err != nil { - req.Error = awserr.NewRequestFailure( - awserr.New(request.ErrCodeSerialization, "failed decoding JSON RPC response", err), - req.HTTPResponse.StatusCode, - req.RequestID, - ) - } - } - return -} - -// UnmarshalMeta unmarshals headers from a response for a JSON RPC service. -func UnmarshalMeta(req *request.Request) { - rest.UnmarshalMeta(req) -} diff --git a/ecs-agent/vendor/github.com/aws/aws-sdk-go/private/protocol/jsonrpc/unmarshal_error.go b/ecs-agent/vendor/github.com/aws/aws-sdk-go/private/protocol/jsonrpc/unmarshal_error.go deleted file mode 100644 index 9c1ccde54ae..00000000000 --- a/ecs-agent/vendor/github.com/aws/aws-sdk-go/private/protocol/jsonrpc/unmarshal_error.go +++ /dev/null @@ -1,160 +0,0 @@ -package jsonrpc - -import ( - "bytes" - "io" - "io/ioutil" - "net/http" - "strings" - - "github.com/aws/aws-sdk-go/aws/awserr" - "github.com/aws/aws-sdk-go/aws/request" - "github.com/aws/aws-sdk-go/private/protocol" - "github.com/aws/aws-sdk-go/private/protocol/json/jsonutil" -) - -const ( - awsQueryError = "x-amzn-query-error" - // A valid header example - "x-amzn-query-error": ";" - awsQueryErrorPartsCount = 2 -) - -// UnmarshalTypedError provides unmarshaling errors API response errors -// for both typed and untyped errors. -type UnmarshalTypedError struct { - exceptions map[string]func(protocol.ResponseMetadata) error - queryExceptions map[string]func(protocol.ResponseMetadata, string) error -} - -// NewUnmarshalTypedError returns an UnmarshalTypedError initialized for the -// set of exception names to the error unmarshalers -func NewUnmarshalTypedError(exceptions map[string]func(protocol.ResponseMetadata) error) *UnmarshalTypedError { - return &UnmarshalTypedError{ - exceptions: exceptions, - queryExceptions: map[string]func(protocol.ResponseMetadata, string) error{}, - } -} - -// NewUnmarshalTypedErrorWithOptions works similar to NewUnmarshalTypedError applying options to the UnmarshalTypedError -// before returning it -func NewUnmarshalTypedErrorWithOptions(exceptions map[string]func(protocol.ResponseMetadata) error, optFns ...func(*UnmarshalTypedError)) *UnmarshalTypedError { - unmarshaledError := NewUnmarshalTypedError(exceptions) - for _, fn := range optFns { - fn(unmarshaledError) - } - return unmarshaledError -} - -// WithQueryCompatibility is a helper function to construct a functional option for use with NewUnmarshalTypedErrorWithOptions. -// The queryExceptions given act as an override for unmarshalling errors when query compatible error codes are found. -// See also [awsQueryCompatible trait] -// -// [awsQueryCompatible trait]: https://smithy.io/2.0/aws/protocols/aws-query-protocol.html#aws-protocols-awsquerycompatible-trait -func WithQueryCompatibility(queryExceptions map[string]func(protocol.ResponseMetadata, string) error) func(*UnmarshalTypedError) { - return func(typedError *UnmarshalTypedError) { - typedError.queryExceptions = queryExceptions - } -} - -// UnmarshalError attempts to unmarshal the HTTP response error as a known -// error type. If unable to unmarshal the error type, the generic SDK error -// type will be used. -func (u *UnmarshalTypedError) UnmarshalError( - resp *http.Response, - respMeta protocol.ResponseMetadata, -) (error, error) { - - var buf bytes.Buffer - var jsonErr jsonErrorResponse - teeReader := io.TeeReader(resp.Body, &buf) - err := jsonutil.UnmarshalJSONError(&jsonErr, teeReader) - if err != nil { - return nil, err - } - body := ioutil.NopCloser(&buf) - - // Code may be separated by hash(#), with the last element being the code - // used by the SDK. - codeParts := strings.SplitN(jsonErr.Code, "#", 2) - code := codeParts[len(codeParts)-1] - msg := jsonErr.Message - - queryCodeParts := queryCodeParts(resp, u) - - if fn, ok := u.exceptions[code]; ok { - // If query-compatible exceptions are found and query-error-header is found, - // then use associated constructor to get exception with query error code. - // - // If exception code is known, use associated constructor to get a value - // for the exception that the JSON body can be unmarshaled into. - var v error - queryErrFn, queryExceptionsFound := u.queryExceptions[code] - if len(queryCodeParts) == awsQueryErrorPartsCount && queryExceptionsFound { - v = queryErrFn(respMeta, queryCodeParts[0]) - } else { - v = fn(respMeta) - } - err := jsonutil.UnmarshalJSONCaseInsensitive(v, body) - if err != nil { - return nil, err - } - return v, nil - } - - if len(queryCodeParts) == awsQueryErrorPartsCount && len(u.queryExceptions) > 0 { - code = queryCodeParts[0] - } - - // fallback to unmodeled generic exceptions - return awserr.NewRequestFailure( - awserr.New(code, msg, nil), - respMeta.StatusCode, - respMeta.RequestID, - ), nil -} - -// A valid header example - "x-amzn-query-error": ";" -func queryCodeParts(resp *http.Response, u *UnmarshalTypedError) []string { - queryCodeHeader := resp.Header.Get(awsQueryError) - var queryCodeParts []string - if queryCodeHeader != "" && len(u.queryExceptions) > 0 { - queryCodeParts = strings.Split(queryCodeHeader, ";") - } - return queryCodeParts -} - -// UnmarshalErrorHandler is a named request handler for unmarshaling jsonrpc -// protocol request errors -var UnmarshalErrorHandler = request.NamedHandler{ - Name: "awssdk.jsonrpc.UnmarshalError", - Fn: UnmarshalError, -} - -// UnmarshalError unmarshals an error response for a JSON RPC service. -func UnmarshalError(req *request.Request) { - defer req.HTTPResponse.Body.Close() - - var jsonErr jsonErrorResponse - err := jsonutil.UnmarshalJSONError(&jsonErr, req.HTTPResponse.Body) - if err != nil { - req.Error = awserr.NewRequestFailure( - awserr.New(request.ErrCodeSerialization, - "failed to unmarshal error message", err), - req.HTTPResponse.StatusCode, - req.RequestID, - ) - return - } - - codes := strings.SplitN(jsonErr.Code, "#", 2) - req.Error = awserr.NewRequestFailure( - awserr.New(codes[len(codes)-1], jsonErr.Message, nil), - req.HTTPResponse.StatusCode, - req.RequestID, - ) -} - -type jsonErrorResponse struct { - Code string `json:"__type"` - Message string `json:"message"` -} diff --git a/ecs-agent/vendor/modules.txt b/ecs-agent/vendor/modules.txt index 16a854944b5..aae2917e1cd 100644 --- a/ecs-agent/vendor/modules.txt +++ b/ecs-agent/vendor/modules.txt @@ -60,7 +60,6 @@ github.com/aws/aws-sdk-go/internal/sync/singleflight github.com/aws/aws-sdk-go/private/model/api github.com/aws/aws-sdk-go/private/protocol github.com/aws/aws-sdk-go/private/protocol/json/jsonutil -github.com/aws/aws-sdk-go/private/protocol/jsonrpc github.com/aws/aws-sdk-go/private/protocol/rest github.com/aws/aws-sdk-go/private/protocol/xml/xmlutil github.com/aws/aws-sdk-go/private/util