diff --git a/src/common/connection.py b/src/common/connection.py index f3627cfae..fac387aee 100644 --- a/src/common/connection.py +++ b/src/common/connection.py @@ -2304,7 +2304,8 @@ class Connection(CommonConnection, ConnectionHandlers): room_id=resp.getTag('unique').getData())) self.connection.SendAndCallForResponse(iq, _on_response) - def join_gc(self, nick, room_jid, password, change_nick=False): + def join_gc(self, nick, room_jid, password, change_nick=False, + rejoin=False): # FIXME: This room JID needs to be normalized; see #1364 if not gajim.account_is_connected(self.name): return @@ -2353,6 +2354,10 @@ class Connection(CommonConnection, ConnectionHandlers): last_date = time.strftime('%Y-%m-%dT%H:%M:%SZ', time.gmtime( last_date)) tags['since'] = last_date + if rejoin: + tags['since'] = time.strftime('%Y-%m-%dT%H:%M:%SZ', + time.gmtime(gajim.logger.get_last_date_that_has_logs( + room_jid, is_room=True) + 1)) nb = gajim.config.get('muc_restore_lines') if nb >= 0: tags['maxstanzas'] = nb diff --git a/src/groupchat_control.py b/src/groupchat_control.py index 469d1a640..9581124f3 100644 --- a/src/groupchat_control.py +++ b/src/groupchat_control.py @@ -1274,7 +1274,7 @@ class GroupchatControl(ChatControlBase): gajim.gc_connected[obj.conn.name][self.room_jid]: return password = gajim.gc_passwords.get(self.room_jid, '') - obj.conn.join_gc(self.nick, self.room_jid, password) + obj.conn.join_gc(self.nick, self.room_jid, password, rejoin=True) def _nec_decrypted_message_received(self, obj): if obj.conn.name != self.account: @@ -1351,7 +1351,7 @@ class GroupchatControl(ChatControlBase): return False password = gajim.gc_passwords.get(self.room_jid, '') gajim.connections[self.account].join_gc(self.nick, self.room_jid, - password) + password, rejoin=True) return True def draw_roster(self):