-
Notifications
You must be signed in to change notification settings - Fork 244
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 logentry.channel json marshaling/unmarshaling #264
Fix logentry.channel json marshaling/unmarshaling #264
Conversation
So this change is technically breaking API compatibility, and under normal circumstances would be a candidate for a v2.0.0 release. That said, digging further I'm not confident that the old format was actually functional based on the API documentation. As such, I'm not confident we should hold this to the same compatibility guarantee under the v1.0.0 release. I'm going to sync up with @stmcallister to propose a |
@theckman may be better instead of breaking API would be to provide custom |
Yeah, that may be more ideal. Unmarshal into a map, extract the type field out, and then set the rest of the map on the Raw field. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should have made that comment (^) while requesting changes.
0b3bd69
to
2e9fa2f
Compare
2e9fa2f
to
635d11a
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Requesting two final adjustments, one of them is my fault. Afterwards I think this will be 👍
log_entry.go
Outdated
@@ -115,8 +115,27 @@ func (c *Channel) UnmarshalJSON(b []byte) error { | |||
ct, ok := raw["type"] | |||
if ok { | |||
c.Type = ct.(string) | |||
delete(raw, "type") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sorry, I'm going to be a real pain in your rear here... For some reason it didn't dawn on me that removing this would also be a breaking change, and also make it not the raw object anymore. Would you have the spare moment to squash out this line? If not I can fix it after merging this PR.
Thank you so much for this contribution.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Not a problem at all. I'll send update shortly
log_entry.go
Outdated
|
||
b, err := json.Marshal(raw) | ||
if err != nil { | ||
return nil, err |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I suspect json.Marshal()
effectively does the same thing. How would you feel about simplifying this error handling block all down to return json.Marshal(raw)
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nice catch. I'll fix it
Hello.
I've faced an issue when unmarshalling and marshalling back of LogEntry lead to results that differ from initial.
First of all just because of absent json tags, so it lead to
"Type"
instead of"type"
, so the next unmarshaling was broken.Also "fixing" tags leads to nested object and
transforms to
So this PR will fix this, however it require Channel type changes.
Looking forward for your feedback.