...
- How many messages should a user be allowed to send?
- 10/min?
- 1/min?
- 1/sec?
- How many recipients can be sent to at once?
- 10?
- 50?
- Infinite?
How should we configure Amazon SES?
- Proposal:
- Reroute bounce and complaints to SNS
- Have a worker disable emails to hard-bounced recipients
- Also flip flags in settings for complaints
- Store the bounce/complaint in a blob
- Proposal:
- Should users be notified of bounces?
- Should some messages be stored as templates?
- If we start sending out notifications about Entity changes and the like, most of the contents will be similar except for the ID and some small part of the message body. We could conceivably add a flag to the MessageToUser object that tells the client to fill in a messages according to some simple template. Then we could store the key-values of the template in a blob (perhaps following the same schema as StringAnnotations) along with the message.
- What options belong in the settings object?
- Send email when...
- Update to a favorite-ed entity
- Team is messaged
- Message from user
- Admin sends mail to everyone
- Mark message as read if forwarded to email?
- Send email when...
- When someone is added to a conversation, should they be allowed to see all previous messages within the conversation? Or should it be the client's job to forward each individual message to the person?
- How should we tie Entities to users in terms of notifications?
- Ownership?
- Favorites?
- Permissions?
- Something else?
Objects
Name | DBO | Migration | DTO |
---|---|---|---|
(Immutable after creation) |
| Backup via ID Note: Etag is required because MessageStatus is mutable. | Interface
|
(Immutable after creation) |
| Secondary to MessageContent | Implements MessageContent
|
(Immutable after creation) |
| Secondary to MessageContent | |
|
| Secondary to MessageContent |
|
(Immutable after creation) |
| Secondary to MessageContent | Implements MessageContent
|
|
| TBD |
|
|
| TBD |
|
| Bundles the MessageToUser and Message Status | ||
|
|
...