From 001900cd4b7e8218991e7029f7871ee1da9cd2e9 Mon Sep 17 00:00:00 2001 From: Mike Dillon Date: Wed, 16 Dec 2015 21:47:11 -0800 Subject: [PATCH] Add additional err handling to SOAP template --- soap_tmpl.go | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) diff --git a/soap_tmpl.go b/soap_tmpl.go index cc9a839..5a91a3a 100644 --- a/soap_tmpl.go +++ b/soap_tmpl.go @@ -123,17 +123,20 @@ func (s *SOAPClient) Call(soapAction string, request, response interface{}) erro encoder := xml.NewEncoder(buffer) //encoder.Indent(" ", " ") - err := encoder.Encode(envelope) - if err == nil { - err = encoder.Flush() + if err := encoder.Encode(envelope); err != nil { + return err } - log.Println(buffer.String()) - if err != nil { + if err := encoder.Flush(); err != nil { return err } + log.Println(buffer.String()) + req, err := http.NewRequest("POST", s.url, buffer) + if err != nil { + return err + } if s.auth != nil { req.SetBasicAuth(s.auth.Login, s.auth.Password) } @@ -161,6 +164,9 @@ func (s *SOAPClient) Call(soapAction string, request, response interface{}) erro defer res.Body.Close() rawbody, err := ioutil.ReadAll(res.Body) + if err != nil { + return err + } if len(rawbody) == 0 { log.Println("empty response") return nil