diff --git a/pkg/extension/action_url.go b/pkg/extension/action_url.go index 72d35371e5d14603cba09b3c8f06629c3e3b1a55..c0285f1c8bf88aa96e04283a0f1287eaa28d6128 100644 --- a/pkg/extension/action_url.go +++ b/pkg/extension/action_url.go @@ -19,14 +19,7 @@ type ActionURL struct { // NewActionURL возвращает пустую структуру ActionURL, если передано пустое действие // при передаче в функцию действия - заполняет структуру func NewActionURL(action string) (*ActionURL, error) { - if action != "" { - parsedURL, err := parseActionURL(action) - if err != nil { - return nil, err - } - return parsedURL, nil - } - return &ActionURL{}, nil + return parseActionURL(action) } // ID возвращает сохраненный в ActionURL id действия @@ -34,8 +27,8 @@ func (p *ActionURL) ID() string { return p.actionID } -// ExtensionID возвращает сохраненный в ActionURL id расширения -func (p *ActionURL) ExtensionID() string { +// Extension возвращает сохраненный в ActionURL id расширения +func (p *ActionURL) Extension() string { return p.extensionID } @@ -46,6 +39,9 @@ func (p *ActionURL) Scheme() string { // parseActionURL функция для заполнения структуры ActionURL из переданного действия func parseActionURL(action string) (*ActionURL, error) { + if action == "" { + return &ActionURL{}, nil + } u, err := url.Parse(action) if err != nil { return nil, err diff --git a/pkg/extension/service/extension.go b/pkg/extension/service/extension.go index f57f8253965bf45225532a71a67c95fc38f3a735..5b9263e083b50b9ea901ad674046819160b4876b 100644 --- a/pkg/extension/service/extension.go +++ b/pkg/extension/service/extension.go @@ -161,7 +161,7 @@ func (s *Extension) Action(ctx context.Context, in *extension.ActionRequest) (*e if err != nil { return nil, err } - extensionID = actionURL.ExtensionID() + extensionID = actionURL.Extension() } ok, err := extension.CheckInstalled(ctx, s.Content, in.SpaceId, in.EnvId, extensionID) if err != nil {