Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix(metrics-operator): provide more information for dynatrace api error #2885

Closed
wants to merge 26 commits into from
Closed
Changes from 7 commits
Commits
Show all changes
26 commits
Select commit Hold shift + click to select a range
29ce035
fix: delete error message after successful retrieval of value
Vickysomtee Jan 3, 2024
2f9d9a2
Merge branch 'main' of https://github.com/Vickysomtee/keptn-lifecycle…
Vickysomtee Jan 3, 2024
6061ec3
test: successfully delete error message
Vickysomtee Jan 15, 2024
4d00167
Merge branch 'main' of https://github.com/Vickysomtee/keptn-lifecycle…
Vickysomtee Jan 15, 2024
02e2ed2
test: successfully delete error message
Vickysomtee Jan 15, 2024
6828600
Merge branch 'main' of https://github.com/Vickysomtee/keptn-lifecycle…
Vickysomtee Jan 26, 2024
2539fcb
fix: improve dynatrace api error message
Vickysomtee Jan 26, 2024
039c504
Merge branch 'main' of https://github.com/Vickysomtee/keptn-lifecycle…
Vickysomtee Feb 1, 2024
69854e0
test: API Client Auth Response
Vickysomtee Feb 1, 2024
3c25460
Merge branch 'main' of https://github.com/Vickysomtee/keptn-lifecycle…
Vickysomtee Feb 19, 2024
81a5858
test: chainsaw test
Vickysomtee Feb 20, 2024
af12ae3
test: chainsaw test
Vickysomtee Feb 21, 2024
1a82cee
test: chainsaw test
Vickysomtee Feb 22, 2024
9025ec4
test: chainsaw test
Vickysomtee Feb 23, 2024
86ea1b2
test: chainsaw test
Vickysomtee Feb 28, 2024
65883df
test: chainsaw test
Vickysomtee Feb 29, 2024
941b602
test: chainsaw test
Vickysomtee Feb 29, 2024
ae5a4fa
fix: PR conflict
Vickysomtee Mar 10, 2024
2ff007a
Merge branch 'main' of https://github.com/Vickysomtee/keptn-lifecycle…
Vickysomtee Apr 3, 2024
129c058
test: fixed failing unit test
Vickysomtee Apr 19, 2024
2794b98
test: update mock server http request
Vickysomtee Apr 23, 2024
f4b4a64
refactor: header request
Vickysomtee Apr 29, 2024
c169a3c
Merge branch 'main' of https://github.com/Vickysomtee/keptn-lifecycle…
Vickysomtee Apr 29, 2024
8d5daf0
Merge branch 'main' of https://github.com/Vickysomtee/keptn-lifecycle…
Vickysomtee May 7, 2024
131675f
refactor: header request
Vickysomtee May 7, 2024
b34e7ab
refactor: header request
Vickysomtee May 7, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Vickysomtee marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,7 @@ func NewAPIClient(config apiConfig, options ...APIClientOption) *apiClient {

// Do sends and API request to the Dynatrace API and returns its result as a string containing the raw response payload
func (client *apiClient) Do(ctx context.Context, path, method string, payload []byte) ([]byte, int, error) {
if err := client.auth(ctx); err != nil {
if _, err := client.auth(ctx); err != nil {
return nil, http.StatusUnauthorized, err
}
api := fmt.Sprintf("%s%s", client.config.serverURL, path)
Expand Down Expand Up @@ -89,10 +89,10 @@ func (client *apiClient) Do(ctx context.Context, path, method string, payload []
return b, res.StatusCode, nil
}

func (client *apiClient) auth(ctx context.Context) error {
func (client *apiClient) auth(ctx context.Context) (int, error) {
odubajDT marked this conversation as resolved.
Show resolved Hide resolved
// return if we already have a token
if client.config.oAuthCredentials.accessToken != "" {
return nil
return http.StatusOK, nil
}
client.Log.V(10).Info("OAuth login")
ctx, cancel := context.WithTimeout(ctx, 30*time.Second)
Expand All @@ -103,12 +103,12 @@ func (client *apiClient) auth(ctx context.Context) error {

req, err := http.NewRequestWithContext(ctx, "POST", client.config.authURL, bytes.NewBuffer(body))
if err != nil {
return err
return http.StatusInternalServerError, err
}
req.Header.Add("Content-Type", "application/x-www-form-urlencoded")
res, err := client.httpClient.Do(req)
if err != nil {
return err
return http.StatusInternalServerError, err
}
defer func() {
err := res.Body.Close()
Expand All @@ -117,20 +117,20 @@ func (client *apiClient) auth(ctx context.Context) error {
}
}()
if isErrorStatus(res.StatusCode) {
return ErrRequestFailed
return res.StatusCode, ErrRequestFailed
}
// we ignore the error here because we fail later while unmarshalling
oauthResponse := OAuthResponse{}
b, _ := io.ReadAll(res.Body)
err = json.Unmarshal(b, &oauthResponse)
if err != nil {
return err
return http.StatusInternalServerError, err
}

if oauthResponse.AccessToken == "" {
return ErrAuthenticationFailed
return http.StatusInternalServerError, ErrAuthenticationFailed
}

client.config.oAuthCredentials.accessToken = oauthResponse.AccessToken
return nil
return http.StatusOK, nil
}
Loading