Skip to content

Commit

Permalink
add parsed response as return parameter
Browse files Browse the repository at this point in the history
  • Loading branch information
AndersonQ committed Nov 14, 2023
1 parent 4f24665 commit a479f50
Showing 1 changed file with 25 additions and 6 deletions.
31 changes: 25 additions & 6 deletions kibana/fleet.go
Original file line number Diff line number Diff line change
Expand Up @@ -148,10 +148,21 @@ type DownloadSource struct {
ProxyID interface{} `json:"proxy_id"`
}

func (client *Client) CreateDownloadSource(ctx context.Context, source DownloadSource) error {
type DownloadSourceResponse struct {
Item struct {
ID string `json:"id"`
Name string `json:"name"`
Host string `json:"host"`
IsDefault bool `json:"is_default"`
ProxyId interface{} `json:"proxy_id"`

Check failure on line 157 in kibana/fleet.go

View workflow job for this annotation

GitHub Actions / lint (windows)

ST1003: struct field ProxyId should be ProxyID (stylecheck)

Check failure on line 157 in kibana/fleet.go

View workflow job for this annotation

GitHub Actions / lint (linux)

ST1003: struct field ProxyId should be ProxyID (stylecheck)

Check failure on line 157 in kibana/fleet.go

View workflow job for this annotation

GitHub Actions / lint (darwin)

ST1003: struct field ProxyId should be ProxyID (stylecheck)
} `json:"item"`
}

func (client *Client) CreateDownloadSource(ctx context.Context, source DownloadSource) (DownloadSourceResponse, error) {
reqBody, err := json.Marshal(source)
if err != nil {
return fmt.Errorf("unable to marshal DownloadSource into JSON: %w", err)
return DownloadSourceResponse{},
fmt.Errorf("unable to marshal DownloadSource into JSON: %w", err)
}

resp, err := client.Connection.SendWithContext(
Expand All @@ -162,7 +173,8 @@ func (client *Client) CreateDownloadSource(ctx context.Context, source DownloadS
nil,
bytes.NewReader(reqBody))
if err != nil {
return fmt.Errorf("error calling Agent Binary Download Sources API: %w", err)
return DownloadSourceResponse{},
fmt.Errorf("error calling Agent Binary Download Sources API: %w", err)
}
defer resp.Body.Close()

Expand All @@ -177,11 +189,18 @@ func (client *Client) CreateDownloadSource(ctx context.Context, source DownloadS
client.log.Errorw(
"could not create download source, kibana returned "+resp.Status,
"http.response.body.content", respBody)
return fmt.Errorf("could not create download source, kibana returned %s. response body: %s: %w",
resp.Status, respBody, err)
return DownloadSourceResponse{},
fmt.Errorf("could not create download source, kibana returned %s. response body: %s: %w",
resp.Status, respBody, err)
}

return nil
body := DownloadSourceResponse{}
if err = json.NewDecoder(resp.Body).Decode(&body); err != nil {
return DownloadSourceResponse{},
fmt.Errorf("failed parsing download source reponse: %w", err)

Check failure on line 200 in kibana/fleet.go

View workflow job for this annotation

GitHub Actions / lint (windows)

`reponse` is a misspelling of `response` (misspell)

Check failure on line 200 in kibana/fleet.go

View workflow job for this annotation

GitHub Actions / lint (linux)

`reponse` is a misspelling of `response` (misspell)

Check failure on line 200 in kibana/fleet.go

View workflow job for this annotation

GitHub Actions / lint (darwin)

`reponse` is a misspelling of `response` (misspell)
}

return body, nil
}

// GetPolicy returns the requested ID
Expand Down

0 comments on commit a479f50

Please sign in to comment.