From ce255d233a850642a51221ca651659421e2f8949 Mon Sep 17 00:00:00 2001 From: "jan.hajek@zerops.io" Date: Mon, 18 Mar 2024 20:53:41 +0100 Subject: [PATCH 1/2] fix: load service by name --- src/cmd/scope/scopeService.go | 5 +---- src/cmd/servicePush.go | 1 - src/entity/repository/service.go | 15 ++++++++++++--- src/errorsx/userError.go | 4 ---- src/i18n/en.go | 2 +- src/i18n/i18n.go | 2 +- 6 files changed, 15 insertions(+), 14 deletions(-) diff --git a/src/cmd/scope/scopeService.go b/src/cmd/scope/scopeService.go index f547b36f..48377065 100644 --- a/src/cmd/scope/scopeService.go +++ b/src/cmd/scope/scopeService.go @@ -36,10 +36,7 @@ func (s *service) LoadSelectedScope(ctx context.Context, _ *cmdBuilder.Cmd, cmdD if serviceIdOrName, exists := cmdData.Args[ServiceArgName]; exists { service, err = repository.GetServiceByIdOrName(ctx, cmdData.RestApiClient, cmdData.Project.ID, serviceIdOrName[0]) if err != nil { - return errorsx.Convert( - err, - errorsx.ConvertInvalidUserInput("id", i18n.T(i18n.ErrorInvalidServiceIdOrName)), - ) + return err } } diff --git a/src/cmd/servicePush.go b/src/cmd/servicePush.go index 06c810a2..c9bddeda 100644 --- a/src/cmd/servicePush.go +++ b/src/cmd/servicePush.go @@ -149,7 +149,6 @@ func servicePushCmd() *cmdBuilder.Cmd { }, body.PutAppVersionBuildAndDeploy{ ZeropsYaml: types.MediumText(configContent), - Source: types.NewStringNull("CLI"), }, ) if err != nil { diff --git a/src/entity/repository/service.go b/src/entity/repository/service.go index 60bfcd41..8016596b 100644 --- a/src/entity/repository/service.go +++ b/src/entity/repository/service.go @@ -5,10 +5,12 @@ import ( "github.com/zeropsio/zcli/src/entity" "github.com/zeropsio/zcli/src/errorsx" + "github.com/zeropsio/zcli/src/i18n" "github.com/zeropsio/zcli/src/zeropsRestApiClient" "github.com/zeropsio/zerops-go/dto/input/body" "github.com/zeropsio/zerops-go/dto/input/path" "github.com/zeropsio/zerops-go/dto/output" + "github.com/zeropsio/zerops-go/errorCode" "github.com/zeropsio/zerops-go/types" "github.com/zeropsio/zerops-go/types/uuid" ) @@ -19,17 +21,24 @@ func GetServiceByIdOrName( projectId uuid.ProjectId, serviceIdOrName string, ) (*entity.Service, error) { + service, err := GetServiceById(ctx, restApiClient, uuid.ServiceStackId(serviceIdOrName)) if err != nil { - if errorsx.IsUserError(err) { + if errorsx.Check(err, + errorsx.CheckErrorCode(errorCode.InvalidUserInput), + errorsx.CheckErrorCode(errorCode.ServiceStackNotFound), + ) { service, err = GetServiceByName(ctx, restApiClient, projectId, types.String(serviceIdOrName)) if err != nil { - return nil, err + return nil, errorsx.Convert( + err, + errorsx.ConvertErrorCode(errorCode.ServiceStackNotFound, i18n.T(i18n.ErrorServiceNotFound, serviceIdOrName)), + ) } } } - return service, err + return service, nil } func GetServiceById( diff --git a/src/errorsx/userError.go b/src/errorsx/userError.go index e9ab2f99..f1992d79 100644 --- a/src/errorsx/userError.go +++ b/src/errorsx/userError.go @@ -16,10 +16,6 @@ func NewUserError(message string, previous error) *UserError { } } -func IsUserError(err error) bool { - return AsUserError(err) != nil -} - func AsUserError(err error) *UserError { var userError *UserError if errors.As(err, &userError) { diff --git a/src/i18n/en.go b/src/i18n/en.go index 49e9d126..2c74d871 100644 --- a/src/i18n/en.go +++ b/src/i18n/en.go @@ -232,5 +232,5 @@ more info: https://docs.zerops.io/documentation/cli/authorization.html`, ErrorInvalidProjectId: "Invalid project ID [%s]", ErrorInvalidScopedProjectId: "Invalid ID of the scoped project [%s], select a different project using `zcli scope project` command.", ErrorInvalidServiceId: "Invalid service ID [%s]", - ErrorInvalidServiceIdOrName: "Invalid service ID or name [%s]", + ErrorServiceNotFound: "Service [%s] not found", } diff --git a/src/i18n/i18n.go b/src/i18n/i18n.go index 381a2f03..aadad0a4 100644 --- a/src/i18n/i18n.go +++ b/src/i18n/i18n.go @@ -242,5 +242,5 @@ const ( ErrorInvalidProjectId = "ErrorInvalidProjectId" ErrorInvalidScopedProjectId = "ErrorInvalidScopedProjectId" ErrorInvalidServiceId = "ErrorInvalidServiceId" - ErrorInvalidServiceIdOrName = "ErrorInvalidServiceIdOrName" + ErrorServiceNotFound = "ErrorServiceNotFound" ) From 61365b6d3a71058bd1aa3b9ab95bf8928b5c41c0 Mon Sep 17 00:00:00 2001 From: "jan.hajek@zerops.io" Date: Mon, 18 Mar 2024 20:59:07 +0100 Subject: [PATCH 2/2] fix linter --- src/entity/repository/service.go | 1 - 1 file changed, 1 deletion(-) diff --git a/src/entity/repository/service.go b/src/entity/repository/service.go index 8016596b..4ba908eb 100644 --- a/src/entity/repository/service.go +++ b/src/entity/repository/service.go @@ -21,7 +21,6 @@ func GetServiceByIdOrName( projectId uuid.ProjectId, serviceIdOrName string, ) (*entity.Service, error) { - service, err := GetServiceById(ctx, restApiClient, uuid.ServiceStackId(serviceIdOrName)) if err != nil { if errorsx.Check(err,