Swagger-baser server REST API interface
[ric-plt/appmgr.git] / pkg / util / util.go
diff --git a/pkg/util/util.go b/pkg/util/util.go
new file mode 100755 (executable)
index 0000000..8ea4d40
--- /dev/null
@@ -0,0 +1,68 @@
+/*
+==================================================================================
+  Copyright (c) 2019 AT&T Intellectual Property.
+  Copyright (c) 2019 Nokia
+
+   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 util
+
+import (
+       "bytes"
+       "errors"
+       "github.com/spf13/viper"
+       "os"
+       "os/exec"
+       "strings"
+       "time"
+
+       "gerrit.oran-osc.org/r/ric-plt/appmgr/pkg/appmgr"
+)
+
+var execCommand = exec.Command
+
+func Exec(args string) (out []byte, err error) {
+       cmd := execCommand("/bin/sh", "-c", args)
+
+       var stdout bytes.Buffer
+       var stderr bytes.Buffer
+       cmd.Stdout = &stdout
+       cmd.Stderr = &stderr
+
+       appmgr.Logger.Info("Running command: %s ", cmd.Args)
+       for i := 0; i < viper.GetInt("helm.retry"); i++ {
+               if err = cmd.Run(); err != nil {
+                       appmgr.Logger.Error("Command failed: %v - %s, retrying", err.Error(), stderr.String())
+                       time.Sleep(time.Duration(2) * time.Second)
+                       continue
+               }
+               break
+       }
+
+       if err == nil && !strings.HasSuffix(os.Args[0], ".test") {
+               appmgr.Logger.Info("command success: %s", stdout.String())
+               return stdout.Bytes(), nil
+       }
+
+       return stdout.Bytes(), errors.New(stderr.String())
+}
+
+var HelmExec = func(args string) (out []byte, err error) {
+       return Exec(strings.Join([]string{"helm", args}, " "))
+}
+
+var KubectlExec = func(args string) (out []byte, err error) {
+       return Exec(strings.Join([]string{"kubectl", args}, " "))
+}