This page is for design considerations around message in Synapse.
Drivers
Features / Considerations
Authorization: Who can send a message to whom?
Event notification: Is this just for messages initiated by users, or should it support notification of events in Synapse (e.g. entity deletion, entity sharing...)
Should we support attachments? mark-up/down?
Should Synapse keep a record of messages sent?
Should Synapse provide each user an in-box (and other boxes, and the ability to move messages between boxes, delete them)?
Should Synapse enforce quotas? (# messages sent/day, bytes sent/day, and/or in-box size limit)
Should Synapse implement filters (e.g. the ability to block users from sending messages or to block/route/delete based on keywords found in messages)?
Is it sufficient to allow sending messages to principals (users and Teams) or do we need other targets? E.g. users might "follow" an entity and other users could "notify" all followers of that entity with a message. Or users could "follow" a user and each user can then send a message to all their followers.
Design approaches
- No proxy: Synapse just provides the user an email address. Email is sent OOB. (Might generate temporary email address to hide actual user address.)
- Simple pass through: Message goes through Synapse but Synapse doesn't retain any record.
- Message history. Synapse keeps each message.
- Web mail client: Synapse implements full-blown web-based mail client with folders, trash can, search, sort.