From 33282590490c799c99794b0d2089deae6531bcc3 Mon Sep 17 00:00:00 2001 From: Anupam Pokharel <120498245+tonystarkjr3@users.noreply.github.com> Date: Thu, 14 Mar 2024 08:10:49 -0500 Subject: [PATCH] Feat: Add config SSO option (#377) and bump version (#396) * Feat: Add config SSO option (#377) * added sso style entry * style to type for SSO * setBasicAuth * Win unit test (#355) * Fixed unit tests so they work in windows environments * Removed dead imports * adding Connection close header in http requests of our golang client (#372) Co-authored-by: Anupam Pokharel * Adds PrintCsv() function and unit tests to bluemix/terminal/table (#352) * added PrintCsv() function and unit tests to bluemix/terminal/table * Added handled errors to function PrintCsv * Added unit test for empty table in function PrintCsv * Added translations for error message and returned it --------- Co-authored-by: Aerex * chore: add csv messages to i18n (#373) * chore: bump version to 1.1.0 (#374) * Add recommendation to use Cobra (#368) * Add recommendation to use Cobra * dummy commit --------- Co-authored-by: steveclay * chore: bump packages for vulnerabilities (#376) * docs: added building section for building architectures * docs: improved description on building architectures * docs: Removed extraneous info for architecture requirements * chore(security): resolved vulnerability by updating golang.org/x/net * chore: bumped to 1.1.1 (#380) --------- Co-authored-by: Anupam Pokharel Co-authored-by: Christopher Gallo Co-authored-by: edsonarios Co-authored-by: Aerex Co-authored-by: steveclay Co-authored-by: lmosca * bump version (#398) --------- Co-authored-by: Anupam Pokharel Co-authored-by: Christopher Gallo Co-authored-by: edsonarios Co-authored-by: Aerex Co-authored-by: steveclay Co-authored-by: lmosca --- .../configuration/core_config/bx_config.go | 14 ++++ .../configuration/core_config/repository.go | 2 + bluemix/version.go | 2 +- common/rest/request.go | 84 ++++++++++++------- 4 files changed, 69 insertions(+), 33 deletions(-) diff --git a/bluemix/configuration/core_config/bx_config.go b/bluemix/configuration/core_config/bx_config.go index 907740f..40b3d36 100644 --- a/bluemix/configuration/core_config/bx_config.go +++ b/bluemix/configuration/core_config/bx_config.go @@ -55,6 +55,7 @@ type BXConfigData struct { Trace string ColorEnabled string HTTPTimeout int + TypeOfSSO string CLIInfoEndpoint string // overwrite the cli info endpoint CheckCLIVersionDisabled bool UsageStatsDisabled bool // deprecated: use UsageStatsEnabled @@ -412,6 +413,13 @@ func (c *bxConfig) ColorEnabled() (enabled string) { return } +func (c *bxConfig) TypeOfSSO() (style string) { + c.read(func() { + style = c.data.TypeOfSSO + }) + return +} + func (c *bxConfig) HTTPTimeout() (timeout int) { c.read(func() { timeout = c.data.HTTPTimeout @@ -639,6 +647,12 @@ func (c *bxConfig) SetHTTPTimeout(timeout int) { }) } +func (c *bxConfig) SetTypeOfSSO(style string) { + c.write(func() { + c.data.TypeOfSSO = style + }) +} + func (c *bxConfig) SetCheckCLIVersionDisabled(disabled bool) { c.write(func() { c.data.CheckCLIVersionDisabled = disabled diff --git a/bluemix/configuration/core_config/repository.go b/bluemix/configuration/core_config/repository.go index 8c035e6..dd9d502 100644 --- a/bluemix/configuration/core_config/repository.go +++ b/bluemix/configuration/core_config/repository.go @@ -51,6 +51,7 @@ type Repository interface { PluginRepos() []models.PluginRepo PluginRepo(string) (models.PluginRepo, bool) IsSSLDisabled() bool + TypeOfSSO() string HTTPTimeout() int CLIInfoEndpoint() string CheckCLIVersionDisabled() bool @@ -99,6 +100,7 @@ type Repository interface { SetPluginRepo(models.PluginRepo) UnsetPluginRepo(string) SetSSLDisabled(bool) + SetTypeOfSSO(string) SetHTTPTimeout(int) // SetUsageSatsDisabled disable or enable usage statistics data collection // Deprecated: use SetUsageSatsEnabled instead diff --git a/bluemix/version.go b/bluemix/version.go index 0c17f77..74497e4 100644 --- a/bluemix/version.go +++ b/bluemix/version.go @@ -3,7 +3,7 @@ package bluemix import "fmt" // Version is the SDK version -var Version = VersionType{Major: 1, Minor: 2, Build: 0} +var Version = VersionType{Major: 1, Minor: 3, Build: 0} // VersionType describe version info type VersionType struct { diff --git a/common/rest/request.go b/common/rest/request.go index f1badd9..cd37ab6 100644 --- a/common/rest/request.go +++ b/common/rest/request.go @@ -1,44 +1,45 @@ // Request examples: -// // create a simple GET request -// req := GetRequest("http://www.example.com") // -// // set header -// req.Set("Accept", "application/json") +// // create a simple GET request +// req := GetRequest("http://www.example.com") // -// // set query parameters -// req.Query("foo1", "bar1") -// req.Query("foo2", "bar2") +// // set header +// req.Set("Accept", "application/json") // -// // Build to a HTTP request -// req.Build() +// // set query parameters +// req.Query("foo1", "bar1") +// req.Query("foo2", "bar2") // -// // method chaining is also supported -// // the above is equal to: -// GetRequest("http://www.example.com"). -// Set("Accept", "application/json"). -// Query("foo1", "bar1"). -// Query("foo2", "bar2"). -// Build() +// // Build to a HTTP request +// req.Build() // -// // struct body -// foo = Foo{Bar: "val"} -// PostRequest("http://www.example.com"). -// Body(foo) +// // method chaining is also supported +// // the above is equal to: +// GetRequest("http://www.example.com"). +// Set("Accept", "application/json"). +// Query("foo1", "bar1"). +// Query("foo2", "bar2"). +// Build() // -// // String body -// PostRequest("http://www.example.com"). -// Body("{\"bar\": \"val\"}") +// // struct body +// foo = Foo{Bar: "val"} +// PostRequest("http://www.example.com"). +// Body(foo) // -// // Stream body -// PostRequest("http://www.example.com"). -// Body(strings.NewReader("abcde")) +// // String body +// PostRequest("http://www.example.com"). +// Body("{\"bar\": \"val\"}") // -// // Multipart POST request -// var f *os.File -// PostRequest("http://www.example.com"). -// Field("foo", "bar"). -// File("file1", File{Name: f.Name(), Content: f}). -// File("file2", File{Name: "1.txt", Content: []byte("abcde"), Type: "text/plain"}) +// // Stream body +// PostRequest("http://www.example.com"). +// Body(strings.NewReader("abcde")) +// +// // Multipart POST request +// var f *os.File +// PostRequest("http://www.example.com"). +// Field("foo", "bar"). +// File("file1", File{Name: f.Name(), Content: f}). +// File("file2", File{Name: "1.txt", Content: []byte("abcde"), Type: "text/plain"}) package rest import ( @@ -79,6 +80,8 @@ type Request struct { queryParams url.Values formParams url.Values + basicAuthn *BasicAuthInfo + // files to upload files map[string][]File @@ -86,6 +89,11 @@ type Request struct { body interface{} } +type BasicAuthInfo struct { + user string + pass string +} + // NewRequest creates a new request with a given rawUrl. func NewRequest(rawUrl string) *Request { return &Request{ @@ -165,6 +173,14 @@ func (r *Request) Set(key string, value string) *Request { return r } +func (r *Request) SetBasicAuth(user string, pass string) *Request { + r.basicAuthn = &BasicAuthInfo{ + user: user, + pass: pass, + } + return r +} + // Query appends the key, value pair to the request query which will be // encoded as url query parameters on HTTP request's url. func (r *Request) Query(key string, value string) *Request { @@ -210,6 +226,10 @@ func (r *Request) Build() (*http.Request, error) { return req, err } + if r.basicAuthn != nil { + req.SetBasicAuth(r.basicAuthn.user, r.basicAuthn.pass) + } + for k, vs := range r.header { for _, v := range vs { req.Header.Add(k, v)