+func sdksInstall(ctx *cli.Context) error {
+ id := GetID(ctx)
+ file := ctx.String("file")
+ force := ctx.Bool("force")
+ shortOut := ctx.Bool("short")
+
+ if id == "" && file == "" {
+ return cli.NewExitError("id or file parameter or option must be set", 1)
+ }
+
+ // Process Socket IO events
+ type exitResult struct {
+ error string
+ code int
+ }
+ exitChan := make(chan exitResult, 1)
+
+ IOsk.On("disconnection", func(err error) {
+ Log.Debugf("WS disconnection event with err: %v\n", err)
+ errMsg := ""
+ if err != nil {
+ errMsg = err.Error()
+ }
+ exitChan <- exitResult{errMsg, 2}
+ })
+
+ IOsk.On(xaapiv1.EVTSDKManagement, func(ev xaapiv1.EventMsg) {
+ sdkEvt, _ := ev.DecodeSDKMgtMsg()
+
+ if sdkEvt.Action != xaapiv1.SdkMgtActionInstall {
+ Log.Debugf("EVTSDKManagement (action %s) IGNORED", sdkEvt.Action)
+ return
+ }
+
+ if !shortOut && sdkEvt.Stdout != "" {
+ fmt.Printf("%s", sdkEvt.Stdout)
+ }
+ if !shortOut && sdkEvt.Stderr != "" {
+ fmt.Fprintf(os.Stderr, "%s", sdkEvt.Stderr)
+ }
+
+ if sdkEvt.Exited {
+ exitChan <- exitResult{sdkEvt.Error, sdkEvt.Code}
+ }
+ })
+
+ IOsk.On(xaapiv1.EVTSDKStateChange, func(ev xaapiv1.EventMsg) {
+ sdk, _ := ev.DecodeSDKEvent()
+ Log.Debugf("EVTSDKStateChange: %v", sdk)
+ })
+
+ evReg := xaapiv1.EventRegisterArgs{Name: xaapiv1.EVTAll}
+ if err := HTTPCli.Post("/events/register", &evReg, nil); err != nil {
+ return cli.NewExitError(err, 1)
+ }
+
+ url := XdsServerComputeURL("/sdks")
+ sdks := xaapiv1.SDKInstallArgs{
+ ID: id,
+ Filename: file,
+ Force: force,
+ }
+
+ if ctx.Bool("debug") {
+ sdks.InstallArgs = []string{"--debug"}
+ }
+
+ newSdk := xaapiv1.SDK{}
+ if err := HTTPCli.Post(url, &sdks, &newSdk); err != nil {
+ return cli.NewExitError(err, 1)
+ }
+ Log.Debugf("Result of %s: %v", url, newSdk)
+ if !shortOut {
+ fmt.Printf("Installation of '%s' SDK successfully started.\n", newSdk.Name)
+ }
+
+ // TODO: trap CTRL+C and print question: "Installation of xxx is in progress, press 'a' to abort, 'b' to continue in background or 'c' to continue installation"
+
+ // Wait exit
+ select {
+ case res := <-exitChan:
+ if res.code == 0 {
+ Log.Debugln("Exit successfully")
+ if shortOut {
+ fmt.Println(newSdk.ID)
+ } else {
+ fmt.Println("SDK ID " + newSdk.ID + " successfully installed.")
+ }
+ }
+ if res.error != "" {
+ Log.Debugln("Exit with ERROR: ", res.error)
+ }
+ return cli.NewExitError(res.error, res.code)
+ }
+}
+
+func sdksUnInstall(ctx *cli.Context) error {
+ id := GetID(ctx)
+ if id == "" {
+ return cli.NewExitError("id parameter or option must be set", 1)
+ }
+
+ if !ctx.Bool("force") {
+ if !Confirm("Do you permanently remove SDK id '" + id + "' [yes/No] ? ") {
+ return nil
+ }
+ }
+
+ delSdk := xaapiv1.SDK{}
+ url := XdsServerComputeURL("/sdks/" + id)
+ if err := HTTPCli.Delete(url, &delSdk); err != nil {
+ return cli.NewExitError(err, 1)
+ }
+
+ Log.Debugf("Result of %s: %v", url, delSdk)
+
+ fmt.Println("SDK ID " + delSdk.ID + " successfully deleted.")
+ return nil