Postoffice is a simple threaded messaging system on top of Cassandra meant to serve as a basic guide for using Cassandra from Java. The system can either be accessed using the Java API or via an HTTP interface that returns JSON and levarages Netty for performance.
The layout is as follows:
folders : {
folder_id_1 : [conv_id_1, conv_id_2, conv_id_3, ...],
folder_id_2 : [conv_id_1, conv_id_2, conv_id_3, ...],
...
}
conversations : {
conv_id_1 : [msg1, msg2, msg3, ...],
conv_id_2 : [msg1, msg2, msg3, ...],
...
}
The folder_id_X and conv_id_X values are built in a way that allows them to be multi-user and multi-folder.
The HTTP interface can be easily extended by adding URLs and their respective handlers. The handlers can then perform the needed operations and use Google GSON to create the response.
Interesting bits and pieces that one could add are hooks around request handlers that allow certain objects to be cached partially or fully. One should also be able to keep track of unread counts for respective folders.
String alice = "1501571";
String bob = "1501572";
String from = alice;
String to = bob;
PostofficeUtil.startConversation(
from, to,
"Postoffice project!",
"Hi " + to + ", I just wanted to tell you about Postoffice, a messaging system using Cassandra!"
);
Get first 10 messages in a the "inbox" folder for "1501572":
http://localhost:8081/folder?folder=inbox&owner=1501572&start=0&count=10
Create a new conversation:
http://localhost:8081/new/from=1501572&to=1501571&subject=hey&body=foobarbaz
Reply to an existing conversation given its id:
http://localhost:8081/reply?from=1501571&to=1501572&subject=hey&body=foobarbazreply&id=218779d1-ac51-11e0-8616-005056c00008
create column family folders with column_type = 'Standard' and comparator = 'TimeUUIDType';
create column family conversations with column_type = 'Standard' and comparator = 'TimeUUIDType';
(C) 2011 Hisham Mardam-Bey hisham.mardambey@gmail.com