-
Notifications
You must be signed in to change notification settings - Fork 176
/
run.go
70 lines (62 loc) · 2.01 KB
/
run.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
// Copyright 2020 ZUP IT SERVICOS EM TECNOLOGIA E INOVACAO SA
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package run
import (
"github.com/ZupIT/horusec/development-kit/pkg/cli_standard/config"
"github.com/ZupIT/horusec/development-kit/pkg/cli_standard/internal/helpers/messages"
"github.com/ZupIT/horusec/development-kit/pkg/cli_standard/internal/usecases/cli"
"github.com/ZupIT/horusec/development-kit/pkg/utils/logger"
"github.com/spf13/cobra"
)
type Run struct {
controller IController
configs *config.Config
useCases cli.Interface
}
type IController interface {
StartAnalysis() error
}
type ICommand interface {
CreateCobraCmd() *cobra.Command
}
func NewRunCommand(configs *config.Config, controller IController) ICommand {
return &Run{
useCases: cli.NewCLIUseCases(),
controller: controller,
configs: configs,
}
}
func (r *Run) CreateCobraCmd() *cobra.Command {
cmd := &cobra.Command{
Use: "run",
RunE: r.runECobraCmd,
}
return cmd
}
func (r *Run) runECobraCmd(cmd *cobra.Command, _ []string) error {
if err := r.useCases.ValidateConfigs(r.configs); err != nil {
logger.LogErrorWithLevel(messages.MsgErrorInvalidConfigs, err)
_ = cmd.Help()
return err
}
r.configs = r.useCases.NormalizeConfigs(r.configs)
logger.LogDebugWithLevel(messages.MsgDebugConfigWasValidated, r.configs)
err := r.controller.StartAnalysis()
if err != nil {
logger.LogErrorWithLevel(messages.MsgErrorAnalysisFinished, err)
} else {
logger.LogDebugWithLevel(messages.MsgDebugAnalysisFinished)
}
return err
}