-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.go
97 lines (93 loc) · 3.2 KB
/
main.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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
// Copyright © 2017 Kujtim Hoxha <[email protected]>
//
// 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 main
import (
"fmt"
"github.com/asaskevich/govalidator"
"github.com/kujtimiihoxha/plis/cmd"
"github.com/kujtimiihoxha/plis/config"
"github.com/kujtimiihoxha/plis/helpers"
"github.com/kujtimiihoxha/plis/logger"
"github.com/kujtimiihoxha/plis/tools"
"github.com/sirupsen/logrus"
"github.com/spf13/afero"
"github.com/spf13/viper"
"os"
"os/exec"
"os/user"
"path/filepath"
)
func main() {
setupConfigValidator()
configDefaults()
initFirstRun()
logger.SetLevel(logrus.WarnLevel)
tools.Initialize()
cmd.Execute()
}
func initFirstRun() {
checkGit()
cmd.RootCmd.PersistentFlags().BoolP("debug", "d", false, "Is plis debugging")
cmd.RootCmd.PersistentFlags().String("debug_folder", "", "Root folder of the debug mode")
viper.BindPFlag("plis.debug_folder", cmd.RootCmd.PersistentFlags().Lookup("debug_folder"))
var err error
if _, err = os.Stat(viper.GetString("plis.dir.root")); err == nil {
return
}
if os.IsNotExist(err) {
logger.GetLogger().Info("Plis root does not exist")
logger.GetLogger().Info("Initializing first run...")
logger.GetLogger().Info(fmt.Sprintf(
"Creating plis root in `%s`...",
viper.GetString("plis.dir.root")))
err := os.MkdirAll(viper.GetString("plis.dir.root")+afero.FilePathSeparator+"tools", os.ModePerm)
if err != nil {
logger.GetLogger().Fatal(err)
}
return
}
logger.GetLogger().Fatal(err)
}
func checkGit() {
cmd := exec.Command("git", "--version")
err := cmd.Run()
if err != nil {
logger.GetLogger().Fatal("Plis needs git to be installed please install git and try again.")
}
}
func configDefaults() {
usr, err := user.Current()
if err != nil {
logger.GetLogger().Fatal(err)
}
viper.Set("plis.dir.user", usr.HomeDir)
viper.Set("plis.dir.root", usr.HomeDir+string(filepath.Separator)+".plis")
viper.Set("plis.dir.tools", usr.HomeDir+string(filepath.Separator)+".plis"+
string(filepath.Separator)+"tools")
}
func setupConfigValidator() {
govalidator.SetNilPtrAllowedByRequired(true)
govalidator.CustomTypeTagMap.Set("inputType", govalidator.CustomTypeValidator(func(i interface{}, o interface{}) bool {
return helpers.StringInSlice(i.(string), config.InputTypes)
}))
govalidator.CustomTypeTagMap.Set("inputDefault", govalidator.CustomTypeValidator(func(i interface{}, o interface{}) bool {
return true
}))
govalidator.CustomTypeTagMap.Set("scriptType", govalidator.CustomTypeValidator(func(i interface{}, o interface{}) bool {
return helpers.StringInSlice(i.(string), config.ScriptTypes)
}))
govalidator.CustomTypeTagMap.Set("lenOne", govalidator.CustomTypeValidator(func(i interface{}, o interface{}) bool {
return len(i.(string)) <= 1
}))
}