You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
That issue was opened by @synergiator with the title "How to change the log level for go-cloudstack module?" and asked for a way to have more detailed logging.
I proposed a broader solution:
I also think that adding logging would be useful, but as there's never consensus on what to log or which logging library to use (log, zap, logrus, etc.), what would you think of adding some "hooks", optional functions that would be called before and after the actual http request? The user of CloudStack client could then provide its own logging or tracing logic.
IMHO, the best would be to also add an optional context.Context to all API functions, in order to make it possible to do contextual tracing for example.
A possible signature for these hooks could be:
// PreRequestHook would be called in newRequest, just before the HTTP request call.typePreRequestHookfunc(ctx context.Context, apistring, params url.Values)
// PostRequestHook would be called in each generated client function,// just after the Unmarshal step.typePostRequestHookfunc(ctx context.Context, rawResp json.RawMessage, errerror, respinterface{})
I can contribute and submit a PR if you are ok with that.
Any thoughts?
The text was updated successfully, but these errors were encountered:
I've not idea as I'm not a Go expert, I can ask @svanharmelen@davidjumani@Pearl1594 to chime in, or ask you to start a [DISCUSS] thread if it's a large issue you want to discuss on the dev@ mailing list.
This issue is a follow-up of xanzy/go-cloudstack#120.
That issue was opened by @synergiator with the title "How to change the log level for go-cloudstack module?" and asked for a way to have more detailed logging.
I proposed a broader solution:
Any thoughts?
The text was updated successfully, but these errors were encountered: