From cfa645286382338d34739e6c39a80dc30494cfe2 Mon Sep 17 00:00:00 2001 From: Tobie Morgan Hitchcock Date: Thu, 16 Nov 2017 19:28:41 +0000 Subject: [PATCH] Improve import and export cli command error parsing --- cli/export.go | 28 +++++++++++++++++++++++----- cli/import.go | 28 +++++++++++++++++++++++----- 2 files changed, 46 insertions(+), 10 deletions(-) diff --git a/cli/export.go b/cli/export.go index 76316ad5..82d13ea9 100644 --- a/cli/export.go +++ b/cli/export.go @@ -20,6 +20,8 @@ import ( "net/http" "os" + "io/ioutil" + "github.com/spf13/cobra" "github.com/abcum/surreal/log" @@ -63,7 +65,7 @@ var exportCmd = &cobra.Command{ // and specify the authentication header using // basic auth for root login. - url := fmt.Sprintf("http://%s@%s:%s/export", opts.Auth.Auth, opts.DB.Host, opts.DB.Port) + url := fmt.Sprintf("https://%s@%s:%s/export", opts.Auth.Auth, opts.DB.Host, opts.DB.Port) // Create a new http request object that we // can use to connect to the export endpoint @@ -89,12 +91,28 @@ var exportCmd = &cobra.Command{ return } - // Ensure that we received a http 200 status + // Ensure that we close the body, otherwise + // if the Body is not closed, the Client can + // not use the underlying transport again. + + defer res.Body.Close() + + // Ensure that we didn't receive a 401 status // code back from the server, otherwise there // was a problem with our authentication. + if res.StatusCode == 401 { + log.Fatalln("Authentication failed - check the connection details and try again.") + return + } + + // Ensure that we received a http 200 status + // code back from the server, otherwise there + // was a problem with our request. + if res.StatusCode != 200 { - log.Fatalln("Connection failed - check the connection details and try again.") + bdy, _ := ioutil.ReadAll(res.Body) + log.Fatalf("%s", bdy) return } @@ -115,7 +133,7 @@ var exportCmd = &cobra.Command{ func init() { exportCmd.PersistentFlags().StringVar(&opts.Auth.Auth, "auth", "root:root", "Master authentication details to use when connecting.") - exportCmd.PersistentFlags().StringVar(&opts.DB.Host, "host", "127.0.0.1", "Database server host to connect to.") - exportCmd.PersistentFlags().StringVar(&opts.DB.Port, "port", "8000", "Database server port to connect to.") + exportCmd.PersistentFlags().StringVar(&opts.DB.Host, "host", "surreal.io", "Database server host to connect to.") + exportCmd.PersistentFlags().StringVar(&opts.DB.Port, "port", "80", "Database server port to connect to.") } diff --git a/cli/import.go b/cli/import.go index cd47f6b4..a39e9645 100644 --- a/cli/import.go +++ b/cli/import.go @@ -19,6 +19,8 @@ import ( "net/http" "os" + "io/ioutil" + "github.com/spf13/cobra" "github.com/abcum/surreal/log" @@ -62,7 +64,7 @@ var importCmd = &cobra.Command{ // and specify the authentication header using // basic auth for root login. - url := fmt.Sprintf("http://%s@%s:%s/import", opts.Auth.Auth, opts.DB.Host, opts.DB.Port) + url := fmt.Sprintf("https://%s@%s:%s/import", opts.Auth.Auth, opts.DB.Host, opts.DB.Port) // Create a new http request object that we // can use to connect to the import endpoint @@ -88,12 +90,28 @@ var importCmd = &cobra.Command{ return } - // Ensure that we received a http 200 status + // Ensure that we close the body, otherwise + // if the Body is not closed, the Client can + // not use the underlying transport again. + + defer res.Body.Close() + + // Ensure that we didn't receive a 401 status // code back from the server, otherwise there // was a problem with our authentication. + if res.StatusCode == 401 { + log.Fatalln("Authentication failed - check the connection details and try again.") + return + } + + // Ensure that we received a http 200 status + // code back from the server, otherwise there + // was a problem with our request. + if res.StatusCode != 200 { - log.Fatalln("Connection failed - check the connection details and try again.") + bdy, _ := ioutil.ReadAll(res.Body) + log.Fatalf("%s", bdy) return } @@ -105,7 +123,7 @@ var importCmd = &cobra.Command{ func init() { importCmd.PersistentFlags().StringVar(&opts.Auth.Auth, "auth", "root:root", "Master authentication details to use when connecting.") - importCmd.PersistentFlags().StringVar(&opts.DB.Host, "host", "127.0.0.1", "Database server host to connect to.") - importCmd.PersistentFlags().StringVar(&opts.DB.Port, "port", "8000", "Database server port to connect to.") + importCmd.PersistentFlags().StringVar(&opts.DB.Host, "host", "surreal.io", "Database server host to connect to.") + importCmd.PersistentFlags().StringVar(&opts.DB.Port, "port", "80", "Database server port to connect to.") }