From c63c3673a2ea3fc7b13d83796aa50a3701d5bcb3 Mon Sep 17 00:00:00 2001 From: Alex Lushpai Date: Tue, 27 Feb 2018 12:52:55 +0300 Subject: [PATCH] merge .gitignore --- .gitignore | 20 +++++++++ client.go | 112 +++++++++++++++++++++++++++++++++++++++++++++++++ client_test.go | 45 ++++++++++++++++++++ 3 files changed, 177 insertions(+) create mode 100644 client.go create mode 100644 client_test.go diff --git a/.gitignore b/.gitignore index 1f6e21e..d70a5fb 100644 --- a/.gitignore +++ b/.gitignore @@ -3,7 +3,27 @@ *.a *.so +# Folders +_obj + +# Architecture specific extensions/prefixes +*.[568vq] +[568vq].out + +*.cgo1.go +*.cgo2.c +_cgo_defun.c +_cgo_gotypes.go +_cgo_export.* + +_testmain.go + +*.exe +*.test +*.prof + # IDE's files .idea +*.iml # Project ignores diff --git a/client.go b/client.go new file mode 100644 index 0000000..1b37527 --- /dev/null +++ b/client.go @@ -0,0 +1,112 @@ +package retailcrm + +import ( + "encoding/json" + "errors" + "fmt" + "io/ioutil" + "net/http" + "net/url" + "strings" + "time" +) + +const ( + ApiPrefix = "/api/v5" +) + +type Client struct { + Url string + apiKey string + httpClient *http.Client +} + +type ErrorResponse struct { + ErrorMsg string `json:"errorMsg,omitempty"` + Errors map[string]string `json:"errors,omitempty"` +} + +func New(url string, apiKey string) *Client { + return &Client{ + url, + apiKey, + &http.Client{Timeout: 20 * time.Second}, + } +} + +func (r *Client) GetRequest(urlWithParameters string) ([]byte, int, error) { + var res []byte + + req, err := http.NewRequest("GET", fmt.Sprintf("%s%s%s", r.Url, ApiPrefix, urlWithParameters), nil) + if err != nil { + return res, 0, err + } + + req.Header.Set("X-API-KEY", r.apiKey) + + resp, err := r.httpClient.Do(req) + if err != nil { + return res, 0, err + } + + if resp.StatusCode >= http.StatusInternalServerError { + return res, resp.StatusCode, errors.New(fmt.Sprintf("HTTP request error. Status code: %d.\n", resp.StatusCode)) + } + + res, err = buildRawResponse(resp) + if err != nil { + return res, 0, err + } + + return res, resp.StatusCode, nil +} + +func (r *Client) PostRequest(url string, postParams url.Values) ([]byte, int, error) { + var res []byte + + req, err := http.NewRequest( + "POST", + fmt.Sprintf("%s%s%s", r.Url, ApiPrefix, url), + strings.NewReader(postParams.Encode()), + ) + if err != nil { + return res, 0, err + } + + req.Header.Set("Content-Type", "application/x-www-form-urlencoded") + req.Header.Set("X-API-KEY", r.apiKey) + + resp, err := r.httpClient.Do(req) + if err != nil { + return res, 0, err + } + + if resp.StatusCode >= http.StatusInternalServerError { + return res, resp.StatusCode, errors.New(fmt.Sprintf("HTTP request error. Status code: %d.\n", resp.StatusCode)) + } + + res, err = buildRawResponse(resp) + if err != nil { + return res, 0, err + } + + return res, resp.StatusCode, nil +} + +func buildRawResponse(resp *http.Response) ([]byte, error) { + defer resp.Body.Close() + + res, err := ioutil.ReadAll(resp.Body) + if err != nil { + return res, err + } + + return res, nil +} + +func (r *Client) ErrorResponse(data []byte) (*ErrorResponse, error) { + var resp ErrorResponse + err := json.Unmarshal(data, &resp) + + return &resp, err +} diff --git a/client_test.go b/client_test.go new file mode 100644 index 0000000..80110ae --- /dev/null +++ b/client_test.go @@ -0,0 +1,45 @@ +package retailcrm + +import ( + "net/http" + "net/url" + "testing" +) + +const ( + TestUrl = "https://demo.retailcrm.ru" + TestApiKey = "111" + WrongApiKeyMsg = "Wrong \"apiKey\" value." +) + +func client() *Client { + return New(TestUrl, TestApiKey) +} + +func TestGetRequest(t *testing.T) { + c := client() + + data, status, _ := c.GetRequest("/store/products") + if status != http.StatusForbidden { + t.Fail() + } + + resp, _ := c.ErrorResponse(data) + if resp.ErrorMsg != WrongApiKeyMsg { + t.Fail() + } +} + +func TestPostRequest(t *testing.T) { + c := client() + + data, status, _ := c.PostRequest("/orders/create", url.Values{}) + if status != http.StatusForbidden { + t.Fail() + } + + resp, _ := c.ErrorResponse(data) + if resp.ErrorMsg != WrongApiKeyMsg { + t.Fail() + } +}