aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/net/java/sip/communicator/impl/history/HistoryReaderImpl.java54
-rw-r--r--src/net/java/sip/communicator/impl/msghistory/MessageHistoryServiceImpl.java207
-rw-r--r--src/net/java/sip/communicator/impl/msghistory/MessageSourceService.java46
-rw-r--r--src/net/java/sip/communicator/impl/protocol/jabber/jabber.provider.manifest.mf1
-rw-r--r--src/net/java/sip/communicator/service/history/HistoryReader.java20
5 files changed, 262 insertions, 66 deletions
diff --git a/src/net/java/sip/communicator/impl/history/HistoryReaderImpl.java b/src/net/java/sip/communicator/impl/history/HistoryReaderImpl.java
index f1159e53..3c872e7 100644
--- a/src/net/java/sip/communicator/impl/history/HistoryReaderImpl.java
+++ b/src/net/java/sip/communicator/impl/history/HistoryReaderImpl.java
@@ -165,6 +165,27 @@ public class HistoryReaderImpl
public synchronized QueryResultSet<HistoryRecord> findLast(int count)
throws RuntimeException
{
+ return findLast(count, null, null, false);
+ }
+
+ /**
+ * Returns the supplied number of recent messages
+ * containing all <tt>keywords</tt>.
+ *
+ * @param count messages count
+ * @param keywords array of keywords we search for
+ * @param field the field where to look for the keyword
+ * @param caseSensitive is keywords search case sensitive
+ * @return the found records
+ * @throws RuntimeException
+ */
+ public synchronized QueryResultSet<HistoryRecord> findLast(
+ int count,
+ String[] keywords,
+ String field,
+ boolean caseSensitive)
+ throws RuntimeException
+ {
// the files are supposed to be ordered from oldest to newest
Vector<String> filelist =
filterFilesByDate(this.historyImpl.getFileList(), null, null);
@@ -227,37 +248,14 @@ public class HistoryReaderImpl
timestamp = new Date(Long.parseLong(ts));
}
- ArrayList<String> nameVals = new ArrayList<String>();
+ HistoryRecord record =
+ filterByKeyword(propertyNodes, timestamp,
+ keywords, field, caseSensitive);
- int len = propertyNodes.getLength();
- for (int j = 0; j < len; j++)
+ if(record != null)
{
- Node propertyNode = propertyNodes.item(j);
- if (propertyNode.getNodeType() == Node.ELEMENT_NODE)
- {
- // Get nested TEXT node's value
- Node nodeValue = propertyNode.getFirstChild();
-
- if(nodeValue == null)
- continue;
-
- nameVals.add(propertyNode.getNodeName());
- nameVals.add(nodeValue.getNodeValue());
- }
- }
-
- String[] propertyNames = new String[nameVals.size() / 2];
- String[] propertyValues = new String[propertyNames.length];
- for (int j = 0; j < propertyNames.length; j++)
- {
- propertyNames[j] = nameVals.get(j * 2);
- propertyValues[j] = nameVals.get(j * 2 + 1);
+ result.add(record);
}
-
- HistoryRecord record = new HistoryRecord(propertyNames,
- propertyValues, timestamp);
-
- result.add(record);
}
currentFile--;
diff --git a/src/net/java/sip/communicator/impl/msghistory/MessageHistoryServiceImpl.java b/src/net/java/sip/communicator/impl/msghistory/MessageHistoryServiceImpl.java
index 9ba43cb..0c1a827 100644
--- a/src/net/java/sip/communicator/impl/msghistory/MessageHistoryServiceImpl.java
+++ b/src/net/java/sip/communicator/impl/msghistory/MessageHistoryServiceImpl.java
@@ -56,17 +56,24 @@ public class MessageHistoryServiceImpl
private static Logger logger = Logger
.getLogger(MessageHistoryServiceImpl.class);
- private static String[] STRUCTURE_NAMES
+ static String[] STRUCTURE_NAMES
= new String[] { "dir", "msg_CDATA", "msgTyp", "enc", "uid", "sub",
- "receivedTimestamp" };
+ "receivedTimestamp", "msgSubTyp" };
private static HistoryRecordStructure recordStructure =
new HistoryRecordStructure(STRUCTURE_NAMES);
- // the field used to search by keywords
+ /**
+ * the field used to search by keywords
+ */
private static final String SEARCH_FIELD = "msg";
/**
+ * Subtype sms to mark sms messages.
+ */
+ static final String MSG_SUBTYPE_SMS = "sms";
+
+ /**
* The BundleContext that we got from the OSGI bus.
*/
private BundleContext bundleContext = null;
@@ -346,6 +353,39 @@ public class MessageHistoryServiceImpl
}
/**
+ * Checks whether this historyID contains messages of certain type.
+ * @param historyID
+ * @param keywords
+ * @param field
+ * @param caseSensitive
+ * @return
+ * @throws IOException
+ */
+ private boolean hasMessages(HistoryID historyID,
+ String[] keywords,
+ String field,
+ boolean caseSensitive)
+ throws IOException
+ {
+ if(!this.historyService.isHistoryCreated(historyID))
+ return false;
+
+ History history;
+ if (this.historyService.isHistoryExisting(historyID))
+ {
+ history = this.historyService.getHistory(historyID);
+ }
+ else
+ {
+ history = this.historyService.createHistory(historyID,
+ recordStructure);
+ }
+
+ return history.getReader().findLast(
+ 1, keywords, field, caseSensitive).hasNext();
+ }
+
+ /**
* Returns the messages for the recently contacted <tt>count</tt> contacts.
*
* @param count contacts count
@@ -357,7 +397,8 @@ public class MessageHistoryServiceImpl
* @throws RuntimeException
*/
Collection<EventObject> findRecentMessagesPerContact(
- int count, String providerToFilter, String contactToFilter)
+ int count, String providerToFilter, String contactToFilter,
+ boolean isSMSEnabled)
throws RuntimeException
{
TreeSet<EventObject> result
@@ -396,7 +437,9 @@ public class MessageHistoryServiceImpl
// find contact or chatroom for historyID
Object descriptor = getContactOrRoomByID(
accountID,
- id.getID()[3]);
+ id.getID()[3],
+ id,
+ isSMSEnabled);
// skip not found contacts, disabled accounts and hidden one
if(descriptor == null)
@@ -415,7 +458,22 @@ public class MessageHistoryServiceImpl
HistoryReader reader = history.getReader();
- Iterator<HistoryRecord> recs = reader.findLast(1);
+ // find last by type
+ Iterator<HistoryRecord> recs;
+
+ if(isSMSEnabled)
+ {
+ recs = reader.findLast(
+ 1,
+ new String[]{MessageHistoryServiceImpl.MSG_SUBTYPE_SMS},
+ MessageHistoryServiceImpl.STRUCTURE_NAMES[7],
+ true);
+ }
+ else
+ {
+ recs = reader.findLast(1);
+ }
+
while (recs.hasNext())
{
if(descriptor instanceof Contact)
@@ -453,7 +511,11 @@ public class MessageHistoryServiceImpl
* @param id the contact or room id.
* @return contact or chat room.
*/
- private Object getContactOrRoomByID(String accountID, String id)
+ private Object getContactOrRoomByID(String accountID,
+ String id,
+ HistoryID historyID,
+ boolean isSMSEnabled)
+ throws IOException
{
AccountID account = null;
for(AccountID acc : AccountUtils.getStoredAccounts())
@@ -484,6 +546,37 @@ public class MessageHistoryServiceImpl
Contact contact = opSetPresence.findContactByID(id);
+ if(isSMSEnabled)
+ {
+ //lets check if we have a contact and it has sms messages return it
+ if(contact != null
+ && hasMessages(
+ historyID,
+ new String[]{MessageHistoryServiceImpl.MSG_SUBTYPE_SMS},
+ MessageHistoryServiceImpl.STRUCTURE_NAMES[7],
+ true))
+ {
+ return contact;
+ }
+
+ // we will check only for sms contacts
+ OperationSetSmsMessaging opSetSMS =
+ pps.getOperationSet(OperationSetSmsMessaging.class);
+
+ // return the contact only if it has stored sms messages
+ if(opSetSMS == null
+ || !hasMessages(
+ historyID,
+ new String[]{MessageHistoryServiceImpl.MSG_SUBTYPE_SMS},
+ MessageHistoryServiceImpl.STRUCTURE_NAMES[7],
+ true))
+ {
+ return null;
+ }
+
+ return opSetSMS.getContact(id);
+ }
+
if(contact != null)
return contact;
@@ -831,16 +924,36 @@ public class MessageHistoryServiceImpl
if(msg.isOutgoing)
{
- return new MessageDeliveredEvent(
- msg,
- contact,
- timestamp);
+ MessageDeliveredEvent evt
+ = new MessageDeliveredEvent(
+ msg,
+ contact,
+ timestamp);
+
+ if(msg.getMsgSubType() != null
+ && msg.getMsgSubType().equals(MSG_SUBTYPE_SMS))
+ {
+ evt.setSmsMessage(true);
+ }
+
+ return evt;
}
else
+ {
+ int eventType = MessageReceivedEvent.CONVERSATION_MESSAGE_RECEIVED;
+
+ if(msg.getMsgSubType() != null
+ && msg.getMsgSubType().equals(MSG_SUBTYPE_SMS))
+ {
+ eventType = MessageReceivedEvent.SMS_MESSAGE_RECEIVED;
+ }
+
return new MessageReceivedEvent(
msg,
contact,
- timestamp);
+ timestamp,
+ eventType);
+ }
}
/**
@@ -910,6 +1023,7 @@ public class MessageHistoryServiceImpl
// 4- uid
// 5 - sub
// 6 - receivedTimestamp
+ // 7 - msgSubType
String textContent = null;
String contentType = null;
String contentEncoding = null;
@@ -917,6 +1031,7 @@ public class MessageHistoryServiceImpl
String subject = null;
boolean isOutgoing = false;
Date messageReceivedDate = new Date(0);
+ String msgSubType = null;
SimpleDateFormat sdf = new SimpleDateFormat(DATE_FORMAT);
for (int i = 0; i < hr.getPropertyNames().length; i++)
{
@@ -951,9 +1066,13 @@ public class MessageHistoryServiceImpl
new Date(Long.parseLong(hr.getPropertyValues()[i]));
}
}
+ else if (propName.equals(STRUCTURE_NAMES[7]))
+ {
+ msgSubType = hr.getPropertyValues()[i];
+ }
}
return new MessageImpl(textContent, contentType, contentEncoding,
- subject, messageUID, isOutgoing, messageReceivedDate);
+ subject, messageUID, isOutgoing, messageReceivedDate, msgSubType);
}
/**
@@ -1049,14 +1168,24 @@ public class MessageHistoryServiceImpl
public void messageReceived(MessageReceivedEvent evt)
{
- this.writeMessage("in", null, evt.getSourceContact(), evt
- .getSourceMessage(), evt.getTimestamp());
+ this.writeMessage(
+ "in",
+ null,
+ evt.getSourceContact(),
+ evt.getSourceMessage(),
+ evt.getTimestamp(),
+ evt.getEventType() == MessageReceivedEvent.SMS_MESSAGE_RECEIVED);
}
public void messageDelivered(MessageDeliveredEvent evt)
{
- this.writeMessage("out", null, evt.getDestinationContact(), evt
- .getSourceMessage(), evt.getTimestamp());
+ this.writeMessage(
+ "out",
+ null,
+ evt.getDestinationContact(),
+ evt.getSourceMessage(),
+ evt.getTimestamp(),
+ evt.isSmsMessage());
}
public void messageDeliveryFailed(MessageDeliveryFailedEvent evt)
@@ -1201,7 +1330,8 @@ public class MessageHistoryServiceImpl
return;
}
- writeMessage(history, "out", evt.getMessage(), evt.getTimestamp());
+ writeMessage(
+ history, "out", evt.getMessage(), evt.getTimestamp(), false);
} catch (IOException e)
{
logger.error("Could not add message to history", e);
@@ -1218,11 +1348,17 @@ public class MessageHistoryServiceImpl
* @param source The source Contact
* @param destination The destination Contact
* @param message Message message to be written
- * @param messageTimestamp Date this is the timestamp when was message received
- * that came from the protocol provider
- */
- private void writeMessage(String direction, Contact source,
- Contact destination, Message message, Date messageTimestamp)
+ * @param messageTimestamp Date this is the timestamp when was message
+ * received that came from the protocol provider
+ * @param isSmsSubtype whether message to write is an sms
+ */
+ private void writeMessage(
+ String direction,
+ Contact source,
+ Contact destination,
+ Message message,
+ Date messageTimestamp,
+ boolean isSmsSubtype)
{
try
{
@@ -1238,7 +1374,8 @@ public class MessageHistoryServiceImpl
History history = this.getHistory(source, destination);
- writeMessage(history, direction, message, messageTimestamp);
+ writeMessage(
+ history, direction, message, messageTimestamp, isSmsSubtype);
} catch (IOException e)
{
logger.error("Could not add message to history", e);
@@ -1250,11 +1387,11 @@ public class MessageHistoryServiceImpl
* @param history The history to which will write the message
* @param direction coming from
* @param message Message
- * @param messageTimestamp Date this is the timestamp when was message received
- * that came from the protocol provider
+ * @param messageTimestamp Date this is the timestamp when was message
+ * received that came from the protocol provider
*/
private void writeMessage(History history, String direction,
- Message message, Date messageTimestamp)
+ Message message, Date messageTimestamp, boolean isSmsSubtype)
{
try {
HistoryWriter historyWriter = history.getWriter();
@@ -1263,7 +1400,8 @@ public class MessageHistoryServiceImpl
historyWriter.addRecord(new String[] { direction,
message.getContent(), message.getContentType(),
message.getEncoding(), message.getMessageUID(),
- message.getSubject(), sdf.format(messageTimestamp) },
+ message.getSubject(), sdf.format(messageTimestamp),
+ isSmsSubtype ? MSG_SUBTYPE_SMS : null},
new Date()); // this date is when the history record is written
} catch (IOException e)
{
@@ -2344,20 +2482,28 @@ public class MessageHistoryServiceImpl
private final Date messageReceivedDate;
+ private String msgSubType;
+
MessageImpl(String content, String contentType, String encoding,
String subject, String messageUID, boolean isOutgoing,
- Date messageReceivedDate)
+ Date messageReceivedDate, String msgSubType)
{
super(content, contentType, encoding, subject, messageUID);
this.isOutgoing = isOutgoing;
this.messageReceivedDate = messageReceivedDate;
+ this.msgSubType = msgSubType;
}
public Date getMessageReceivedDate()
{
return messageReceivedDate;
}
+
+ public String getMsgSubType()
+ {
+ return msgSubType;
+ }
}
/**
@@ -2686,7 +2832,8 @@ public class MessageHistoryServiceImpl
getHistoryForAdHocMultiChat(
evt.getSourceAdHocChatRoom());
- writeMessage(history, "out", evt.getMessage(), evt.getTimestamp());
+ writeMessage(
+ history, "out", evt.getMessage(), evt.getTimestamp(), false);
}
catch (IOException e)
{
diff --git a/src/net/java/sip/communicator/impl/msghistory/MessageSourceService.java b/src/net/java/sip/communicator/impl/msghistory/MessageSourceService.java
index 6be3220..1e667f8 100644
--- a/src/net/java/sip/communicator/impl/msghistory/MessageSourceService.java
+++ b/src/net/java/sip/communicator/impl/msghistory/MessageSourceService.java
@@ -64,6 +64,12 @@ public class MessageSourceService
= "net.java.sip.communicator.impl.msghistory.contactsrc.MSG_NUMBER";
/**
+ * Property to control messages type. Can query for message sub type.
+ */
+ private static final String IS_MESSAGE_SUBTYPE_SMS_PROP
+ = "net.java.sip.communicator.impl.msghistory.contactsrc.IS_SMS_ENABLED";
+
+ /**
* Number of messages to show.
*/
private int numberOfMessages = 10;
@@ -102,6 +108,11 @@ public class MessageSourceService
private MessageHistoryContactQuery recentQuery = null;
/**
+ * The message subtype if any.
+ */
+ private boolean isSMSEnabled = false;
+
+ /**
* Constructs MessageSourceService.
*/
MessageSourceService()
@@ -117,6 +128,9 @@ public class MessageSourceService
numberOfMessages = MessageHistoryActivator.getConfigurationService()
.getInt(NUMBER_OF_RECENT_MSGS_PROP, numberOfMessages);
+
+ isSMSEnabled = MessageHistoryActivator.getConfigurationService()
+ .getBoolean(IS_MESSAGE_SUBTYPE_SMS_PROP, isSMSEnabled);
}
/**
@@ -192,7 +206,8 @@ public class MessageSourceService
MessageHistoryServiceImpl msgHistoryService =
MessageHistoryActivator.getMessageHistoryService();
Collection<EventObject> res = msgHistoryService
- .findRecentMessagesPerContact(numberOfMessages, null, null);
+ .findRecentMessagesPerContact(
+ numberOfMessages, null, null, isSMSEnabled);
for(EventObject obj : res)
{
@@ -218,9 +233,9 @@ public class MessageSourceService
{
synchronized(historyID)
{
- MessageHistoryServiceImpl msgService
- = MessageHistoryActivator.getMessageHistoryService();
- HistoryService historyService = msgService.getHistoryService();
+ HistoryService historyService =
+ MessageHistoryActivator.getMessageHistoryService()
+ .getHistoryService();
// if not existing, return to search for initial load
if (history == null
@@ -282,8 +297,9 @@ public class MessageSourceService
if(provider == null || contact == null)
return res;
- for(EventObject ev : msgService.findRecentMessagesPerContact(
- numberOfMessages, provider, contact))
+ for(EventObject ev
+ : msgService.findRecentMessagesPerContact(
+ numberOfMessages, provider, contact, isSMSEnabled))
{
res.add(new MessageSourceContact(ev, this));
}
@@ -425,7 +441,8 @@ public class MessageSourceService
.findRecentMessagesPerContact(
numberOfMessages,
evt.getProvider().getAccountID().getAccountUniqueID(),
- null);
+ null,
+ isSMSEnabled);
List<String> recentMessagesForProvider = new LinkedList<String>();
List<MessageSourceContact> messages = getRecentMessages();
@@ -595,6 +612,12 @@ public class MessageSourceService
@Override
public void messageReceived(MessageReceivedEvent evt)
{
+ if(isSMSEnabled
+ && evt.getEventType() != MessageReceivedEvent.SMS_MESSAGE_RECEIVED)
+ {
+ return;
+ }
+
handle(
evt,
evt.getSourceContact().getProtocolProvider(),
@@ -604,6 +627,9 @@ public class MessageSourceService
@Override
public void messageDelivered(MessageDeliveredEvent evt)
{
+ if(isSMSEnabled && !evt.isSmsMessage())
+ return;
+
handle(
evt,
evt.getDestinationContact().getProtocolProvider(),
@@ -621,6 +647,9 @@ public class MessageSourceService
@Override
public void messageReceived(ChatRoomMessageReceivedEvent evt)
{
+ if(isSMSEnabled)
+ return;
+
// ignore non conversation messages
if(evt.getEventType() !=
ChatRoomMessageReceivedEvent.CONVERSATION_MESSAGE_RECEIVED)
@@ -635,6 +664,9 @@ public class MessageSourceService
@Override
public void messageDelivered(ChatRoomMessageDeliveredEvent evt)
{
+ if(isSMSEnabled)
+ return;
+
handle(
evt,
evt.getSourceChatRoom().getParentProvider(),
diff --git a/src/net/java/sip/communicator/impl/protocol/jabber/jabber.provider.manifest.mf b/src/net/java/sip/communicator/impl/protocol/jabber/jabber.provider.manifest.mf
index 8a4c14b..549d8d3 100644
--- a/src/net/java/sip/communicator/impl/protocol/jabber/jabber.provider.manifest.mf
+++ b/src/net/java/sip/communicator/impl/protocol/jabber/jabber.provider.manifest.mf
@@ -14,6 +14,7 @@ Import-Package: ch.imvs.sdes4j.srtp,
net.java.sip.communicator.service.certificate,
net.java.sip.communicator.service.credentialsstorage,
net.java.sip.communicator.service.customavatar,
+ net.java.sip.communicator.service.contactsource,
net.java.sip.communicator.service.gui,
net.java.sip.communicator.service.hid,
net.java.sip.communicator.service.httputil,
diff --git a/src/net/java/sip/communicator/service/history/HistoryReader.java b/src/net/java/sip/communicator/service/history/HistoryReader.java
index fa6fffe..8f7be98 100644
--- a/src/net/java/sip/communicator/service/history/HistoryReader.java
+++ b/src/net/java/sip/communicator/service/history/HistoryReader.java
@@ -167,7 +167,25 @@ public interface HistoryReader {
* @return the found records
* @throws RuntimeException
*/
- QueryResultSet<HistoryRecord> findLast(int count) throws RuntimeException;
+ QueryResultSet<HistoryRecord> findLast(int count)
+ throws RuntimeException;
+
+ /**
+ * Returns the supplied number of recent messages
+ * containing all <tt>keywords</tt>.
+ *
+ * @param count messages count
+ * @param keywords array of keywords we search for
+ * @param field the field where to look for the keyword
+ * @param caseSensitive is keywords search case sensitive
+ * @return the found records
+ * @throws RuntimeException
+ */
+ QueryResultSet<HistoryRecord> findLast( int count,
+ String[] keywords,
+ String field,
+ boolean caseSensitive)
+ throws RuntimeException;
/**
* Returns the supplied number of recent messages after the given date