-
Notifications
You must be signed in to change notification settings - Fork 385
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
MSC4133: Extending User Profile API with Key:Value Pairs #4133
base: main
Are you sure you want to change the base?
Conversation
This comment was marked as resolved.
This comment was marked as resolved.
Looks great, thanks! |
Seems we discuss here a key-value CRDT, as keys would need to be updated over time. Personally, I'm all in favor. Matrix Event Graph is isomorphic to Merkle-CRDT that powers OrbitDB (key-value DB is one of the supported CRDT). |
Co-authored-by: Travis Ralston <[email protected]>
This is an attempt to answer the authentication/rate-limiting/guest access requirements in the FCP checklist: f686090 Please post a review if any further clarification is required, thanks! |
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.
A couple of minor comments, but overall, this looks great. I particularly like that you're keeping the initial proposal small and encouraging future extensions via future proposals.
I know a lot of time and effort has gone into putting this proposal together, and it shows. Thank you.
Co-authored-by: Richard van der Hoff <[email protected]>
Co-authored-by: Richard van der Hoff <[email protected]>
Co-authored-by: Richard van der Hoff <[email protected]>
Co-authored-by: Richard van der Hoff <[email protected]>
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.
Very clear and easy to read proposal. Well done!
Only two minor comments below - the rest looks good to me!
unstable features. Proposal [MSC4175](https://github.com/matrix-org/matrix-spec-proposals/pull/4175) | ||
demonstrates the process of defining new fields in the `m.*` namespace. | ||
|
||
## Error Handling |
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.
Could you add a case for M_MISSING_PARAM
for if the client tries to set the profile field "foobar", yet neglects to include a "foobar" field in the PUT
request body JSON?
I noticed this case was handled in the Synapse implementation, but clients will not be expecting it.
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 copied that from the avatar URL profile endpoint, so probably is a spec bug that it was never documented?
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'm happy to take this opportunity to document it now? 🙂
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.
Sounds good! Was mostly implying it shouldn't be controversial!
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.
How's this? a11286a (I've since fixed the line-wrapping, as I forgot it the first time, oops...)
unstable features. Proposal [MSC4175](https://github.com/matrix-org/matrix-spec-proposals/pull/4175) | ||
demonstrates the process of defining new fields in the `m.*` namespace. | ||
|
||
## Error Handling |
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.
When it comes time to write the spec PR, the author will be trying to match up error codes to each individual endpoint.
Is it expected that all status code/error code combinations here can be used for all Client-Server and Server-Server endpoints introduced in this MSC? If so, could you explicitly say so at the beginning of this section?
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.
My assumption was that the Server-Server endpoints would have identical errors to the current ones, as federation access is still read-only in this MSC.
I'm happy to try to make the Client-Server endpoints a bit clearer on which errors apply to each of them though!
I might not have time to work on this over the weekend as my schedule is pretty full, but I'll try to get time ASAP 🙂
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.
My assumption was that the Server-Server endpoints would have identical errors to the current ones, as federation access is still read-only in this MSC.
That's fine! It's just not clear with the current copy. I'd explicitly state what you just said in the MSC to make it clear.
I'm happy to try to make the Client-Server endpoints a bit clearer on which errors apply to each of them though!
That would be appreciated!
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've written this: 2a86235
Would you prefer I literally write which errors apply to each endpoint, or is a section like this ok? I'm not sure what works best for spec-writers, so let me know and I'll do my best to help!
Rendered
Signed-off-by: Tom Foster [email protected]
Known Implementations:
FCP tickyboxes
MSC checklist