From 65dadb7e51e206b6411a4518f8a26471d586bc6f Mon Sep 17 00:00:00 2001 From: feistel <6742251-feistel@users.noreply.gitlab.com> Date: Mon, 20 Sep 2021 08:19:41 +0000 Subject: refactor: unify instantiation of command.Shell --- cmd/gitlab-shell/command/command.go | 14 ++++++++++++++ 1 file changed, 14 insertions(+) (limited to 'cmd') diff --git a/cmd/gitlab-shell/command/command.go b/cmd/gitlab-shell/command/command.go index be54ac6..5f828cd 100644 --- a/cmd/gitlab-shell/command/command.go +++ b/cmd/gitlab-shell/command/command.go @@ -30,6 +30,20 @@ func New(arguments []string, env sshenv.Env, config *config.Config, readWriter * return nil, disallowedcommand.Error } +func NewWithKey(gitlabKeyId string, env sshenv.Env, config *config.Config, readWriter *readwriter.ReadWriter) (command.Command, error) { + args, err := Parse(nil, env) + if err != nil { + return nil, err + } + + args.GitlabKeyId = gitlabKeyId + if cmd := Build(args, config, readWriter); cmd != nil { + return cmd, nil + } + + return nil, disallowedcommand.Error +} + func Parse(arguments []string, env sshenv.Env) (*commandargs.Shell, error) { args := &commandargs.Shell{Arguments: arguments, Env: env} -- cgit v1.2.1