Skip to content

Commit

Permalink
Add support for array response in REST(#103)
Browse files Browse the repository at this point in the history
fix: add support for array response in REST
  • Loading branch information
naj1n authored Jan 5, 2023
2 parents 8a1eae1 + e45dd18 commit 9730fe0
Showing 1 changed file with 20 additions and 0 deletions.
20 changes: 20 additions & 0 deletions pkg/plugins/restapi/service.go
Original file line number Diff line number Diff line change
Expand Up @@ -194,9 +194,13 @@ func (r *RESTAPIConnector) Run(resourceOptions map[string]interface{}, actionOpt
case METHOD_GET:
resp, err := actionClient.SetQueryParams(actionURLParams).Get(baseURL + r.Action.URL)
body := make(map[string]interface{})
listBody := make([]map[string]interface{}, 0)
if err := json.Unmarshal(resp.Body(), &body); err == nil {
res.Rows = append(res.Rows, body)
}
if err := json.Unmarshal(resp.Body(), &listBody); err == nil {
res.Rows = listBody
}
res.Extra["raw"] = resp.Body()
res.Extra["headers"] = resp.Header()
if err != nil {
Expand All @@ -207,9 +211,13 @@ func (r *RESTAPIConnector) Run(resourceOptions map[string]interface{}, actionOpt
case METHOD_POST:
resp, err := actionClient.SetQueryParams(actionURLParams).Post(baseURL + r.Action.URL)
body := make(map[string]interface{})
listBody := make([]map[string]interface{}, 0)
if err := json.Unmarshal(resp.Body(), &body); err == nil {
res.Rows = append(res.Rows, body)
}
if err := json.Unmarshal(resp.Body(), &listBody); err == nil {
res.Rows = listBody
}
res.Extra["raw"] = resp.Body()
res.Extra["headers"] = resp.Header()
if err != nil {
Expand All @@ -220,9 +228,13 @@ func (r *RESTAPIConnector) Run(resourceOptions map[string]interface{}, actionOpt
case METHOD_PUT:
resp, err := actionClient.SetQueryParams(actionURLParams).Put(baseURL + r.Action.URL)
body := make(map[string]interface{})
listBody := make([]map[string]interface{}, 0)
if err := json.Unmarshal(resp.Body(), &body); err == nil {
res.Rows = append(res.Rows, body)
}
if err := json.Unmarshal(resp.Body(), &listBody); err == nil {
res.Rows = listBody
}
res.Extra["raw"] = resp.Body()
res.Extra["headers"] = resp.Header()
if err != nil {
Expand All @@ -233,9 +245,13 @@ func (r *RESTAPIConnector) Run(resourceOptions map[string]interface{}, actionOpt
case METHOD_PATCH:
resp, err := actionClient.SetQueryParams(actionURLParams).Patch(baseURL + r.Action.URL)
body := make(map[string]interface{})
listBody := make([]map[string]interface{}, 0)
if err := json.Unmarshal(resp.Body(), &body); err == nil {
res.Rows = append(res.Rows, body)
}
if err := json.Unmarshal(resp.Body(), &listBody); err == nil {
res.Rows = listBody
}
res.Extra["raw"] = resp.Body()
res.Extra["headers"] = resp.Header()
if err != nil {
Expand All @@ -246,9 +262,13 @@ func (r *RESTAPIConnector) Run(resourceOptions map[string]interface{}, actionOpt
case METHOD_DELETE:
resp, err := actionClient.SetQueryParams(actionURLParams).Delete(baseURL + r.Action.URL)
body := make(map[string]interface{})
listBody := make([]map[string]interface{}, 0)
if err := json.Unmarshal(resp.Body(), &body); err == nil {
res.Rows = append(res.Rows, body)
}
if err := json.Unmarshal(resp.Body(), &listBody); err == nil {
res.Rows = listBody
}
res.Extra["raw"] = resp.Body()
res.Extra["headers"] = resp.Header()
if err != nil {
Expand Down

0 comments on commit 9730fe0

Please sign in to comment.