aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/net/java/sip/communicator/impl/protocol/jabber/ChatRoomJabberImpl.java47
1 files changed, 47 insertions, 0 deletions
diff --git a/src/net/java/sip/communicator/impl/protocol/jabber/ChatRoomJabberImpl.java b/src/net/java/sip/communicator/impl/protocol/jabber/ChatRoomJabberImpl.java
index dc9ebb2..9c9cc31 100644
--- a/src/net/java/sip/communicator/impl/protocol/jabber/ChatRoomJabberImpl.java
+++ b/src/net/java/sip/communicator/impl/protocol/jabber/ChatRoomJabberImpl.java
@@ -1701,6 +1701,18 @@ public class ChatRoomJabberImpl
implements PacketListener
{
/**
+ * The timestamp of the last history message sent to the UI.
+ * Do not send earlier or messages with the same timestamp.
+ */
+ private Date lastSeenDelayedMessage = null;
+
+ /**
+ * The property to store the timestamp.
+ */
+ private static final String LAST_SEEN_DELAYED_MESSAGE_PROP
+ = "lastSeenDelayedMessage";
+
+ /**
* Process a packet.
* @param packet to process.
*/
@@ -1720,6 +1732,41 @@ public class ChatRoomJabberImpl
if(delay != null)
{
timeStamp = delay.getStamp();
+
+ // This is a delayed chat room message, a history message for
+ // the room coming from server. Lets check have we already
+ // shown this message and if this is the case skip it
+ // otherwise save it as last seen delayed message
+ if(lastSeenDelayedMessage == null)
+ {
+ // initialise this from configuration
+ String timestamp =
+ ConfigurationUtils.getChatRoomProperty(
+ provider,
+ getIdentifier(),
+ LAST_SEEN_DELAYED_MESSAGE_PROP);
+
+ try
+ {
+ lastSeenDelayedMessage =
+ new Date(Long.parseLong(timestamp));
+ }
+ catch(Throwable t)
+ {}
+ }
+
+ if(lastSeenDelayedMessage != null
+ && !timeStamp.after(lastSeenDelayedMessage))
+ return;
+
+ // save it in configuration
+ ConfigurationUtils.updateChatRoomProperty(
+ provider,
+ getIdentifier(),
+ LAST_SEEN_DELAYED_MESSAGE_PROP,
+ String.valueOf(timeStamp.getTime()));
+
+ lastSeenDelayedMessage = timeStamp;
}
else
{