annotate bot.py @ 175:8378da7844f2

minor fix in Bridge.addParticipant(), don't rely on Bridge.irc_connection or Bridge.xmpp_room when not necessary Signed-off-by: Charly COSTE <changaco@changaco.net>
author Charly COSTE <changaco@changaco.net>
date Mon, 08 Feb 2010 19:01:04 +0100
parents 64a0e9636ae6
children d1686164b9e3
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
1 #!/usr/bin/env python
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
2 # -*- coding: utf-8 -*-
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
3
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
4 # This program is free software: you can redistribute it and/or modify
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
5 # it under the terms of the GNU General Public License as published by
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
6 # the Free Software Foundation, either version 3 of the License, or
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
7 # (at your option) any later version.
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
8 #
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
9 # This program is distributed in the hope that it will be useful,
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
12 # GNU General Public License for more details.
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
13 #
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
14 # You should have received a copy of the GNU General Public License
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
15 # along with this program. If not, see <http://www.gnu.org/licenses/>.
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
16
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
17
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
18 import re
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
19 import sys
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
20 import threading
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
21 from time import sleep
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
22 import traceback
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
23 import xml.parsers.expat
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
24
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
25 import irclib
75
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
26 import muc
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
27 xmpp = muc.xmpp
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
28 del muc
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
29
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
30 from bridge import Bridge
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
31 from participant import Participant
134
931a5edc7971 moved commands to a separate file
Charly COSTE <changaco@changaco.net>
parents: 133
diff changeset
32 import commands
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
33
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
34
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
35 class Bot(threading.Thread):
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
36
86
bfa32b017fc9 First hack at an error notification system
Charly COSTE <changaco@changaco.net>
parents: 79
diff changeset
37 def __init__(self, jid, password, nickname, admins_jid=[], error_fd=sys.stderr, debug=False):
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
38 threading.Thread.__init__(self)
155
63db565438bd fixed the halt command
Charly COSTE <changaco@changaco.net>
parents: 152
diff changeset
39 self.halt = False
171
489c157d9e82 display error when bot creation fails
Charly COSTE <changaco@changaco.net>
parents: 166
diff changeset
40 self.bridges = []
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
41 self.bare_jid = xmpp.protocol.JID(jid=jid)
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
42 self.bare_jid.setResource('')
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
43 self.nickname = nickname
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
44 self.password = password
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
45 self.error_fd = error_fd
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
46 self.debug = debug
86
bfa32b017fc9 First hack at an error notification system
Charly COSTE <changaco@changaco.net>
parents: 79
diff changeset
47 self.admins_jid = admins_jid
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
48 self.xmpp_connections = {}
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
49 self.irc = irclib.IRC()
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
50 self.irc.bot = self
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
51 self.irc.add_global_handler('all_events', self._irc_event_handler)
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
52 self.irc_thread = threading.Thread(target=self.irc.process_forever)
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
53 self.irc_thread.start()
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
54 # Open connection with XMPP server
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
55 try:
22
e2bd4de698e5 Solved an XMPP resource conflict that would have happened when someone on IRC changed its nickname and later its old nickname would be used again. In other words, the bot no longer uses nicknames as XMPP resources.
Charly COSTE <changaco@changaco.net>
parents: 21
diff changeset
56 self.xmpp_c = self.get_xmpp_connection(self.nickname)
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
57 except:
19
c1b84196c100 Changed format of non-debug error messages, fixed IRC namreply handling, prevented crash when receiving bad XMPP stanza.
Charly COSTE <changaco@changaco.net>
parents: 18
diff changeset
58 self.error('[Error] XMPP Connection failed')
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
59 raise
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
60 self.xmpp_thread = threading.Thread(target=self._xmpp_loop)
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
61 self.xmpp_thread.start()
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
62
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
63
86
bfa32b017fc9 First hack at an error notification system
Charly COSTE <changaco@changaco.net>
parents: 79
diff changeset
64 def error(self, s, debug=False, send_to_admins=False):
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
65 """Output an error message."""
86
bfa32b017fc9 First hack at an error notification system
Charly COSTE <changaco@changaco.net>
parents: 79
diff changeset
66 if send_to_admins == True:
bfa32b017fc9 First hack at an error notification system
Charly COSTE <changaco@changaco.net>
parents: 79
diff changeset
67 self._send_message_to_admins(s)
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
68 if not debug or debug and self.debug:
172
64a0e9636ae6 removed encoding.py, charsets handling is now in irclib and custom charsets can be set per server in the configuration file
Charly COSTE <changaco@changaco.net>
parents: 171
diff changeset
69 self.error_fd.write(s.encode('utf-8')+"\n")
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
70
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
71
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
72 def _xmpp_loop(self):
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
73 """[Internal] XMPP infinite loop."""
75
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
74 i = 1
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
75 while True:
155
63db565438bd fixed the halt command
Charly COSTE <changaco@changaco.net>
parents: 152
diff changeset
76 if self.halt:
63db565438bd fixed the halt command
Charly COSTE <changaco@changaco.net>
parents: 152
diff changeset
77 s = len(self.xmpp_connections)
63db565438bd fixed the halt command
Charly COSTE <changaco@changaco.net>
parents: 152
diff changeset
78 for i in range(s):
63db565438bd fixed the halt command
Charly COSTE <changaco@changaco.net>
parents: 152
diff changeset
79 self.close_xmpp_connection(self.xmpp_connections.keys()[s-i-1], force=True)
63db565438bd fixed the halt command
Charly COSTE <changaco@changaco.net>
parents: 152
diff changeset
80 break
79
73a30fc1922b Fixed the XMPP loop (release the lock)
Charly COSTE <changaco@changaco.net>
parents: 78
diff changeset
81 unlock = False
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
82 try:
51
2737ed5b9003 Tried to improve the XMPP loop, again.
Charly COSTE <changaco@changaco.net>
parents: 50
diff changeset
83 if len(self.xmpp_connections) == 1:
2737ed5b9003 Tried to improve the XMPP loop, again.
Charly COSTE <changaco@changaco.net>
parents: 50
diff changeset
84 sleep(0.5) # avoid bot connection being locked all the time
101
29d3b85c6286 Minor fixes/improvements
Charly COSTE <changaco@changaco.net>
parents: 100
diff changeset
85 for j, c in enumerate(self.xmpp_connections.itervalues()):
75
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
86 i += 1
51
2737ed5b9003 Tried to improve the XMPP loop, again.
Charly COSTE <changaco@changaco.net>
parents: 50
diff changeset
87 if hasattr(c, 'lock'):
49
714e78fb912e Tried to improve thread-safety during XMPP connection closing.
Charly COSTE <changaco@changaco.net>
parents: 48
diff changeset
88 c.lock.acquire()
75
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
89 if i == j:
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
90 ping = xmpp.protocol.Iq(typ='get')
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
91 ping.addChild(name='ping', namespace='urn:xmpp:ping')
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
92 self.error('=> Debug: sending XMPP ping', debug=True)
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
93 c.pings.append(c.send(ping))
52
5aabf124c78d Fixed XMPP connection closing and the XMPP loop
Charly COSTE <changaco@changaco.net>
parents: 51
diff changeset
94 if hasattr(c, 'Process'):
5aabf124c78d Fixed XMPP connection closing and the XMPP loop
Charly COSTE <changaco@changaco.net>
parents: 51
diff changeset
95 c.Process(0.01)
5aabf124c78d Fixed XMPP connection closing and the XMPP loop
Charly COSTE <changaco@changaco.net>
parents: 51
diff changeset
96 c.lock.release()
75
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
97 if i > 5000:
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
98 i = 0
51
2737ed5b9003 Tried to improve the XMPP loop, again.
Charly COSTE <changaco@changaco.net>
parents: 50
diff changeset
99 except RuntimeError:
2737ed5b9003 Tried to improve the XMPP loop, again.
Charly COSTE <changaco@changaco.net>
parents: 50
diff changeset
100 pass
24
4e1f27ea527b First hack at locks for thread safety. Some other minor changes.
Charly COSTE <changaco@changaco.net>
parents: 23
diff changeset
101 except (xml.parsers.expat.ExpatError, xmpp.protocol.XMLNotWellFormed):
72
6c4b841144f6 Better handling of participants
Charly COSTE <changaco@changaco.net>
parents: 70
diff changeset
102 self.error('=> Debug: invalid stanza', debug=True)
101
29d3b85c6286 Minor fixes/improvements
Charly COSTE <changaco@changaco.net>
parents: 100
diff changeset
103 self.reopen_xmpp_connection(c)
79
73a30fc1922b Fixed the XMPP loop (release the lock)
Charly COSTE <changaco@changaco.net>
parents: 78
diff changeset
104 unlock = True
91
69e4fc0f015c Tried to fix XMPP «Replaced by new connection» problem
Charly COSTE <changaco@changaco.net>
parents: 90
diff changeset
105 except xmpp.Conflict:
101
29d3b85c6286 Minor fixes/improvements
Charly COSTE <changaco@changaco.net>
parents: 100
diff changeset
106 self.error('=> Debug: conflict', debug=True)
100
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
107 self.reopen_xmpp_connection(c)
91
69e4fc0f015c Tried to fix XMPP «Replaced by new connection» problem
Charly COSTE <changaco@changaco.net>
parents: 90
diff changeset
108 unlock = True
51
2737ed5b9003 Tried to improve the XMPP loop, again.
Charly COSTE <changaco@changaco.net>
parents: 50
diff changeset
109 except:
101
29d3b85c6286 Minor fixes/improvements
Charly COSTE <changaco@changaco.net>
parents: 100
diff changeset
110 error = '[Error] Unknown exception on XMPP thread:\n'
86
bfa32b017fc9 First hack at an error notification system
Charly COSTE <changaco@changaco.net>
parents: 79
diff changeset
111 error += traceback.format_exc()
bfa32b017fc9 First hack at an error notification system
Charly COSTE <changaco@changaco.net>
parents: 79
diff changeset
112 self.error(error, send_to_admins=True)
79
73a30fc1922b Fixed the XMPP loop (release the lock)
Charly COSTE <changaco@changaco.net>
parents: 78
diff changeset
113 unlock = True
73a30fc1922b Fixed the XMPP loop (release the lock)
Charly COSTE <changaco@changaco.net>
parents: 78
diff changeset
114 if unlock == True:
73a30fc1922b Fixed the XMPP loop (release the lock)
Charly COSTE <changaco@changaco.net>
parents: 78
diff changeset
115 c.lock.release()
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
116
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
117
22
e2bd4de698e5 Solved an XMPP resource conflict that would have happened when someone on IRC changed its nickname and later its old nickname would be used again. In other words, the bot no longer uses nicknames as XMPP resources.
Charly COSTE <changaco@changaco.net>
parents: 21
diff changeset
118 def _xmpp_presence_handler(self, dispatcher, presence):
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
119 """[Internal] Manage XMPP presence."""
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
120
22
e2bd4de698e5 Solved an XMPP resource conflict that would have happened when someone on IRC changed its nickname and later its old nickname would be used again. In other words, the bot no longer uses nicknames as XMPP resources.
Charly COSTE <changaco@changaco.net>
parents: 21
diff changeset
121 xmpp_c = dispatcher._owner
e2bd4de698e5 Solved an XMPP resource conflict that would have happened when someone on IRC changed its nickname and later its old nickname would be used again. In other words, the bot no longer uses nicknames as XMPP resources.
Charly COSTE <changaco@changaco.net>
parents: 21
diff changeset
122
e2bd4de698e5 Solved an XMPP resource conflict that would have happened when someone on IRC changed its nickname and later its old nickname would be used again. In other words, the bot no longer uses nicknames as XMPP resources.
Charly COSTE <changaco@changaco.net>
parents: 21
diff changeset
123 if xmpp_c.nickname != self.nickname:
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
124 self.error('=> Debug: Skipping XMPP presence not received on bot connection.', debug=True)
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
125 return
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
126
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
127 self.error('==> Debug: Received XMPP presence.', debug=True)
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
128 self.error(presence.__str__(fancy=1), debug=True)
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
129
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
130 from_ = xmpp.protocol.JID(presence.getFrom())
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
131 bare_jid = unicode(from_.getNode()+'@'+from_.getDomain())
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
132 for bridge in self.bridges:
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
133 if bare_jid == bridge.xmpp_room_jid:
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
134 # presence comes from a muc
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
135 resource = unicode(from_.getResource())
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
136
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
137 if resource == '':
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
138 # presence comes from the muc itself
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
139 pass
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
140
108
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
141 elif resource == xmpp_c.nickname:
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
142 # presence comes from self
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
143 x = presence.getTag('x', namespace='http://jabber.org/protocol/muc#user')
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
144 if x:
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
145 d = x.getTag('destroy')
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
146 if d:
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
147 # room was destroyed
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
148 # problem is that this is used by some MUC servers when they shut down or restart
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
149 # considering this lack of semantic we have no choice but to do a check on the reason
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
150 reason = d.getTag('reason')
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
151 if reason:
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
152 r = reason.getData()
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
153 if r == 'The conference component is shutting down':
121
765e460bc20a Restart all bridges connected to a MUC server when it goes down
Charly COSTE <changaco@changaco.net>
parents: 119
diff changeset
154 # MUC server is going down, try to restart the bridges in 1 minute
765e460bc20a Restart all bridges connected to a MUC server when it goes down
Charly COSTE <changaco@changaco.net>
parents: 119
diff changeset
155 bridges = self.findBridges([from_.getDomain()])
765e460bc20a Restart all bridges connected to a MUC server when it goes down
Charly COSTE <changaco@changaco.net>
parents: 119
diff changeset
156 error_message = '[Warning] The MUC server '+from_.getDomain()+' seems to be going down, the bot will try to recreate all bridges related to this server in 1 minute'
765e460bc20a Restart all bridges connected to a MUC server when it goes down
Charly COSTE <changaco@changaco.net>
parents: 119
diff changeset
157 self.restart_bridges_delayed(bridges, 60, error_message)
765e460bc20a Restart all bridges connected to a MUC server when it goes down
Charly COSTE <changaco@changaco.net>
parents: 119
diff changeset
158 self.error(presence.__str__(fancy=1).encode('utf-8'), debug=True)
108
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
159 return
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
160 elif r == '':
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
161 r = 'None given'
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
162 else:
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
163 r = 'None given'
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
164
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
165 # room has been destroyed, stop the bridge
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
166 self.error('[Error] The MUC room of the bridge '+str(bridge)+' has been destroyed with reason "'+r+'", stopping the bridge', send_to_admins=True)
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
167 bridge.stop(message='The MUC room of the bridge has been destroyed with reason "'+r+'", stopping the bridge')
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
168
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
169 else:
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
170 # presence comes from a participant of the muc
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
171
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
172 x = presence.getTag('x', namespace='http://jabber.org/protocol/muc#user')
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
173 item = None
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
174 if x:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
175 item = x.getTag('item')
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
176
93
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
177 if presence.getType() == 'unavailable':
96
dd7e1b935894 Code cleaning
Charly COSTE <changaco@changaco.net>
parents: 93
diff changeset
178 try:
dd7e1b935894 Code cleaning
Charly COSTE <changaco@changaco.net>
parents: 93
diff changeset
179 p = bridge.getParticipant(resource)
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
180 except Bridge.NoSuchParticipantException:
96
dd7e1b935894 Code cleaning
Charly COSTE <changaco@changaco.net>
parents: 93
diff changeset
181 p = None
dd7e1b935894 Code cleaning
Charly COSTE <changaco@changaco.net>
parents: 93
diff changeset
182
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
183 if x and x.getTag('status', attrs={'code': '303'}):
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
184 # participant changed its nickname
93
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
185 if p == None:
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
186 return
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
187 if p.protocol != 'xmpp':
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
188 return
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
189 item = x.getTag('item')
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
190 if not item:
19
c1b84196c100 Changed format of non-debug error messages, fixed IRC namreply handling, prevented crash when receiving bad XMPP stanza.
Charly COSTE <changaco@changaco.net>
parents: 18
diff changeset
191 self.error('=> Debug: bad stanza, no item element', debug=True)
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
192 return
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
193 new_nick = item.getAttr('nick')
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
194 if not new_nick:
19
c1b84196c100 Changed format of non-debug error messages, fixed IRC namreply handling, prevented crash when receiving bad XMPP stanza.
Charly COSTE <changaco@changaco.net>
parents: 18
diff changeset
195 self.error('=> Debug: bad stanza, new nick is not given', debug=True)
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
196 return
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
197 p.changeNickname(new_nick, 'irc')
93
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
198
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
199 elif x and x.getTag('status', attrs={'code': '307'}):
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
200 # participant was kicked
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
201 if p == None:
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
202 bridge.xmpp_room.rejoin()
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
203 return
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
204 if isinstance(p.xmpp_c, xmpp.client.Client):
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
205 p.muc.rejoin()
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
206 else:
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
207 if item:
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
208 reason = item.getTag('reason')
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
209 actor = item.getTag('actor')
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
210 if actor and actor.has_attr('jid'):
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
211 kicker = actor.getAttr('jid')
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
212 s1 = 'Kicked by '+kicker
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
213 else:
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
214 s1 = 'Kicked from XMPP'
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
215 if reason:
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
216 s2 = ' with reason: '+reason.getData()
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
217 else:
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
218 s2 = ' (no reason was given)'
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
219 else:
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
220 s1 = 'Kicked from XMPP'
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
221 s2 = ' (no reason was given)'
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
222
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
223 bridge.removeParticipant('xmpp', p.nickname, s1+s2)
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
224
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
225 elif x and x.getTag('status', attrs={'code': '301'}):
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
226 # participant was banned
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
227 if p == None:
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
228 m = '[Error] bot got banned from XMPP'
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
229 self.error(m)
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
230 bridge.say(m, on_xmpp=False)
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
231 self.removeBridge(bridge)
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
232 return
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
233 if item:
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
234 reason = item.getTag('reason')
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
235 actor = item.getTag('actor')
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
236 if actor and actor.has_attr('jid'):
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
237 kicker = actor.getAttr('jid')
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
238 s1 = 'Banned by '+kicker
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
239 else:
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
240 s1 = 'Banned from XMPP'
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
241 if reason:
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
242 s2 = ' with reason: '+reason.getData()
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
243 else:
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
244 s2 = ' (no reason was given)'
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
245 else:
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
246 s1 = 'Banned from XMPP'
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
247 s2 = ' (no reason was given)'
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
248
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
249 bridge.removeParticipant('xmpp', p.nickname, s1+s2)
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
250
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
251 else:
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
252 # participant left
99
5390e9abfa44 Don't try to remove a participant that does not exist
Charly COSTE <changaco@changaco.net>
parents: 96
diff changeset
253 if p != None:
5390e9abfa44 Don't try to remove a participant that does not exist
Charly COSTE <changaco@changaco.net>
parents: 96
diff changeset
254 bridge.removeParticipant('xmpp', resource, presence.getStatus())
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
255
111
59401ac0f47a handle XMPP remote-server-not-found
Charly COSTE <changaco@changaco.net>
parents: 110
diff changeset
256 elif presence.getType() == 'error':
59401ac0f47a handle XMPP remote-server-not-found
Charly COSTE <changaco@changaco.net>
parents: 110
diff changeset
257 error = presence.getTag('error')
59401ac0f47a handle XMPP remote-server-not-found
Charly COSTE <changaco@changaco.net>
parents: 110
diff changeset
258 if error:
59401ac0f47a handle XMPP remote-server-not-found
Charly COSTE <changaco@changaco.net>
parents: 110
diff changeset
259 for c in error.getChildren():
59401ac0f47a handle XMPP remote-server-not-found
Charly COSTE <changaco@changaco.net>
parents: 110
diff changeset
260 if c.getNamespace() == 'urn:ietf:params:xml:ns:xmpp-stanzas' and c.getName() != 'text':
59401ac0f47a handle XMPP remote-server-not-found
Charly COSTE <changaco@changaco.net>
parents: 110
diff changeset
261 err = error.getAttr('type')+' '+c.getName()
59401ac0f47a handle XMPP remote-server-not-found
Charly COSTE <changaco@changaco.net>
parents: 110
diff changeset
262 if err == 'cancel remote-server-not-found':
59401ac0f47a handle XMPP remote-server-not-found
Charly COSTE <changaco@changaco.net>
parents: 110
diff changeset
263 # Remote server not found
59401ac0f47a handle XMPP remote-server-not-found
Charly COSTE <changaco@changaco.net>
parents: 110
diff changeset
264 # Stop bridges that depend on this server
59401ac0f47a handle XMPP remote-server-not-found
Charly COSTE <changaco@changaco.net>
parents: 110
diff changeset
265 bridges = self.findBridges([from_.getDomain()])
121
765e460bc20a Restart all bridges connected to a MUC server when it goes down
Charly COSTE <changaco@changaco.net>
parents: 119
diff changeset
266 error_message = '[Error] XMPP Remote server not found: '+from_.getDomain()
765e460bc20a Restart all bridges connected to a MUC server when it goes down
Charly COSTE <changaco@changaco.net>
parents: 119
diff changeset
267 self.restart_bridges_delayed(bridges, 60, error_message)
111
59401ac0f47a handle XMPP remote-server-not-found
Charly COSTE <changaco@changaco.net>
parents: 110
diff changeset
268 self.error(presence.__str__(fancy=1).encode('utf-8'), debug=True)
59401ac0f47a handle XMPP remote-server-not-found
Charly COSTE <changaco@changaco.net>
parents: 110
diff changeset
269 else:
59401ac0f47a handle XMPP remote-server-not-found
Charly COSTE <changaco@changaco.net>
parents: 110
diff changeset
270 raise Exception(presence.__str__(fancy=1).encode('utf-8'))
59401ac0f47a handle XMPP remote-server-not-found
Charly COSTE <changaco@changaco.net>
parents: 110
diff changeset
271
96
dd7e1b935894 Code cleaning
Charly COSTE <changaco@changaco.net>
parents: 93
diff changeset
272 elif resource != bridge.bot.nickname:
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
273 real_jid = None
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
274 if item and item.has_attr('jid'):
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
275 real_jid = item.getAttr('jid')
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
276
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
277 p = bridge.addParticipant('xmpp', resource, real_jid)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
278
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
279 # if we have the real jid check if the participant is a bot admin
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
280 if real_jid and isinstance(p, Participant):
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
281 for jid in self.admins_jid:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
282 if xmpp.protocol.JID(jid).bareMatch(real_jid):
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
283 p.bot_admin = True
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
284 break
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
285
96
dd7e1b935894 Code cleaning
Charly COSTE <changaco@changaco.net>
parents: 93
diff changeset
286 return
dd7e1b935894 Code cleaning
Charly COSTE <changaco@changaco.net>
parents: 93
diff changeset
287
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
288 return
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
289
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
290
22
e2bd4de698e5 Solved an XMPP resource conflict that would have happened when someone on IRC changed its nickname and later its old nickname would be used again. In other words, the bot no longer uses nicknames as XMPP resources.
Charly COSTE <changaco@changaco.net>
parents: 21
diff changeset
291 def _xmpp_iq_handler(self, dispatcher, iq):
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
292 """[Internal] Manage XMPP IQs."""
75
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
293
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
294 xmpp_c = dispatcher._owner
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
295
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
296 # Ignore pongs
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
297 if iq.getType() in ['result', 'error'] and iq.getID() in xmpp_c.pings:
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
298 xmpp_c.pings.remove(iq.getID())
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
299 self.error('=> Debug: received XMPP pong', debug=True)
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
300 return
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
301
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
302 self.error('==> Debug: Received XMPP iq.', debug=True)
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
303 self.error(iq.__str__(fancy=1), debug=True)
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
304
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
305
22
e2bd4de698e5 Solved an XMPP resource conflict that would have happened when someone on IRC changed its nickname and later its old nickname would be used again. In other words, the bot no longer uses nicknames as XMPP resources.
Charly COSTE <changaco@changaco.net>
parents: 21
diff changeset
306 def _xmpp_message_handler(self, dispatcher, message):
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
307 """[Internal] Manage XMPP messages."""
22
e2bd4de698e5 Solved an XMPP resource conflict that would have happened when someone on IRC changed its nickname and later its old nickname would be used again. In other words, the bot no longer uses nicknames as XMPP resources.
Charly COSTE <changaco@changaco.net>
parents: 21
diff changeset
308
e2bd4de698e5 Solved an XMPP resource conflict that would have happened when someone on IRC changed its nickname and later its old nickname would be used again. In other words, the bot no longer uses nicknames as XMPP resources.
Charly COSTE <changaco@changaco.net>
parents: 21
diff changeset
309 xmpp_c = dispatcher._owner
e2bd4de698e5 Solved an XMPP resource conflict that would have happened when someone on IRC changed its nickname and later its old nickname would be used again. In other words, the bot no longer uses nicknames as XMPP resources.
Charly COSTE <changaco@changaco.net>
parents: 21
diff changeset
310
34
57d0e66378b0 Fixed XMPP message handling and removed disconnect handler.
Charly COSTE <changaco@changaco.net>
parents: 33
diff changeset
311 if message.getBody() == None:
57d0e66378b0 Fixed XMPP message handling and removed disconnect handler.
Charly COSTE <changaco@changaco.net>
parents: 33
diff changeset
312 return
57d0e66378b0 Fixed XMPP message handling and removed disconnect handler.
Charly COSTE <changaco@changaco.net>
parents: 33
diff changeset
313
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
314 if message.getType() == 'chat':
11
79b0a7f48a3e Introduced the command mechanism and fixed a bug
Charly COSTE <changaco@changaco.net>
parents: 10
diff changeset
315 from_bare_jid = unicode(message.getFrom().getNode()+'@'+message.getFrom().getDomain())
79b0a7f48a3e Introduced the command mechanism and fixed a bug
Charly COSTE <changaco@changaco.net>
parents: 10
diff changeset
316 for bridge in self.bridges:
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
317 if from_bare_jid == bridge.xmpp_room_jid:
11
79b0a7f48a3e Introduced the command mechanism and fixed a bug
Charly COSTE <changaco@changaco.net>
parents: 10
diff changeset
318 # message comes from a room participant
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
319
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
320 self.error('==> Debug: Received XMPP chat message.', debug=True)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
321 self.error(message.__str__(fancy=1), debug=True)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
322
11
79b0a7f48a3e Introduced the command mechanism and fixed a bug
Charly COSTE <changaco@changaco.net>
parents: 10
diff changeset
323 try:
79b0a7f48a3e Introduced the command mechanism and fixed a bug
Charly COSTE <changaco@changaco.net>
parents: 10
diff changeset
324 from_ = bridge.getParticipant(message.getFrom().getResource())
27
9b7a628ca612 Fixed XMPP message handling, again.
Charly COSTE <changaco@changaco.net>
parents: 25
diff changeset
325 to_ = bridge.getParticipant(xmpp_c.nickname)
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
326
34
57d0e66378b0 Fixed XMPP message handling and removed disconnect handler.
Charly COSTE <changaco@changaco.net>
parents: 33
diff changeset
327 from_.sayOnIRCTo(to_.nickname, message.getBody())
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
328
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
329 except Bridge.NoSuchParticipantException:
22
e2bd4de698e5 Solved an XMPP resource conflict that would have happened when someone on IRC changed its nickname and later its old nickname would be used again. In other words, the bot no longer uses nicknames as XMPP resources.
Charly COSTE <changaco@changaco.net>
parents: 21
diff changeset
330 if xmpp_c.nickname == self.nickname:
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
331 r = self.respond(str(message.getBody()), participant=from_)
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
332 if isinstance(r, basestring) and len(r) > 0:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
333 s = xmpp.protocol.Message(to=message.getFrom(), body=r, typ='chat')
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
334 self.error('==> Debug: Sending', debug=True)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
335 self.error(s.__str__(fancy=1), debug=True)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
336 xmpp_c.send(s)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
337 else:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
338 self.error('=> Debug: won\'t answer.', debug=True)
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
339 return
22
e2bd4de698e5 Solved an XMPP resource conflict that would have happened when someone on IRC changed its nickname and later its old nickname would be used again. In other words, the bot no longer uses nicknames as XMPP resources.
Charly COSTE <changaco@changaco.net>
parents: 21
diff changeset
340 self.error('=> Debug: XMPP chat message not relayed', debug=True)
11
79b0a7f48a3e Introduced the command mechanism and fixed a bug
Charly COSTE <changaco@changaco.net>
parents: 10
diff changeset
341 return
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
342
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
343 # message does not come from a room
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
344 if xmpp_c.nickname == self.nickname:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
345 self.error('==> Debug: Received XMPP chat message.', debug=True)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
346 self.error(message.__str__(fancy=1), debug=True)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
347
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
348 # Find out if the message comes from a bot admin
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
349 bot_admin = False
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
350 for jid in self.admins_jid:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
351 if xmpp.protocol.JID(jid).bareMatch(message.getFrom()):
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
352 bot_admin = True
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
353 break
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
354
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
355 # Respond
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
356 r = self.respond(str(message.getBody()), bot_admin=bot_admin)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
357 if isinstance(r, basestring) and len(r) > 0:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
358 s = xmpp.protocol.Message(to=message.getFrom(), body=r, typ='chat')
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
359 self.error('==> Debug: Sending', debug=True)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
360 self.error(s.__str__(fancy=1), debug=True)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
361 xmpp_c.send(s)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
362
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
363 else:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
364 self.error('=> Debug: Ignoring XMPP chat message not received on bot connection.', debug=True)
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
365
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
366 elif message.getType() == 'groupchat':
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
367 # message comes from a room
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
368
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
369 for child in message.getChildren():
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
370 if child.getName() == 'delay':
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
371 # MUC delayed message
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
372 return
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
373
22
e2bd4de698e5 Solved an XMPP resource conflict that would have happened when someone on IRC changed its nickname and later its old nickname would be used again. In other words, the bot no longer uses nicknames as XMPP resources.
Charly COSTE <changaco@changaco.net>
parents: 21
diff changeset
374 if xmpp_c.nickname != self.nickname:
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
375 self.error('=> Debug: Ignoring XMPP MUC message not received on bot connection.', debug=True)
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
376 return
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
377
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
378
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
379 from_ = xmpp.protocol.JID(message.getFrom())
23
abdb7a2b6c6d Minor fixes.
Charly COSTE <changaco@changaco.net>
parents: 22
diff changeset
380
abdb7a2b6c6d Minor fixes.
Charly COSTE <changaco@changaco.net>
parents: 22
diff changeset
381 if unicode(from_.getResource()) == self.nickname:
abdb7a2b6c6d Minor fixes.
Charly COSTE <changaco@changaco.net>
parents: 22
diff changeset
382 self.error('=> Debug: Ignoring XMPP MUC message sent by self.', debug=True)
abdb7a2b6c6d Minor fixes.
Charly COSTE <changaco@changaco.net>
parents: 22
diff changeset
383 return
abdb7a2b6c6d Minor fixes.
Charly COSTE <changaco@changaco.net>
parents: 22
diff changeset
384
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
385 room_jid = unicode(from_.getNode()+'@'+from_.getDomain())
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
386 for bridge in self.bridges:
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
387 if room_jid == bridge.xmpp_room_jid:
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
388 resource = unicode(from_.getResource())
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
389 if resource == '':
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
390 # message comes from the room itself
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
391 self.error('=> Debug: Ignoring XMPP groupchat message sent by the room.', debug=True)
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
392 return
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
393 else:
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
394 # message comes from a participant of the room
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
395 self.error('==> Debug: Received XMPP groupchat message.', debug=True)
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
396 self.error(message.__str__(fancy=1), debug=True)
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
397
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
398 try:
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
399 participant = bridge.getParticipant(resource)
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
400 except Bridge.NoSuchParticipantException:
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
401 if resource != self.nickname:
37
7e500d4064fb Cosmetics.
Charly COSTE <changaco@changaco.net>
parents: 35
diff changeset
402 self.error('=> Debug: NoSuchParticipantException "'+resource+'" on "'+str(bridge)+'", WTF ?', debug=True)
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
403 return
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
404
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
405 participant.sayOnIRC(message.getBody())
37
7e500d4064fb Cosmetics.
Charly COSTE <changaco@changaco.net>
parents: 35
diff changeset
406 return
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
407
105
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
408 elif message.getType() == 'error':
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
409 for b in self.bridges:
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
410 if message.getFrom() == b.xmpp_room_jid:
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
411 # message comes from a room
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
412 for c in message.getChildren():
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
413 if c.getName() == 'error':
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
414 for cc in c.getChildren():
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
415 if cc.getNamespace() == 'urn:ietf:params:xml:ns:xmpp-stanzas' and cc.getName() != 'text':
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
416 err = cc.getName()
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
417 if err == 'not-acceptable':
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
418 # we sent a message to a room we are not in
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
419 # probable cause is a MUC server restart
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
420 # let's restart the bot
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
421 self.restart()
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
422 elif err == 'forbidden':
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
423 # we don't have the permission to speak
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
424 # let's remove the bridge and tell admins
112
a817ad05dd1d stop bridge on error instead of removing it
Charly COSTE <changaco@changaco.net>
parents: 111
diff changeset
425 self.error('[Error] Not allowed to speak on the XMPP MUC of bridge '+str(b)+', stopping it', send_to_admins=True)
a817ad05dd1d stop bridge on error instead of removing it
Charly COSTE <changaco@changaco.net>
parents: 111
diff changeset
426 b.stop(message='Not allowed to speak on the XMPP MUC, stopping bridge.')
105
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
427 else:
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
428 self.error('==> Debug: recevied unknown error message', debug=True)
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
429 self.error(message.__str__(fancy=1), debug=True)
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
430 return
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
431
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
432 self.error('==> Debug: recevied unknown error message', debug=True)
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
433 self.error(message.__str__(fancy=1), debug=True)
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
434
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
435 else:
141
46c02cc89f18 minor fix
Charly COSTE <changaco@changaco.net>
parents: 137
diff changeset
436 self.error('==> Debug: Received XMPP message of unknown type "'+str(message.getType())+'".', debug=True)
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
437 self.error(message.__str__(fancy=1), debug=True)
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
438
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
439
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
440 def _irc_event_handler(self, connection, event):
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
441 """[Internal] Manage IRC events"""
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
442
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
443 # Answer ping
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
444 if event.eventtype() == 'ping':
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
445 connection.pong(connection.get_server_name())
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
446 return
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
447
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
448
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
449 # Events we always want to ignore
166
0fc24e232997 some fixes related to IRC nicknames
Charly COSTE <changaco@changaco.net>
parents: 156
diff changeset
450 if 'all' in event.eventtype() or 'motd' in event.eventtype() or event.eventtype() in ['nicknameinuse', 'nickcollision', 'erroneusnickname']:
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
451 return
144
fcab2bdf1d65 added an IRC event to ignore
Charly COSTE <changaco@changaco.net>
parents: 141
diff changeset
452 if event.eventtype() in ['pong', 'privnotice', 'ctcp', 'nochanmodes', 'notexttosend', 'currenttopic', 'topicinfo', '328']:
75
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
453 self.error('=> Debug: ignoring IRC '+event.eventtype(), debug=True)
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
454 return
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
455
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
456
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
457 nickname = None
24
4e1f27ea527b First hack at locks for thread safety. Some other minor changes.
Charly COSTE <changaco@changaco.net>
parents: 23
diff changeset
458 if event.source() != None:
4e1f27ea527b First hack at locks for thread safety. Some other minor changes.
Charly COSTE <changaco@changaco.net>
parents: 23
diff changeset
459 if '!' in event.source():
4e1f27ea527b First hack at locks for thread safety. Some other minor changes.
Charly COSTE <changaco@changaco.net>
parents: 23
diff changeset
460 nickname = event.source().split('!')[0]
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
461
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
462
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
463 # Events that we want to ignore only in some cases
14
1a1f2a0d35c7 Fixed bug that prevented the bot from connecting to freenode and all other servers that don't send "umode"
Charly COSTE <changaco@changaco.net>
parents: 11
diff changeset
464 if event.eventtype() in ['umode', 'welcome', 'yourhost', 'created', 'myinfo', 'featurelist', 'luserclient', 'luserop', 'luserchannels', 'luserme', 'n_local', 'n_global', 'endofnames', 'luserunknown', 'luserconns']:
1a1f2a0d35c7 Fixed bug that prevented the bot from connecting to freenode and all other servers that don't send "umode"
Charly COSTE <changaco@changaco.net>
parents: 11
diff changeset
465 if connection.really_connected == False:
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
466 if event.target() == connection.nickname:
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
467 connection.really_connected = True
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
468 connection._call_nick_callbacks(None)
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
469 elif len(connection.nick_callbacks) > 0:
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
470 self.error('===> Debug: event target ('+event.target()+') and connection nickname ('+connection.nickname+') don\'t match')
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
471 connection._call_nick_callbacks('nicknametoolong', arguments=[len(event.target())])
14
1a1f2a0d35c7 Fixed bug that prevented the bot from connecting to freenode and all other servers that don't send "umode"
Charly COSTE <changaco@changaco.net>
parents: 11
diff changeset
472 self.error('=> Debug: ignoring '+event.eventtype(), debug=True)
1a1f2a0d35c7 Fixed bug that prevented the bot from connecting to freenode and all other servers that don't send "umode"
Charly COSTE <changaco@changaco.net>
parents: 11
diff changeset
473 return
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
474
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
475
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
476 # A string representation of the event
172
64a0e9636ae6 removed encoding.py, charsets handling is now in irclib and custom charsets can be set per server in the configuration file
Charly COSTE <changaco@changaco.net>
parents: 171
diff changeset
477 event_str = '==> Debug: Received IRC event.\nconnection='+connection.__str__()+'\neventtype='+event.eventtype()+'\nsource='+repr(event.source())+'\ntarget='+repr(event.target())+'\narguments='+repr(event.arguments())
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
478
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
479
53
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
480 if event.eventtype() in ['pubmsg', 'action', 'privmsg', 'quit', 'part', 'nick', 'kick']:
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
481 if nickname == None:
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
482 return
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
483
39
3b06450d60cd Improved debug output.
Charly COSTE <changaco@changaco.net>
parents: 37
diff changeset
484 handled = False
3b06450d60cd Improved debug output.
Charly COSTE <changaco@changaco.net>
parents: 37
diff changeset
485
53
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
486 if event.eventtype() in ['quit', 'part', 'nick', 'kick']:
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
487 if connection.get_nickname() != self.nickname:
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
488 self.error('=> Debug: ignoring IRC '+event.eventtype()+' not received on bot connection', debug=True)
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
489 return
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
490 else:
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
491 self.error(event_str, debug=True)
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
492
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
493 if event.eventtype() == 'kick' and len(event.arguments()) < 1:
58
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
494 self.error('=> Debug: length of arguments should be greater than 0 for a '+event.eventtype()+' event')
53
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
495 return
39
3b06450d60cd Improved debug output.
Charly COSTE <changaco@changaco.net>
parents: 37
diff changeset
496
54
2507f424773a Fixed a bug introduced in previous commit
Charly COSTE <changaco@changaco.net>
parents: 53
diff changeset
497 if event.eventtype() in ['pubmsg', 'action']:
55
c09f9523fe2e I'm stupid ...
Charly COSTE <changaco@changaco.net>
parents: 54
diff changeset
498 if connection.get_nickname() != self.nickname:
54
2507f424773a Fixed a bug introduced in previous commit
Charly COSTE <changaco@changaco.net>
parents: 53
diff changeset
499 self.error('=> Debug: ignoring IRC '+event.eventtype()+' not received on bot connection', debug=True)
2507f424773a Fixed a bug introduced in previous commit
Charly COSTE <changaco@changaco.net>
parents: 53
diff changeset
500 return
2507f424773a Fixed a bug introduced in previous commit
Charly COSTE <changaco@changaco.net>
parents: 53
diff changeset
501 if nickname == self.nickname:
2507f424773a Fixed a bug introduced in previous commit
Charly COSTE <changaco@changaco.net>
parents: 53
diff changeset
502 self.error('=> Debug: ignoring IRC '+event.eventtype()+' sent by self', debug=True)
2507f424773a Fixed a bug introduced in previous commit
Charly COSTE <changaco@changaco.net>
parents: 53
diff changeset
503 return
50
dbb7c29a71e2 Ignore messages sent by self
Charly COSTE <changaco@changaco.net>
parents: 49
diff changeset
504
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
505 # TODO: lock self.bridges for thread safety
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
506 for bridge in self.bridges:
32
8aa261545662 Implemented "/me" in the IRC->XMPP way (ie "action" event is now handled). Re-written bot.getBridges because the old one didn't always work and was slow.
Charly COSTE <changaco@changaco.net>
parents: 30
diff changeset
507 if connection.server != bridge.irc_server:
8aa261545662 Implemented "/me" in the IRC->XMPP way (ie "action" event is now handled). Re-written bot.getBridges because the old one didn't always work and was slow.
Charly COSTE <changaco@changaco.net>
parents: 30
diff changeset
508 continue
8aa261545662 Implemented "/me" in the IRC->XMPP way (ie "action" event is now handled). Re-written bot.getBridges because the old one didn't always work and was slow.
Charly COSTE <changaco@changaco.net>
parents: 30
diff changeset
509
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
510 try:
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
511 from_ = bridge.getParticipant(nickname)
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
512
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
513 except Bridge.NoSuchParticipantException:
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
514 continue
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
515
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
516
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
517 # Private message
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
518 if event.eventtype() == 'privmsg':
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
519 if event.target() == None:
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
520 return
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
521
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
522 try:
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
523 to_ = bridge.getParticipant(event.target().split('!')[0])
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
524 self.error(event_str, debug=True)
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
525 from_.sayOnXMPPTo(to_.nickname, event.arguments()[0])
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
526 return
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
527
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
528 except Bridge.NoSuchParticipantException:
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
529 if event.target().split('!')[0] == self.nickname:
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
530 # Message is for the bot
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
531 self.error(event_str, debug=True)
18
3cdf7bb580da Fixed bot.respond(), boosted XMPP thread to lower latency, fixed mode notice.
Charly COSTE <changaco@changaco.net>
parents: 17
diff changeset
532 connection.privmsg(from_.nickname, self.respond(event.arguments()[0]))
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
533 return
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
534 else:
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
535 continue
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
536
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
537
92
aae8870b3727 Better handling of IRC kick
Charly COSTE <changaco@changaco.net>
parents: 91
diff changeset
538 # kick handling
53
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
539 if event.eventtype() == 'kick':
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
540 if event.target().lower() == bridge.irc_room:
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
541 try:
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
542 kicked = bridge.getParticipant(event.arguments()[0])
72
6c4b841144f6 Better handling of participants
Charly COSTE <changaco@changaco.net>
parents: 70
diff changeset
543 if isinstance(kicked.irc_connection, irclib.ServerConnection):
53
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
544 kicked.irc_connection.join(bridge.irc_room)
93
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
545 else:
92
aae8870b3727 Better handling of IRC kick
Charly COSTE <changaco@changaco.net>
parents: 91
diff changeset
546 if len(event.arguments()) > 1:
aae8870b3727 Better handling of IRC kick
Charly COSTE <changaco@changaco.net>
parents: 91
diff changeset
547 bridge.removeParticipant('irc', kicked.nickname, 'Kicked by '+nickname+' with reason: '+event.arguments()[1])
aae8870b3727 Better handling of IRC kick
Charly COSTE <changaco@changaco.net>
parents: 91
diff changeset
548 else:
aae8870b3727 Better handling of IRC kick
Charly COSTE <changaco@changaco.net>
parents: 91
diff changeset
549 bridge.removeParticipant('irc', kicked.nickname, 'Kicked by '+nickname+' (no reason was given)')
58
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
550 return
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
551 except Bridge.NoSuchParticipantException:
53
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
552 self.error('=> Debug: a participant that was not here has been kicked ? WTF ?')
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
553 return
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
554 else:
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
555 continue
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
556
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
557
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
558 # Leaving events
45
41394ddb3aff Lower before comparing strings.
Charly COSTE <changaco@changaco.net>
parents: 44
diff changeset
559 if event.eventtype() == 'quit' or event.eventtype() == 'part' and event.target().lower() == bridge.irc_room:
78
a8749705fe94 Fixed IRC quit event handling
Charly COSTE <changaco@changaco.net>
parents: 77
diff changeset
560 if event.eventtype() == 'quit' and ( bridge.mode != 'normal' or isinstance(from_.irc_connection, irclib.ServerConnection) ):
a8749705fe94 Fixed IRC quit event handling
Charly COSTE <changaco@changaco.net>
parents: 77
diff changeset
561 continue
30
c0fb916cb0a0 Fixed IRC leaving events handling.
Charly COSTE <changaco@changaco.net>
parents: 29
diff changeset
562 if len(event.arguments()) > 0:
c0fb916cb0a0 Fixed IRC leaving events handling.
Charly COSTE <changaco@changaco.net>
parents: 29
diff changeset
563 leave_message = event.arguments()[0]
c0fb916cb0a0 Fixed IRC leaving events handling.
Charly COSTE <changaco@changaco.net>
parents: 29
diff changeset
564 elif event.eventtype() == 'quit':
c0fb916cb0a0 Fixed IRC leaving events handling.
Charly COSTE <changaco@changaco.net>
parents: 29
diff changeset
565 leave_message = 'Left server.'
c0fb916cb0a0 Fixed IRC leaving events handling.
Charly COSTE <changaco@changaco.net>
parents: 29
diff changeset
566 elif event.eventtype() == 'part':
c0fb916cb0a0 Fixed IRC leaving events handling.
Charly COSTE <changaco@changaco.net>
parents: 29
diff changeset
567 leave_message = 'Left channel.'
c0fb916cb0a0 Fixed IRC leaving events handling.
Charly COSTE <changaco@changaco.net>
parents: 29
diff changeset
568 else:
c0fb916cb0a0 Fixed IRC leaving events handling.
Charly COSTE <changaco@changaco.net>
parents: 29
diff changeset
569 leave_message = ''
c0fb916cb0a0 Fixed IRC leaving events handling.
Charly COSTE <changaco@changaco.net>
parents: 29
diff changeset
570 bridge.removeParticipant('irc', from_.nickname, leave_message)
39
3b06450d60cd Improved debug output.
Charly COSTE <changaco@changaco.net>
parents: 37
diff changeset
571 handled = True
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
572 continue
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
573
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
574
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
575 # Nickname change
41
4c4f4ee72e17 Fixed IRC "nick" event handling. Fixed bot's XMPP infinite loop.
Charly COSTE <changaco@changaco.net>
parents: 39
diff changeset
576 if event.eventtype() == 'nick':
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
577 from_.changeNickname(event.target(), 'xmpp')
39
3b06450d60cd Improved debug output.
Charly COSTE <changaco@changaco.net>
parents: 37
diff changeset
578 handled = True
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
579 continue
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
580
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
581
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
582 # Chan message
32
8aa261545662 Implemented "/me" in the IRC->XMPP way (ie "action" event is now handled). Re-written bot.getBridges because the old one didn't always work and was slow.
Charly COSTE <changaco@changaco.net>
parents: 30
diff changeset
583 if event.eventtype() in ['pubmsg', 'action']:
45
41394ddb3aff Lower before comparing strings.
Charly COSTE <changaco@changaco.net>
parents: 44
diff changeset
584 if bridge.irc_room == event.target().lower() and bridge.irc_server == connection.server:
39
3b06450d60cd Improved debug output.
Charly COSTE <changaco@changaco.net>
parents: 37
diff changeset
585 self.error(event_str, debug=True)
32
8aa261545662 Implemented "/me" in the IRC->XMPP way (ie "action" event is now handled). Re-written bot.getBridges because the old one didn't always work and was slow.
Charly COSTE <changaco@changaco.net>
parents: 30
diff changeset
586 message = event.arguments()[0]
8aa261545662 Implemented "/me" in the IRC->XMPP way (ie "action" event is now handled). Re-written bot.getBridges because the old one didn't always work and was slow.
Charly COSTE <changaco@changaco.net>
parents: 30
diff changeset
587 if event.eventtype() == 'action':
8aa261545662 Implemented "/me" in the IRC->XMPP way (ie "action" event is now handled). Re-written bot.getBridges because the old one didn't always work and was slow.
Charly COSTE <changaco@changaco.net>
parents: 30
diff changeset
588 message = '/me '+message
8aa261545662 Implemented "/me" in the IRC->XMPP way (ie "action" event is now handled). Re-written bot.getBridges because the old one didn't always work and was slow.
Charly COSTE <changaco@changaco.net>
parents: 30
diff changeset
589 from_.sayOnXMPP(message)
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
590 return
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
591 else:
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
592 continue
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
593
39
3b06450d60cd Improved debug output.
Charly COSTE <changaco@changaco.net>
parents: 37
diff changeset
594 if handled == False:
53
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
595 if not event.eventtype() in ['quit', 'part', 'nick', 'kick']:
39
3b06450d60cd Improved debug output.
Charly COSTE <changaco@changaco.net>
parents: 37
diff changeset
596 self.error(event_str, debug=True)
44
3d964ca1cf89 Fixed XMPP infinite loop and a debug message that wasn't flagged as a debug one.
Charly COSTE <changaco@changaco.net>
parents: 42
diff changeset
597 self.error('=> Debug: event was not handled', debug=True)
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
598 return
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
599
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
600
58
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
601 # Handle bannedfromchan
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
602 if event.eventtype() == 'bannedfromchan':
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
603 if len(event.arguments()) < 1:
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
604 self.error('=> Debug: length of arguments should be greater than 0 for a '+event.eventtype()+' event')
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
605 return
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
606
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
607 for bridge in self.bridges:
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
608 if connection.server != bridge.irc_server or event.arguments()[0].lower() != bridge.irc_room:
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
609 continue
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
610
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
611 if event.target() == self.nickname:
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
612 self.error('[Error] the nickname "'+event.target()+'" is banned from the IRC chan of bridge "'+str(bridge)+'"')
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
613 raise Exception('[Error] the nickname "'+event.target()+'" is banned from the IRC chan of bridge "'+str(bridge)+'"')
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
614 else:
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
615 try:
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
616 banned = bridge.getParticipant(event.target())
72
6c4b841144f6 Better handling of participants
Charly COSTE <changaco@changaco.net>
parents: 70
diff changeset
617 if banned.irc_connection != 'bannedfromchan':
6c4b841144f6 Better handling of participants
Charly COSTE <changaco@changaco.net>
parents: 70
diff changeset
618 banned.irc_connection = 'bannedfromchan'
58
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
619 self.error(event_str, debug=True)
137
9f39cead20cb reduced duplication of error messages
Charly COSTE <changaco@changaco.net>
parents: 134
diff changeset
620 bridge.say('[Warning] the nickname "'+event.target()+'" is banned from the IRC chan', log=True)
58
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
621 else:
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
622 self.error('=> Debug: ignoring '+event.eventtype(), debug=True)
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
623 except Bridge.NoSuchParticipantException:
58
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
624 self.error('=> Debug: no such participant. WTF ?')
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
625 return
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
626
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
627 return
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
628
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
629
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
630 # Joining events
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
631 if event.eventtype() in ['namreply', 'join']:
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
632 if connection.get_nickname() != self.nickname:
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
633 self.error('=> Debug: ignoring IRC '+event.eventtype()+' not received on bridge connection', debug=True)
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
634 return
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
635
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
636 if event.eventtype() == 'namreply':
48
cb08ea878db9 lower() for "join" and "namreply" IRC events
Charly COSTE <changaco@changaco.net>
parents: 47
diff changeset
637 for bridge in self.getBridges(irc_room=event.arguments()[1].lower(), irc_server=connection.server):
77
686724c5183c Fixed IRC namreply handling
Charly COSTE <changaco@changaco.net>
parents: 75
diff changeset
638 for nickname in re.split('(?:^[&@\+%]?|(?: [&@\+%]?)*)', event.arguments()[2].strip()):
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
639 if nickname == '' or nickname == self.nickname:
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
640 continue
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
641 bridge.addParticipant('irc', nickname)
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
642 return
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
643 elif event.eventtype() == 'join':
48
cb08ea878db9 lower() for "join" and "namreply" IRC events
Charly COSTE <changaco@changaco.net>
parents: 47
diff changeset
644 bridges = self.getBridges(irc_room=event.target().lower(), irc_server=connection.server)
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
645 if len(bridges) == 0:
58
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
646 self.error(event_str, debug=True)
48
cb08ea878db9 lower() for "join" and "namreply" IRC events
Charly COSTE <changaco@changaco.net>
parents: 47
diff changeset
647 self.error('===> Debug: no bridge found for "'+event.target().lower()+' at '+connection.server+'"', debug=True)
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
648 return
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
649 for bridge in bridges:
115
0ae0f8836a7a split long messages when sending on IRC
Charly COSTE <changaco@changaco.net>
parents: 113
diff changeset
650 bridge.addParticipant('irc', nickname, irc_id=event.source())
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
651 return
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
652
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
653
152
17305e57f71d removed automatic switching to limited mode (created Bridge.show_participants_list_on())
Charly COSTE <changaco@changaco.net>
parents: 151
diff changeset
654 if event.eventtype() in ['disconnect', 'kill', 'error']:
17305e57f71d removed automatic switching to limited mode (created Bridge.show_participants_list_on())
Charly COSTE <changaco@changaco.net>
parents: 151
diff changeset
655 if len(event.arguments()) > 0 and event.arguments()[0] == 'Connection reset by peer':
17305e57f71d removed automatic switching to limited mode (created Bridge.show_participants_list_on())
Charly COSTE <changaco@changaco.net>
parents: 151
diff changeset
656 self.error(event_str, debug=True)
17305e57f71d removed automatic switching to limited mode (created Bridge.show_participants_list_on())
Charly COSTE <changaco@changaco.net>
parents: 151
diff changeset
657 else:
17305e57f71d removed automatic switching to limited mode (created Bridge.show_participants_list_on())
Charly COSTE <changaco@changaco.net>
parents: 151
diff changeset
658 self.error(event_str, send_to_admins=True)
17305e57f71d removed automatic switching to limited mode (created Bridge.show_participants_list_on())
Charly COSTE <changaco@changaco.net>
parents: 151
diff changeset
659 return
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
660
58
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
661
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
662 # Unhandled events
166
0fc24e232997 some fixes related to IRC nicknames
Charly COSTE <changaco@changaco.net>
parents: 156
diff changeset
663 self.error(event_str+'\n=> Debug: event not handled', debug=True)
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
664
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
665
86
bfa32b017fc9 First hack at an error notification system
Charly COSTE <changaco@changaco.net>
parents: 79
diff changeset
666 def _send_message_to_admins(self, message):
bfa32b017fc9 First hack at an error notification system
Charly COSTE <changaco@changaco.net>
parents: 79
diff changeset
667 """[Internal] Send XMPP Message to bot admin(s)"""
bfa32b017fc9 First hack at an error notification system
Charly COSTE <changaco@changaco.net>
parents: 79
diff changeset
668 for admin_jid in self.admins_jid:
bfa32b017fc9 First hack at an error notification system
Charly COSTE <changaco@changaco.net>
parents: 79
diff changeset
669 try:
bfa32b017fc9 First hack at an error notification system
Charly COSTE <changaco@changaco.net>
parents: 79
diff changeset
670 self.xmpp_c.send(xmpp.protocol.Message(to=admin_jid, body=message, typ='chat'))
bfa32b017fc9 First hack at an error notification system
Charly COSTE <changaco@changaco.net>
parents: 79
diff changeset
671 except:
bfa32b017fc9 First hack at an error notification system
Charly COSTE <changaco@changaco.net>
parents: 79
diff changeset
672 pass
bfa32b017fc9 First hack at an error notification system
Charly COSTE <changaco@changaco.net>
parents: 79
diff changeset
673
bfa32b017fc9 First hack at an error notification system
Charly COSTE <changaco@changaco.net>
parents: 79
diff changeset
674
172
64a0e9636ae6 removed encoding.py, charsets handling is now in irclib and custom charsets can be set per server in the configuration file
Charly COSTE <changaco@changaco.net>
parents: 171
diff changeset
675 def new_bridge(self, xmpp_room, irc_room, irc_server, mode, say_level, irc_port=6667, irc_connection_interval=1, irc_charsets=None):
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
676 """Create a bridge between xmpp_room and irc_room at irc_server."""
172
64a0e9636ae6 removed encoding.py, charsets handling is now in irclib and custom charsets can be set per server in the configuration file
Charly COSTE <changaco@changaco.net>
parents: 171
diff changeset
677 b = Bridge(self, xmpp_room, irc_room, irc_server, mode, say_level, irc_port=irc_port, irc_connection_interval=irc_connection_interval, irc_charsets=irc_charsets)
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
678 self.bridges.append(b)
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
679 return b
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
680
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
681
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
682 def findBridges(self, str_array):
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
683 # TODO: lock self.bridges for thread safety
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
684 bridges = [b for b in self.bridges]
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
685 for bridge in [b for b in bridges]:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
686 for s in str_array:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
687 if not s in str(bridge):
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
688 bridges.remove(bridge)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
689 break
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
690 return bridges
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
691
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
692
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
693 def getBridges(self, irc_room=None, irc_server=None, xmpp_room_jid=None):
96
dd7e1b935894 Code cleaning
Charly COSTE <changaco@changaco.net>
parents: 93
diff changeset
694 # TODO: lock self.bridges for thread safety
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
695 bridges = [b for b in self.bridges]
32
8aa261545662 Implemented "/me" in the IRC->XMPP way (ie "action" event is now handled). Re-written bot.getBridges because the old one didn't always work and was slow.
Charly COSTE <changaco@changaco.net>
parents: 30
diff changeset
696 for bridge in [b for b in bridges]:
8aa261545662 Implemented "/me" in the IRC->XMPP way (ie "action" event is now handled). Re-written bot.getBridges because the old one didn't always work and was slow.
Charly COSTE <changaco@changaco.net>
parents: 30
diff changeset
697 if irc_room != None and bridge.irc_room != irc_room:
8aa261545662 Implemented "/me" in the IRC->XMPP way (ie "action" event is now handled). Re-written bot.getBridges because the old one didn't always work and was slow.
Charly COSTE <changaco@changaco.net>
parents: 30
diff changeset
698 bridges.remove(bridge)
8aa261545662 Implemented "/me" in the IRC->XMPP way (ie "action" event is now handled). Re-written bot.getBridges because the old one didn't always work and was slow.
Charly COSTE <changaco@changaco.net>
parents: 30
diff changeset
699 continue
8aa261545662 Implemented "/me" in the IRC->XMPP way (ie "action" event is now handled). Re-written bot.getBridges because the old one didn't always work and was slow.
Charly COSTE <changaco@changaco.net>
parents: 30
diff changeset
700 if irc_server != None and bridge.irc_server != irc_server:
8aa261545662 Implemented "/me" in the IRC->XMPP way (ie "action" event is now handled). Re-written bot.getBridges because the old one didn't always work and was slow.
Charly COSTE <changaco@changaco.net>
parents: 30
diff changeset
701 bridges.remove(bridge)
8aa261545662 Implemented "/me" in the IRC->XMPP way (ie "action" event is now handled). Re-written bot.getBridges because the old one didn't always work and was slow.
Charly COSTE <changaco@changaco.net>
parents: 30
diff changeset
702 continue
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
703 if xmpp_room_jid != None and bridge.xmpp_room_jid != xmpp_room_jid:
32
8aa261545662 Implemented "/me" in the IRC->XMPP way (ie "action" event is now handled). Re-written bot.getBridges because the old one didn't always work and was slow.
Charly COSTE <changaco@changaco.net>
parents: 30
diff changeset
704 bridges.remove(bridge)
8aa261545662 Implemented "/me" in the IRC->XMPP way (ie "action" event is now handled). Re-written bot.getBridges because the old one didn't always work and was slow.
Charly COSTE <changaco@changaco.net>
parents: 30
diff changeset
705 continue
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
706 return bridges
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
707
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
708
22
e2bd4de698e5 Solved an XMPP resource conflict that would have happened when someone on IRC changed its nickname and later its old nickname would be used again. In other words, the bot no longer uses nicknames as XMPP resources.
Charly COSTE <changaco@changaco.net>
parents: 21
diff changeset
709 def get_xmpp_connection(self, nickname):
e2bd4de698e5 Solved an XMPP resource conflict that would have happened when someone on IRC changed its nickname and later its old nickname would be used again. In other words, the bot no longer uses nicknames as XMPP resources.
Charly COSTE <changaco@changaco.net>
parents: 21
diff changeset
710 if self.xmpp_connections.has_key(nickname):
e2bd4de698e5 Solved an XMPP resource conflict that would have happened when someone on IRC changed its nickname and later its old nickname would be used again. In other words, the bot no longer uses nicknames as XMPP resources.
Charly COSTE <changaco@changaco.net>
parents: 21
diff changeset
711 c = self.xmpp_connections[nickname]
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
712 c.used_by += 1
22
e2bd4de698e5 Solved an XMPP resource conflict that would have happened when someone on IRC changed its nickname and later its old nickname would be used again. In other words, the bot no longer uses nicknames as XMPP resources.
Charly COSTE <changaco@changaco.net>
parents: 21
diff changeset
713 self.error('===> Debug: using existing XMPP connection for "'+nickname+'", now used by '+str(c.used_by)+' bridges', debug=True)
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
714 return c
22
e2bd4de698e5 Solved an XMPP resource conflict that would have happened when someone on IRC changed its nickname and later its old nickname would be used again. In other words, the bot no longer uses nicknames as XMPP resources.
Charly COSTE <changaco@changaco.net>
parents: 21
diff changeset
715 self.error('===> Debug: opening new XMPP connection for "'+nickname+'"', debug=True)
e2bd4de698e5 Solved an XMPP resource conflict that would have happened when someone on IRC changed its nickname and later its old nickname would be used again. In other words, the bot no longer uses nicknames as XMPP resources.
Charly COSTE <changaco@changaco.net>
parents: 21
diff changeset
716 c = xmpp.client.Client(self.bare_jid.getDomain(), debug=[])
35
ebf516b2e5c9 Switched from Lock() to RLock().
Charly COSTE <changaco@changaco.net>
parents: 34
diff changeset
717 c.lock = threading.RLock()
24
4e1f27ea527b First hack at locks for thread safety. Some other minor changes.
Charly COSTE <changaco@changaco.net>
parents: 23
diff changeset
718 c.lock.acquire()
22
e2bd4de698e5 Solved an XMPP resource conflict that would have happened when someone on IRC changed its nickname and later its old nickname would be used again. In other words, the bot no longer uses nicknames as XMPP resources.
Charly COSTE <changaco@changaco.net>
parents: 21
diff changeset
719 self.xmpp_connections[nickname] = c
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
720 c.used_by = 1
22
e2bd4de698e5 Solved an XMPP resource conflict that would have happened when someone on IRC changed its nickname and later its old nickname would be used again. In other words, the bot no longer uses nicknames as XMPP resources.
Charly COSTE <changaco@changaco.net>
parents: 21
diff changeset
721 c.nickname = nickname
90
965dd6f5fcc3 Tried to improve XMPP disconnections handling
Charly COSTE <changaco@changaco.net>
parents: 88
diff changeset
722 c.mucs = []
75
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
723 c.pings = []
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
724 c.connect()
22
e2bd4de698e5 Solved an XMPP resource conflict that would have happened when someone on IRC changed its nickname and later its old nickname would be used again. In other words, the bot no longer uses nicknames as XMPP resources.
Charly COSTE <changaco@changaco.net>
parents: 21
diff changeset
725 c.auth(self.bare_jid.getNode(), self.password)
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
726 c.RegisterHandler('presence', self._xmpp_presence_handler)
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
727 c.RegisterHandler('iq', self._xmpp_iq_handler)
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
728 c.RegisterHandler('message', self._xmpp_message_handler)
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
729 c.sendInitPresence()
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
730 if nickname == self.nickname:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
731 c.send(xmpp.protocol.Presence(priority=127))
24
4e1f27ea527b First hack at locks for thread safety. Some other minor changes.
Charly COSTE <changaco@changaco.net>
parents: 23
diff changeset
732 c.lock.release()
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
733 return c
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
734
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
735
100
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
736 def reopen_xmpp_connection(self, c):
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
737 if not isinstance(c, xmpp.client.Client):
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
738 return
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
739 bot_connection = False
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
740 if c == self.xmpp_c:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
741 bot_connection = True
100
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
742 mucs = c.mucs
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
743 nickname = c.nickname
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
744 used_by = c.used_by
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
745 participants = []
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
746 for b in self.bridges:
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
747 for p in b.participants:
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
748 if p.xmpp_c == c:
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
749 participants.append(p)
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
750 p.xmpp_c = None
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
751 self.error('===> Debug: reopening XMPP connection for "'+nickname+'"', debug=True)
122
9e90e15913a7 bug fixes
Charly COSTE <changaco@changaco.net>
parents: 121
diff changeset
752 if self.xmpp_connections.has_key(nickname):
9e90e15913a7 bug fixes
Charly COSTE <changaco@changaco.net>
parents: 121
diff changeset
753 self.xmpp_connections.pop(nickname)
100
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
754 c.send(xmpp.protocol.Presence(typ='unavailable'))
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
755 del c
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
756 c = self.get_xmpp_connection(nickname)
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
757 c.used_by = used_by
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
758 if bot_connection:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
759 self.xmpp_c = c
100
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
760 for p in participants:
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
761 p.xmpp_c = c
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
762 c.mucs = mucs
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
763 for m in c.mucs:
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
764 m.rejoin()
122
9e90e15913a7 bug fixes
Charly COSTE <changaco@changaco.net>
parents: 121
diff changeset
765 return c
100
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
766
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
767
155
63db565438bd fixed the halt command
Charly COSTE <changaco@changaco.net>
parents: 152
diff changeset
768 def close_xmpp_connection(self, nickname, force=False):
29
a694ffe6a973 Fixed nickname change.
Charly COSTE <changaco@changaco.net>
parents: 27
diff changeset
769 if not self.xmpp_connections.has_key(nickname):
a694ffe6a973 Fixed nickname change.
Charly COSTE <changaco@changaco.net>
parents: 27
diff changeset
770 return
37
7e500d4064fb Cosmetics.
Charly COSTE <changaco@changaco.net>
parents: 35
diff changeset
771 c = self.xmpp_connections[nickname]
42
b8c9ddf320f8 Thread safety for bot.close_xmpp_connection().
Charly COSTE <changaco@changaco.net>
parents: 41
diff changeset
772 c.lock.acquire()
37
7e500d4064fb Cosmetics.
Charly COSTE <changaco@changaco.net>
parents: 35
diff changeset
773 c.used_by -= 1
155
63db565438bd fixed the halt command
Charly COSTE <changaco@changaco.net>
parents: 152
diff changeset
774 if c.used_by < 1 or force:
22
e2bd4de698e5 Solved an XMPP resource conflict that would have happened when someone on IRC changed its nickname and later its old nickname would be used again. In other words, the bot no longer uses nicknames as XMPP resources.
Charly COSTE <changaco@changaco.net>
parents: 21
diff changeset
775 self.error('===> Debug: closing XMPP connection for "'+nickname+'"', debug=True)
37
7e500d4064fb Cosmetics.
Charly COSTE <changaco@changaco.net>
parents: 35
diff changeset
776 self.xmpp_connections.pop(nickname)
52
5aabf124c78d Fixed XMPP connection closing and the XMPP loop
Charly COSTE <changaco@changaco.net>
parents: 51
diff changeset
777 c.send(xmpp.protocol.Presence(typ='unavailable'))
49
714e78fb912e Tried to improve thread-safety during XMPP connection closing.
Charly COSTE <changaco@changaco.net>
parents: 48
diff changeset
778 c.lock.release()
37
7e500d4064fb Cosmetics.
Charly COSTE <changaco@changaco.net>
parents: 35
diff changeset
779 del c
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
780 else:
42
b8c9ddf320f8 Thread safety for bot.close_xmpp_connection().
Charly COSTE <changaco@changaco.net>
parents: 41
diff changeset
781 c.lock.release()
37
7e500d4064fb Cosmetics.
Charly COSTE <changaco@changaco.net>
parents: 35
diff changeset
782 self.error('===> Debug: XMPP connection for "'+nickname+'" is now used by '+str(c.used_by)+' bridges', debug=True)
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
783
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
784
105
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
785 def removeBridge(self, bridge, message='Removing bridge'):
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
786 self.bridges.remove(bridge)
105
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
787 bridge.stop(message)
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
788
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
789
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
790 def respond(self, message, participant=None, bot_admin=False):
134
931a5edc7971 moved commands to a separate file
Charly COSTE <changaco@changaco.net>
parents: 133
diff changeset
791 if isinstance(participant, Participant):
931a5edc7971 moved commands to a separate file
Charly COSTE <changaco@changaco.net>
parents: 133
diff changeset
792 bridge = participant.bridge
931a5edc7971 moved commands to a separate file
Charly COSTE <changaco@changaco.net>
parents: 133
diff changeset
793 if bot_admin != participant.bot_admin:
931a5edc7971 moved commands to a separate file
Charly COSTE <changaco@changaco.net>
parents: 133
diff changeset
794 bot_admin = participant.bot_admin
931a5edc7971 moved commands to a separate file
Charly COSTE <changaco@changaco.net>
parents: 133
diff changeset
795 else:
931a5edc7971 moved commands to a separate file
Charly COSTE <changaco@changaco.net>
parents: 133
diff changeset
796 bridge = None
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
797
134
931a5edc7971 moved commands to a separate file
Charly COSTE <changaco@changaco.net>
parents: 133
diff changeset
798 return commands.execute(self, message, bot_admin, bridge)
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
799
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
800
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
801 def restart(self):
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
802 # Stop the bridges
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
803 for b in self.bridges:
105
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
804 b.stop(message='Restarting bot')
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
805
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
806 # Reopen the bot's XMPP connection
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
807 self.reopen_xmpp_connection(self.xmpp_c)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
808
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
809 # Restart the bridges
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
810 for b in self.bridges:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
811 b.init2()
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
812
105
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
813 self.error('Bot restarted.', send_to_admins=True)
11
79b0a7f48a3e Introduced the command mechanism and fixed a bug
Charly COSTE <changaco@changaco.net>
parents: 10
diff changeset
814
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
815
121
765e460bc20a Restart all bridges connected to a MUC server when it goes down
Charly COSTE <changaco@changaco.net>
parents: 119
diff changeset
816 def restart_bridges_delayed(self, bridges, delay, error_message):
765e460bc20a Restart all bridges connected to a MUC server when it goes down
Charly COSTE <changaco@changaco.net>
parents: 119
diff changeset
817 if len(bridges) > 0:
765e460bc20a Restart all bridges connected to a MUC server when it goes down
Charly COSTE <changaco@changaco.net>
parents: 119
diff changeset
818 error_message += '\nThese bridges will be stopped:'
765e460bc20a Restart all bridges connected to a MUC server when it goes down
Charly COSTE <changaco@changaco.net>
parents: 119
diff changeset
819 for b in bridges:
765e460bc20a Restart all bridges connected to a MUC server when it goes down
Charly COSTE <changaco@changaco.net>
parents: 119
diff changeset
820 error_message += '\n'+str(b)
765e460bc20a Restart all bridges connected to a MUC server when it goes down
Charly COSTE <changaco@changaco.net>
parents: 119
diff changeset
821 if hasattr(b, 'reconnecting'):
765e460bc20a Restart all bridges connected to a MUC server when it goes down
Charly COSTE <changaco@changaco.net>
parents: 119
diff changeset
822 leave_message = 'MUC server seems to be down'
765e460bc20a Restart all bridges connected to a MUC server when it goes down
Charly COSTE <changaco@changaco.net>
parents: 119
diff changeset
823 else:
765e460bc20a Restart all bridges connected to a MUC server when it goes down
Charly COSTE <changaco@changaco.net>
parents: 119
diff changeset
824 leave_message = 'MUC server seems to be down, will try to recreate the bridge in '+str(delay)+' seconds'
765e460bc20a Restart all bridges connected to a MUC server when it goes down
Charly COSTE <changaco@changaco.net>
parents: 119
diff changeset
825 self.reconnecting = True
765e460bc20a Restart all bridges connected to a MUC server when it goes down
Charly COSTE <changaco@changaco.net>
parents: 119
diff changeset
826 self.irc.execute_delayed(delay, b.init2)
765e460bc20a Restart all bridges connected to a MUC server when it goes down
Charly COSTE <changaco@changaco.net>
parents: 119
diff changeset
827 b.stop(message=leave_message)
765e460bc20a Restart all bridges connected to a MUC server when it goes down
Charly COSTE <changaco@changaco.net>
parents: 119
diff changeset
828
765e460bc20a Restart all bridges connected to a MUC server when it goes down
Charly COSTE <changaco@changaco.net>
parents: 119
diff changeset
829 self.error(error_message, send_to_admins=True)
765e460bc20a Restart all bridges connected to a MUC server when it goes down
Charly COSTE <changaco@changaco.net>
parents: 119
diff changeset
830
765e460bc20a Restart all bridges connected to a MUC server when it goes down
Charly COSTE <changaco@changaco.net>
parents: 119
diff changeset
831
129
b13ca9cefe1c tried to fix the halt command (added Bot.stop())
Charly COSTE <changaco@changaco.net>
parents: 127
diff changeset
832 def stop(self, message='Stopping bot'):
17
32a35f7eff70 Rewrote/modified many things, multiple bridges should now work and are preferred over multiple bots.
Charly COSTE <changaco@changaco.net>
parents: 14
diff changeset
833 for bridge in self.bridges:
155
63db565438bd fixed the halt command
Charly COSTE <changaco@changaco.net>
parents: 152
diff changeset
834 bridge.stop(message=message)
129
b13ca9cefe1c tried to fix the halt command (added Bot.stop())
Charly COSTE <changaco@changaco.net>
parents: 127
diff changeset
835
b13ca9cefe1c tried to fix the halt command (added Bot.stop())
Charly COSTE <changaco@changaco.net>
parents: 127
diff changeset
836
b13ca9cefe1c tried to fix the halt command (added Bot.stop())
Charly COSTE <changaco@changaco.net>
parents: 127
diff changeset
837 def __del__(self):
155
63db565438bd fixed the halt command
Charly COSTE <changaco@changaco.net>
parents: 152
diff changeset
838 for bridge in self.bridges:
156
3f299ad4d452 oops, fix for the halt command
Charly COSTE <changaco@changaco.net>
parents: 155
diff changeset
839 self.removeBridge(bridge, message='Stopping bot')
155
63db565438bd fixed the halt command
Charly COSTE <changaco@changaco.net>
parents: 152
diff changeset
840 self.halt = True