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

MSC4208: Adding User-Defined Custom Fields to User Global Profiles #4208

Open
wants to merge 2 commits into
base: main
Choose a base branch
from

Conversation

tcpipuk
Copy link

@tcpipuk tcpipuk commented Oct 2, 2024

Rendered

Signed-off-by: Tom Foster [email protected]


Known Implementations:

  • Clients:
  • Servers:

@tcpipuk tcpipuk changed the title Adding User-Defined Custom Fields to User Global Profiles MSC4208: Adding User-Defined Custom Fields to User Global Profiles Oct 2, 2024
@tcpipuk
Copy link
Author

tcpipuk commented Oct 2, 2024

This needs a little work done to it. I've exported the custom field requirements from MSC4133 and am updating this to reflect that it is a new/separate MSC.

@turt2live turt2live added proposal A matrix spec change proposal client-server Client-Server API kind:feature MSC for not-core and not-maintenance stuff needs-implementation This MSC does not have a qualifying implementation for the SCT to review. The MSC cannot enter FCP. labels Oct 2, 2024
@@ -0,0 +1,227 @@
# MSC4208: Adding User-Defined Custom Fields to User Global Profiles

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

For reference, conduwuit still has the initial implementation of custom fields that was initially in MSC4133. Will review and validate to this new MSC some time in the next few days.

Comment on lines +24 to +25
### Client-Server API Changes

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There don't seem to be any actual client-server API changes in this MSC, so this entire section should probably just be deleted? The only real change is defining the u. namespace, the endpoints defined by MSC4133 work without any changes.


A new capability `m.custom_profile_fields` is introduced to control the ability to set custom
profile fields. It is advertised on the `GET /_matrix/client/v3/capabilities` endpoint. Clients
should check for this capability before attempting to create or modify custom fields.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm not sure if this really needs a whole new capability. If m.profile_fields can use globs, it could just have u.* in the disallowed list to block user-defined fields

- **Privacy Concerns**: Users need to be aware that custom profile fields are public and visible to
anyone who can access their profile.

- **Abuse Potential**: As with any user-generated content, there is potential for misuse. Servers

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This section needs beefing up considerably - including both client and server considerations for preventing the creation of obviously harmful custom fields, mechanisms for identifying harmful user generated content in these fields, and client controls for choosing whether to display all, some or none custom fields, with sensible defaults.

I'll aim to swing back with suggestions - happy to have conversations to help articulate the concerns more too!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
client-server Client-Server API hacktoberfest-accepted kind:feature MSC for not-core and not-maintenance stuff needs-implementation This MSC does not have a qualifying implementation for the SCT to review. The MSC cannot enter FCP. proposal A matrix spec change proposal
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants