annotate bot.py @ 132:6a6885dbed25

handle more mode changing cases (added bridge.createDuplicatesOn()) Signed-off-by: Charly COSTE <changaco@changaco.net>
author Charly COSTE <changaco@changaco.net>
date Fri, 15 Jan 2010 17:04:45 +0100
parents 52d94261a406
children e662ff6ecf50
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 shlex
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
20 import sys
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
21 import threading
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
22 from time import sleep
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
23 import traceback
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
24 import xml.parsers.expat
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
25
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
26 from argparse_modified import ArgumentParser
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
27 from encoding import *
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
28 import irclib
75
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
29 import muc
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
30 xmpp = muc.xmpp
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
31 del muc
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
32
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
33 from bridge import Bridge
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
34 from participant import Participant
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
35
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
36
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
37 class Bot(threading.Thread):
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
38
113
6daf0854aa9f added "--show-say-level" and "--show-participants" options to the "bridges" command, renamed {irc,xmpp}_participants commands
Charly COSTE <changaco@changaco.net>
parents: 112
diff changeset
39 commands = ['xmpp-participants', 'irc-participants', 'bridges']
110
ec4fbec1f160 new stop-bridge command
Charly COSTE <changaco@changaco.net>
parents: 108
diff changeset
40 admin_commands = ['add-bridge', 'add-xmpp-admin', 'halt', 'remove-bridge', 'restart-bot', 'restart-bridge', 'stop-bridge']
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
41
86
bfa32b017fc9 First hack at an error notification system
Charly COSTE <changaco@changaco.net>
parents: 79
diff changeset
42 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
43 threading.Thread.__init__(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
44 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
45 self.bare_jid.setResource('')
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
46 self.nickname = nickname
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
47 self.password = password
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
48 self.error_fd = error_fd
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
49 self.debug = debug
86
bfa32b017fc9 First hack at an error notification system
Charly COSTE <changaco@changaco.net>
parents: 79
diff changeset
50 self.admins_jid = admins_jid
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
51 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
52 self.xmpp_connections = {}
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
53 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
54 self.irc.bot = self
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
55 self.irc.add_global_handler('all_events', self._irc_event_handler)
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
56 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
57 self.irc_thread.start()
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
58 # Open connection with XMPP server
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
59 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
60 self.xmpp_c = self.get_xmpp_connection(self.nickname)
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
61 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
62 self.error('[Error] XMPP Connection failed')
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
63 raise
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
64 self.xmpp_thread = threading.Thread(target=self._xmpp_loop)
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
65 self.xmpp_thread.start()
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
66
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
67
86
bfa32b017fc9 First hack at an error notification system
Charly COSTE <changaco@changaco.net>
parents: 79
diff changeset
68 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
69 """Output an error message."""
86
bfa32b017fc9 First hack at an error notification system
Charly COSTE <changaco@changaco.net>
parents: 79
diff changeset
70 if send_to_admins == True:
bfa32b017fc9 First hack at an error notification system
Charly COSTE <changaco@changaco.net>
parents: 79
diff changeset
71 self._send_message_to_admins(s)
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
72 if not debug or debug and self.debug:
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
73 try:
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
74 self.error_fd.write(auto_encode(s)+"\n")
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
75 except EncodingException:
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
76 self.error_fd.write('Error message cannot be transcoded.\n')
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
77
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
78
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
79 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
80 """[Internal] XMPP infinite loop."""
75
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
81 i = 1
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
82 while True:
79
73a30fc1922b Fixed the XMPP loop (release the lock)
Charly COSTE <changaco@changaco.net>
parents: 78
diff changeset
83 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
84 try:
51
2737ed5b9003 Tried to improve the XMPP loop, again.
Charly COSTE <changaco@changaco.net>
parents: 50
diff changeset
85 if len(self.xmpp_connections) == 1:
2737ed5b9003 Tried to improve the XMPP loop, again.
Charly COSTE <changaco@changaco.net>
parents: 50
diff changeset
86 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
87 for j, c in enumerate(self.xmpp_connections.itervalues()):
75
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
88 i += 1
51
2737ed5b9003 Tried to improve the XMPP loop, again.
Charly COSTE <changaco@changaco.net>
parents: 50
diff changeset
89 if hasattr(c, 'lock'):
49
714e78fb912e Tried to improve thread-safety during XMPP connection closing.
Charly COSTE <changaco@changaco.net>
parents: 48
diff changeset
90 c.lock.acquire()
75
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
91 if i == j:
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
92 ping = xmpp.protocol.Iq(typ='get')
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
93 ping.addChild(name='ping', namespace='urn:xmpp:ping')
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
94 self.error('=> Debug: sending XMPP ping', debug=True)
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
95 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
96 if hasattr(c, 'Process'):
5aabf124c78d Fixed XMPP connection closing and the XMPP loop
Charly COSTE <changaco@changaco.net>
parents: 51
diff changeset
97 c.Process(0.01)
5aabf124c78d Fixed XMPP connection closing and the XMPP loop
Charly COSTE <changaco@changaco.net>
parents: 51
diff changeset
98 c.lock.release()
75
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
99 if i > 5000:
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
100 i = 0
51
2737ed5b9003 Tried to improve the XMPP loop, again.
Charly COSTE <changaco@changaco.net>
parents: 50
diff changeset
101 except RuntimeError:
2737ed5b9003 Tried to improve the XMPP loop, again.
Charly COSTE <changaco@changaco.net>
parents: 50
diff changeset
102 pass
24
4e1f27ea527b First hack at locks for thread safety. Some other minor changes.
Charly COSTE <changaco@changaco.net>
parents: 23
diff changeset
103 except (xml.parsers.expat.ExpatError, xmpp.protocol.XMLNotWellFormed):
72
6c4b841144f6 Better handling of participants
Charly COSTE <changaco@changaco.net>
parents: 70
diff changeset
104 self.error('=> Debug: invalid stanza', debug=True)
101
29d3b85c6286 Minor fixes/improvements
Charly COSTE <changaco@changaco.net>
parents: 100
diff changeset
105 self.reopen_xmpp_connection(c)
79
73a30fc1922b Fixed the XMPP loop (release the lock)
Charly COSTE <changaco@changaco.net>
parents: 78
diff changeset
106 unlock = True
91
69e4fc0f015c Tried to fix XMPP «Replaced by new connection» problem
Charly COSTE <changaco@changaco.net>
parents: 90
diff changeset
107 except xmpp.Conflict:
101
29d3b85c6286 Minor fixes/improvements
Charly COSTE <changaco@changaco.net>
parents: 100
diff changeset
108 self.error('=> Debug: conflict', debug=True)
100
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
109 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
110 unlock = True
51
2737ed5b9003 Tried to improve the XMPP loop, again.
Charly COSTE <changaco@changaco.net>
parents: 50
diff changeset
111 except:
101
29d3b85c6286 Minor fixes/improvements
Charly COSTE <changaco@changaco.net>
parents: 100
diff changeset
112 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
113 error += traceback.format_exc()
bfa32b017fc9 First hack at an error notification system
Charly COSTE <changaco@changaco.net>
parents: 79
diff changeset
114 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
115 unlock = True
73a30fc1922b Fixed the XMPP loop (release the lock)
Charly COSTE <changaco@changaco.net>
parents: 78
diff changeset
116 if unlock == True:
73a30fc1922b Fixed the XMPP loop (release the lock)
Charly COSTE <changaco@changaco.net>
parents: 78
diff changeset
117 c.lock.release()
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
118
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
119
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
120 def _xmpp_presence_handler(self, dispatcher, presence):
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
121 """[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
122
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
123 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
124
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
125 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
126 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
127 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
128
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
129 self.error('==> Debug: Received XMPP presence.', debug=True)
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
130 self.error(presence.__str__(fancy=1), debug=True)
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
131
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
132 from_ = xmpp.protocol.JID(presence.getFrom())
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
133 bare_jid = unicode(from_.getNode()+'@'+from_.getDomain())
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
134 for bridge in self.bridges:
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
135 if bare_jid == bridge.xmpp_room_jid:
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
136 # presence comes from a muc
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
137 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
138
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
139 if resource == '':
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
140 # presence comes from the muc itself
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
141 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
142
108
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
143 elif resource == xmpp_c.nickname:
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
144 # presence comes from self
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
145 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
146 if x:
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
147 d = x.getTag('destroy')
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
148 if d:
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
149 # room was destroyed
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
150 # 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
151 # 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
152 reason = d.getTag('reason')
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
153 if reason:
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
154 r = reason.getData()
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
155 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
156 # 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
157 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
158 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
159 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
160 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
161 return
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
162 elif r == '':
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 else:
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
165 r = 'None given'
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
166
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
167 # 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
168 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
169 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
170
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
171 else:
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
172 # 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
173
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
174 x = presence.getTag('x', namespace='http://jabber.org/protocol/muc#user')
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
175 item = None
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
176 if x:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
177 item = x.getTag('item')
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
178
93
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
179 if presence.getType() == 'unavailable':
96
dd7e1b935894 Code cleaning
Charly COSTE <changaco@changaco.net>
parents: 93
diff changeset
180 try:
dd7e1b935894 Code cleaning
Charly COSTE <changaco@changaco.net>
parents: 93
diff changeset
181 p = bridge.getParticipant(resource)
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
182 except Bridge.NoSuchParticipantException:
96
dd7e1b935894 Code cleaning
Charly COSTE <changaco@changaco.net>
parents: 93
diff changeset
183 p = None
dd7e1b935894 Code cleaning
Charly COSTE <changaco@changaco.net>
parents: 93
diff changeset
184
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
185 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
186 # participant changed its nickname
93
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
187 if p == None:
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
188 return
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
189 if p.protocol != 'xmpp':
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
190 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
191 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
192 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
193 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
194 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
195 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
196 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
197 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
198 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
199 p.changeNickname(new_nick, 'irc')
93
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
200
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
201 elif x and x.getTag('status', attrs={'code': '307'}):
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
202 # participant was kicked
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
203 if p == None:
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
204 bridge.xmpp_room.rejoin()
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
205 return
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
206 if isinstance(p.xmpp_c, xmpp.client.Client):
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
207 p.muc.rejoin()
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
208 else:
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
209 if item:
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
210 reason = item.getTag('reason')
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
211 actor = item.getTag('actor')
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
212 if actor and actor.has_attr('jid'):
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
213 kicker = actor.getAttr('jid')
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
214 s1 = 'Kicked by '+kicker
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
215 else:
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
216 s1 = 'Kicked from XMPP'
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
217 if reason:
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
218 s2 = ' with reason: '+reason.getData()
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 s2 = ' (no reason was given)'
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
221 else:
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
222 s1 = 'Kicked from XMPP'
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
223 s2 = ' (no reason was given)'
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 bridge.removeParticipant('xmpp', p.nickname, s1+s2)
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
226
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
227 elif x and x.getTag('status', attrs={'code': '301'}):
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
228 # participant was banned
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
229 if p == None:
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
230 m = '[Error] bot got banned from XMPP'
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
231 self.error(m)
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
232 bridge.say(m, on_xmpp=False)
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
233 self.removeBridge(bridge)
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
234 return
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
235 if item:
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
236 reason = item.getTag('reason')
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
237 actor = item.getTag('actor')
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
238 if actor and actor.has_attr('jid'):
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
239 kicker = actor.getAttr('jid')
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
240 s1 = 'Banned by '+kicker
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
241 else:
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
242 s1 = 'Banned from XMPP'
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
243 if reason:
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
244 s2 = ' with reason: '+reason.getData()
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 s2 = ' (no reason was given)'
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
247 else:
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
248 s1 = 'Banned from XMPP'
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
249 s2 = ' (no reason was given)'
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
250
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
251 bridge.removeParticipant('xmpp', p.nickname, s1+s2)
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
252
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
253 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
254 # participant left
99
5390e9abfa44 Don't try to remove a participant that does not exist
Charly COSTE <changaco@changaco.net>
parents: 96
diff changeset
255 if p != None:
5390e9abfa44 Don't try to remove a participant that does not exist
Charly COSTE <changaco@changaco.net>
parents: 96
diff changeset
256 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
257
111
59401ac0f47a handle XMPP remote-server-not-found
Charly COSTE <changaco@changaco.net>
parents: 110
diff changeset
258 elif presence.getType() == 'error':
59401ac0f47a handle XMPP remote-server-not-found
Charly COSTE <changaco@changaco.net>
parents: 110
diff changeset
259 error = presence.getTag('error')
59401ac0f47a handle XMPP remote-server-not-found
Charly COSTE <changaco@changaco.net>
parents: 110
diff changeset
260 if error:
59401ac0f47a handle XMPP remote-server-not-found
Charly COSTE <changaco@changaco.net>
parents: 110
diff changeset
261 for c in error.getChildren():
59401ac0f47a handle XMPP remote-server-not-found
Charly COSTE <changaco@changaco.net>
parents: 110
diff changeset
262 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
263 err = error.getAttr('type')+' '+c.getName()
59401ac0f47a handle XMPP remote-server-not-found
Charly COSTE <changaco@changaco.net>
parents: 110
diff changeset
264 if err == 'cancel remote-server-not-found':
59401ac0f47a handle XMPP remote-server-not-found
Charly COSTE <changaco@changaco.net>
parents: 110
diff changeset
265 # Remote server not found
59401ac0f47a handle XMPP remote-server-not-found
Charly COSTE <changaco@changaco.net>
parents: 110
diff changeset
266 # Stop bridges that depend on this server
59401ac0f47a handle XMPP remote-server-not-found
Charly COSTE <changaco@changaco.net>
parents: 110
diff changeset
267 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
268 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
269 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
270 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
271 else:
59401ac0f47a handle XMPP remote-server-not-found
Charly COSTE <changaco@changaco.net>
parents: 110
diff changeset
272 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
273
96
dd7e1b935894 Code cleaning
Charly COSTE <changaco@changaco.net>
parents: 93
diff changeset
274 elif resource != bridge.bot.nickname:
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
275 real_jid = None
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
276 if item and item.has_attr('jid'):
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
277 real_jid = item.getAttr('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 p = bridge.addParticipant('xmpp', resource, real_jid)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
280
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
281 # 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
282 if real_jid and isinstance(p, Participant):
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
283 for jid in self.admins_jid:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
284 if xmpp.protocol.JID(jid).bareMatch(real_jid):
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
285 p.bot_admin = True
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
286 break
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
287
96
dd7e1b935894 Code cleaning
Charly COSTE <changaco@changaco.net>
parents: 93
diff changeset
288 return
dd7e1b935894 Code cleaning
Charly COSTE <changaco@changaco.net>
parents: 93
diff changeset
289
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
290 return
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
291
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
292
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
293 def _xmpp_iq_handler(self, dispatcher, iq):
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
294 """[Internal] Manage XMPP IQs."""
75
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 xmpp_c = dispatcher._owner
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
297
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
298 # Ignore pongs
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
299 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
300 xmpp_c.pings.remove(iq.getID())
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
301 self.error('=> Debug: received XMPP pong', debug=True)
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
302 return
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
303
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
304 self.error('==> Debug: Received XMPP iq.', debug=True)
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
305 self.error(iq.__str__(fancy=1), debug=True)
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
306
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
307
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 def _xmpp_message_handler(self, dispatcher, message):
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
309 """[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
310
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
311 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
312
34
57d0e66378b0 Fixed XMPP message handling and removed disconnect handler.
Charly COSTE <changaco@changaco.net>
parents: 33
diff changeset
313 if message.getBody() == None:
57d0e66378b0 Fixed XMPP message handling and removed disconnect handler.
Charly COSTE <changaco@changaco.net>
parents: 33
diff changeset
314 return
57d0e66378b0 Fixed XMPP message handling and removed disconnect handler.
Charly COSTE <changaco@changaco.net>
parents: 33
diff changeset
315
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
316 if message.getType() == 'chat':
11
79b0a7f48a3e Introduced the command mechanism and fixed a bug
Charly COSTE <changaco@changaco.net>
parents: 10
diff changeset
317 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
318 for bridge in self.bridges:
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
319 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
320 # 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
321
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
322 self.error('==> Debug: Received XMPP chat message.', debug=True)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
323 self.error(message.__str__(fancy=1), debug=True)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
324
11
79b0a7f48a3e Introduced the command mechanism and fixed a bug
Charly COSTE <changaco@changaco.net>
parents: 10
diff changeset
325 try:
79b0a7f48a3e Introduced the command mechanism and fixed a bug
Charly COSTE <changaco@changaco.net>
parents: 10
diff changeset
326 from_ = bridge.getParticipant(message.getFrom().getResource())
27
9b7a628ca612 Fixed XMPP message handling, again.
Charly COSTE <changaco@changaco.net>
parents: 25
diff changeset
327 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
328
34
57d0e66378b0 Fixed XMPP message handling and removed disconnect handler.
Charly COSTE <changaco@changaco.net>
parents: 33
diff changeset
329 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
330
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
331 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
332 if xmpp_c.nickname == self.nickname:
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
333 r = self.respond(str(message.getBody()), participant=from_)
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
334 if isinstance(r, basestring) and len(r) > 0:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
335 s = xmpp.protocol.Message(to=message.getFrom(), body=r, typ='chat')
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
336 self.error('==> Debug: Sending', debug=True)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
337 self.error(s.__str__(fancy=1), debug=True)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
338 xmpp_c.send(s)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
339 else:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
340 self.error('=> Debug: won\'t answer.', debug=True)
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
341 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
342 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
343 return
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
344
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
345 # message does not come from a room
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
346 if xmpp_c.nickname == self.nickname:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
347 self.error('==> Debug: Received XMPP chat message.', debug=True)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
348 self.error(message.__str__(fancy=1), debug=True)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
349
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
350 # Find out if the message comes from a bot admin
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
351 bot_admin = False
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
352 for jid in self.admins_jid:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
353 if xmpp.protocol.JID(jid).bareMatch(message.getFrom()):
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
354 bot_admin = True
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
355 break
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
356
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
357 # Respond
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
358 r = self.respond(str(message.getBody()), bot_admin=bot_admin)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
359 if isinstance(r, basestring) and len(r) > 0:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
360 s = xmpp.protocol.Message(to=message.getFrom(), body=r, typ='chat')
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
361 self.error('==> Debug: Sending', debug=True)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
362 self.error(s.__str__(fancy=1), debug=True)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
363 xmpp_c.send(s)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
364
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
365 else:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
366 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
367
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
368 elif message.getType() == 'groupchat':
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
369 # 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
370
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
371 for child in message.getChildren():
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
372 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
373 # MUC delayed message
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
374 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
375
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
376 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
377 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
378 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
379
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
380
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
381 from_ = xmpp.protocol.JID(message.getFrom())
23
abdb7a2b6c6d Minor fixes.
Charly COSTE <changaco@changaco.net>
parents: 22
diff changeset
382
abdb7a2b6c6d Minor fixes.
Charly COSTE <changaco@changaco.net>
parents: 22
diff changeset
383 if unicode(from_.getResource()) == self.nickname:
abdb7a2b6c6d Minor fixes.
Charly COSTE <changaco@changaco.net>
parents: 22
diff changeset
384 self.error('=> Debug: Ignoring XMPP MUC message sent by self.', debug=True)
abdb7a2b6c6d Minor fixes.
Charly COSTE <changaco@changaco.net>
parents: 22
diff changeset
385 return
abdb7a2b6c6d Minor fixes.
Charly COSTE <changaco@changaco.net>
parents: 22
diff changeset
386
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
387 room_jid = unicode(from_.getNode()+'@'+from_.getDomain())
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
388 for bridge in self.bridges:
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
389 if room_jid == bridge.xmpp_room_jid:
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
390 resource = unicode(from_.getResource())
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
391 if resource == '':
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
392 # 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
393 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
394 return
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
395 else:
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
396 # 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
397 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
398 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
399
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
400 try:
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
401 participant = bridge.getParticipant(resource)
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
402 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
403 if resource != self.nickname:
37
7e500d4064fb Cosmetics.
Charly COSTE <changaco@changaco.net>
parents: 35
diff changeset
404 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
405 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
406
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
407 participant.sayOnIRC(message.getBody())
37
7e500d4064fb Cosmetics.
Charly COSTE <changaco@changaco.net>
parents: 35
diff changeset
408 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
409
105
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
410 elif message.getType() == 'error':
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
411 for b in self.bridges:
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
412 if message.getFrom() == b.xmpp_room_jid:
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
413 # message comes from a room
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
414 for c in message.getChildren():
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
415 if c.getName() == 'error':
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
416 for cc in c.getChildren():
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
417 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
418 err = cc.getName()
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
419 if err == 'not-acceptable':
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
420 # 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
421 # probable cause is a MUC server restart
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
422 # let's restart the bot
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
423 self.restart()
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
424 elif err == 'forbidden':
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
425 # we don't have the permission to speak
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
426 # 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
427 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
428 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
429 else:
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
430 self.error('==> Debug: recevied unknown error message', debug=True)
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
431 self.error(message.__str__(fancy=1), debug=True)
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
432 return
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
433
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
434 self.error('==> Debug: recevied unknown error message', debug=True)
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
435 self.error(message.__str__(fancy=1), debug=True)
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
436
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
437 else:
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
438 self.error('==> Debug: Received XMPP message of unknown type "'+message.getType()+'".', debug=True)
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
439 self.error(message.__str__(fancy=1), debug=True)
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
440
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
441
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
442 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
443 """[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
444
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
445 # Answer ping
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
446 if event.eventtype() == 'ping':
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
447 connection.pong(connection.get_server_name())
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
448 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
449
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
450
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 # Events we always want to ignore
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
452 if 'all' in event.eventtype() or 'motd' in event.eventtype():
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
453 return
23
abdb7a2b6c6d Minor fixes.
Charly COSTE <changaco@changaco.net>
parents: 22
diff changeset
454 if event.eventtype() in ['pong', 'privnotice', 'ctcp', 'nochanmodes', 'notexttosend', 'currenttopic', 'topicinfo']:
75
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
455 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
456 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
457
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
458
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
459 nickname = None
24
4e1f27ea527b First hack at locks for thread safety. Some other minor changes.
Charly COSTE <changaco@changaco.net>
parents: 23
diff changeset
460 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
461 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
462 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
463
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
464
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
465 # 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
466 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
467 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
468 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
469 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
470 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
471 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
472 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
473 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
474 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
475 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
476
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
477
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 # A string representation of the event
56
b048c4c03b00 Fixed encoding issues
Charly COSTE <changaco@changaco.net>
parents: 55
diff changeset
479 event_str = '==> Debug: Received IRC event.\nconnection='+connection.__str__()+'\neventtype='+event.eventtype()+'\nsource='+auto_decode(event.source().__str__())+'\ntarget='+auto_decode(event.target().__str__())+'\narguments='+auto_decode(event.arguments().__str__())
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
480
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
53
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
482 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
483 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
484 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
485
39
3b06450d60cd Improved debug output.
Charly COSTE <changaco@changaco.net>
parents: 37
diff changeset
486 handled = False
3b06450d60cd Improved debug output.
Charly COSTE <changaco@changaco.net>
parents: 37
diff changeset
487
53
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
488 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
489 if connection.get_nickname() != self.nickname:
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
490 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
491 return
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
492 else:
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
493 self.error(event_str, debug=True)
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
494
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
495 if event.eventtype() == 'kick' and len(event.arguments()) < 1:
58
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
496 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
497 return
39
3b06450d60cd Improved debug output.
Charly COSTE <changaco@changaco.net>
parents: 37
diff changeset
498
54
2507f424773a Fixed a bug introduced in previous commit
Charly COSTE <changaco@changaco.net>
parents: 53
diff changeset
499 if event.eventtype() in ['pubmsg', 'action']:
55
c09f9523fe2e I'm stupid ...
Charly COSTE <changaco@changaco.net>
parents: 54
diff changeset
500 if connection.get_nickname() != self.nickname:
54
2507f424773a Fixed a bug introduced in previous commit
Charly COSTE <changaco@changaco.net>
parents: 53
diff changeset
501 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
502 return
2507f424773a Fixed a bug introduced in previous commit
Charly COSTE <changaco@changaco.net>
parents: 53
diff changeset
503 if nickname == self.nickname:
2507f424773a Fixed a bug introduced in previous commit
Charly COSTE <changaco@changaco.net>
parents: 53
diff changeset
504 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
505 return
50
dbb7c29a71e2 Ignore messages sent by self
Charly COSTE <changaco@changaco.net>
parents: 49
diff changeset
506
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
507 # 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
508 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
509 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
510 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
511
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
512 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
513 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
514
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
515 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
516 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
517
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
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 # 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
520 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
521 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
522 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
523
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 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
525 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
526 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
527 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
528 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
529
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
530 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
531 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
532 # 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
533 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
534 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
535 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
536 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
537 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
538
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
539
92
aae8870b3727 Better handling of IRC kick
Charly COSTE <changaco@changaco.net>
parents: 91
diff changeset
540 # kick handling
53
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
541 if event.eventtype() == 'kick':
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
542 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
543 try:
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
544 kicked = bridge.getParticipant(event.arguments()[0])
72
6c4b841144f6 Better handling of participants
Charly COSTE <changaco@changaco.net>
parents: 70
diff changeset
545 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
546 kicked.irc_connection.join(bridge.irc_room)
93
c95fe0b319d9 XMPP kick and ban handling
Charly COSTE <changaco@changaco.net>
parents: 92
diff changeset
547 else:
92
aae8870b3727 Better handling of IRC kick
Charly COSTE <changaco@changaco.net>
parents: 91
diff changeset
548 if len(event.arguments()) > 1:
aae8870b3727 Better handling of IRC kick
Charly COSTE <changaco@changaco.net>
parents: 91
diff changeset
549 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
550 else:
aae8870b3727 Better handling of IRC kick
Charly COSTE <changaco@changaco.net>
parents: 91
diff changeset
551 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
552 return
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
553 except Bridge.NoSuchParticipantException:
53
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
554 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
555 return
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
556 else:
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
557 continue
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
558
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
559
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
560 # Leaving events
45
41394ddb3aff Lower before comparing strings.
Charly COSTE <changaco@changaco.net>
parents: 44
diff changeset
561 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
562 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
563 continue
30
c0fb916cb0a0 Fixed IRC leaving events handling.
Charly COSTE <changaco@changaco.net>
parents: 29
diff changeset
564 if len(event.arguments()) > 0:
c0fb916cb0a0 Fixed IRC leaving events handling.
Charly COSTE <changaco@changaco.net>
parents: 29
diff changeset
565 leave_message = event.arguments()[0]
c0fb916cb0a0 Fixed IRC leaving events handling.
Charly COSTE <changaco@changaco.net>
parents: 29
diff changeset
566 elif event.eventtype() == 'quit':
c0fb916cb0a0 Fixed IRC leaving events handling.
Charly COSTE <changaco@changaco.net>
parents: 29
diff changeset
567 leave_message = 'Left server.'
c0fb916cb0a0 Fixed IRC leaving events handling.
Charly COSTE <changaco@changaco.net>
parents: 29
diff changeset
568 elif event.eventtype() == 'part':
c0fb916cb0a0 Fixed IRC leaving events handling.
Charly COSTE <changaco@changaco.net>
parents: 29
diff changeset
569 leave_message = 'Left channel.'
c0fb916cb0a0 Fixed IRC leaving events handling.
Charly COSTE <changaco@changaco.net>
parents: 29
diff changeset
570 else:
c0fb916cb0a0 Fixed IRC leaving events handling.
Charly COSTE <changaco@changaco.net>
parents: 29
diff changeset
571 leave_message = ''
c0fb916cb0a0 Fixed IRC leaving events handling.
Charly COSTE <changaco@changaco.net>
parents: 29
diff changeset
572 bridge.removeParticipant('irc', from_.nickname, leave_message)
39
3b06450d60cd Improved debug output.
Charly COSTE <changaco@changaco.net>
parents: 37
diff changeset
573 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
574 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
575
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
576
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 # Nickname change
41
4c4f4ee72e17 Fixed IRC "nick" event handling. Fixed bot's XMPP infinite loop.
Charly COSTE <changaco@changaco.net>
parents: 39
diff changeset
578 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
579 from_.changeNickname(event.target(), 'xmpp')
39
3b06450d60cd Improved debug output.
Charly COSTE <changaco@changaco.net>
parents: 37
diff changeset
580 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
581 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
582
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
583
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
584 # 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
585 if event.eventtype() in ['pubmsg', 'action']:
45
41394ddb3aff Lower before comparing strings.
Charly COSTE <changaco@changaco.net>
parents: 44
diff changeset
586 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
587 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
588 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
589 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
590 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
591 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
592 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
593 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
594 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
595
39
3b06450d60cd Improved debug output.
Charly COSTE <changaco@changaco.net>
parents: 37
diff changeset
596 if handled == False:
53
a2258a705a17 Handle kick (by simply rejoining) on IRC side
Charly COSTE <changaco@changaco.net>
parents: 52
diff changeset
597 if not event.eventtype() in ['quit', 'part', 'nick', 'kick']:
39
3b06450d60cd Improved debug output.
Charly COSTE <changaco@changaco.net>
parents: 37
diff changeset
598 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
599 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
600 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
601
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
602
58
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
603 # Handle bannedfromchan
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
604 if event.eventtype() == 'bannedfromchan':
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
605 if len(event.arguments()) < 1:
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
606 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
607 return
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
608
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
609 for bridge in self.bridges:
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
610 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
611 continue
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
612
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
613 if event.target() == self.nickname:
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
614 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
615 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
616 else:
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
617 try:
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
618 banned = bridge.getParticipant(event.target())
72
6c4b841144f6 Better handling of participants
Charly COSTE <changaco@changaco.net>
parents: 70
diff changeset
619 if banned.irc_connection != 'bannedfromchan':
6c4b841144f6 Better handling of participants
Charly COSTE <changaco@changaco.net>
parents: 70
diff changeset
620 banned.irc_connection = 'bannedfromchan'
58
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
621 self.error(event_str, debug=True)
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
622 self.error('[Notice] 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
623 bridge.say('[Warning] the nickname "'+event.target()+'" is banned from the IRC chan')
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
624 else:
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
625 self.error('=> Debug: ignoring '+event.eventtype(), debug=True)
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
626 except Bridge.NoSuchParticipantException:
58
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
627 self.error('=> Debug: no such participant. WTF ?')
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
628 return
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 return
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
631
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
632
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
633 # 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
634 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
635 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
636 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
637 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
638
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 event.eventtype() == 'namreply':
48
cb08ea878db9 lower() for "join" and "namreply" IRC events
Charly COSTE <changaco@changaco.net>
parents: 47
diff changeset
640 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
641 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
642 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
643 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
644 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
645 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
646 elif event.eventtype() == 'join':
48
cb08ea878db9 lower() for "join" and "namreply" IRC events
Charly COSTE <changaco@changaco.net>
parents: 47
diff changeset
647 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
648 if len(bridges) == 0:
58
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
649 self.error(event_str, debug=True)
48
cb08ea878db9 lower() for "join" and "namreply" IRC events
Charly COSTE <changaco@changaco.net>
parents: 47
diff changeset
650 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
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 for bridge in bridges:
115
0ae0f8836a7a split long messages when sending on IRC
Charly COSTE <changaco@changaco.net>
parents: 113
diff changeset
653 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
654 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
655
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
656
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
657 # From here the event is shown
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
658 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
659
58
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
660
88
8b071629558e Handle IRC "kill" event
Charly COSTE <changaco@changaco.net>
parents: 86
diff changeset
661 if event.eventtype() in ['disconnect', 'kill']:
70
01f1c6cb7447 Prevent unjustified switching to limited mode
Charly COSTE <changaco@changaco.net>
parents: 64
diff changeset
662 if len(event.arguments()) > 0 and event.arguments()[0] == 'Connection reset by peer':
01f1c6cb7447 Prevent unjustified switching to limited mode
Charly COSTE <changaco@changaco.net>
parents: 64
diff changeset
663 return
01f1c6cb7447 Prevent unjustified switching to limited mode
Charly COSTE <changaco@changaco.net>
parents: 64
diff changeset
664
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
665 # 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
666 for bridge in self.bridges:
63
71508f22edb4 Fixed unjustified switching to limited mode
Charly COSTE <changaco@changaco.net>
parents: 58
diff changeset
667 if connection.server != bridge.irc_server:
71508f22edb4 Fixed unjustified switching to limited mode
Charly COSTE <changaco@changaco.net>
parents: 58
diff changeset
668 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
669 try:
88
8b071629558e Handle IRC "kill" event
Charly COSTE <changaco@changaco.net>
parents: 86
diff changeset
670 p = bridge.getParticipant(connection.get_nickname())
118
b29fd5696a78 new mode bypass and new method bridge.changeMode
Charly COSTE <changaco@changaco.net>
parents: 115
diff changeset
671 if bridge.mode in ['normal', 'bypass']:
b29fd5696a78 new mode bypass and new method bridge.changeMode
Charly COSTE <changaco@changaco.net>
parents: 115
diff changeset
672 bridge.changeMode('limited')
88
8b071629558e Handle IRC "kill" event
Charly COSTE <changaco@changaco.net>
parents: 86
diff changeset
673 else:
8b071629558e Handle IRC "kill" event
Charly COSTE <changaco@changaco.net>
parents: 86
diff changeset
674 if p.irc_connection.really_connected == True:
8b071629558e Handle IRC "kill" event
Charly COSTE <changaco@changaco.net>
parents: 86
diff changeset
675 p.irc_connection.part(bridge.irc_room, message=message)
8b071629558e Handle IRC "kill" event
Charly COSTE <changaco@changaco.net>
parents: 86
diff changeset
676 p.irc_connection.used_by -= 1
8b071629558e Handle IRC "kill" event
Charly COSTE <changaco@changaco.net>
parents: 86
diff changeset
677 if p.irc_connection.used_by < 1:
8b071629558e Handle IRC "kill" event
Charly COSTE <changaco@changaco.net>
parents: 86
diff changeset
678 p.irc_connection.close(message)
8b071629558e Handle IRC "kill" event
Charly COSTE <changaco@changaco.net>
parents: 86
diff changeset
679 p.irc_connection = None
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
680 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
681 pass
5
cb0daec4b778 Added support for IRC "nick" event, fixed participant.changeNickname(), fixed handling of IRC "namreply" event, removed muc._check() because waiting does not solve the problem if it is blocking incoming messages handling
Charly COSTE <changaco@changaco.net>
parents: 3
diff changeset
682 return
58
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
683
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
684
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
685 # Nickname callbacks
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
686 # TODO: move this into irclib.py
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
687 if event.eventtype() == 'nicknameinuse':
118
b29fd5696a78 new mode bypass and new method bridge.changeMode
Charly COSTE <changaco@changaco.net>
parents: 115
diff changeset
688 connection._call_nick_callbacks('nicknameinuse', arguments=[event])
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
689 return
64
8fc496eaa17b Handle IRC "nickcollision" event
Charly COSTE <changaco@changaco.net>
parents: 63
diff changeset
690 if event.eventtype() == 'nickcollision':
118
b29fd5696a78 new mode bypass and new method bridge.changeMode
Charly COSTE <changaco@changaco.net>
parents: 115
diff changeset
691 connection._call_nick_callbacks('nickcollision', arguments=[event])
64
8fc496eaa17b Handle IRC "nickcollision" event
Charly COSTE <changaco@changaco.net>
parents: 63
diff changeset
692 return
58
92341dbfb8b7 Handle bannedfromchan IRC event
Charly COSTE <changaco@changaco.net>
parents: 56
diff changeset
693 if event.eventtype() == 'erroneusnickname':
118
b29fd5696a78 new mode bypass and new method bridge.changeMode
Charly COSTE <changaco@changaco.net>
parents: 115
diff changeset
694 connection._call_nick_callbacks('erroneusnickname', arguments=[event])
5
cb0daec4b778 Added support for IRC "nick" event, fixed participant.changeNickname(), fixed handling of IRC "namreply" event, removed muc._check() because waiting does not solve the problem if it is blocking incoming messages handling
Charly COSTE <changaco@changaco.net>
parents: 3
diff changeset
695 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
696
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
697
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
698 # Unhandled 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
699 self.error('=> Debug: event not handled', debug=True)
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
700
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
701
86
bfa32b017fc9 First hack at an error notification system
Charly COSTE <changaco@changaco.net>
parents: 79
diff changeset
702 def _send_message_to_admins(self, message):
bfa32b017fc9 First hack at an error notification system
Charly COSTE <changaco@changaco.net>
parents: 79
diff changeset
703 """[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
704 for admin_jid in self.admins_jid:
bfa32b017fc9 First hack at an error notification system
Charly COSTE <changaco@changaco.net>
parents: 79
diff changeset
705 try:
bfa32b017fc9 First hack at an error notification system
Charly COSTE <changaco@changaco.net>
parents: 79
diff changeset
706 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
707 except:
bfa32b017fc9 First hack at an error notification system
Charly COSTE <changaco@changaco.net>
parents: 79
diff changeset
708 pass
bfa32b017fc9 First hack at an error notification system
Charly COSTE <changaco@changaco.net>
parents: 79
diff changeset
709
bfa32b017fc9 First hack at an error notification system
Charly COSTE <changaco@changaco.net>
parents: 79
diff changeset
710
21
801160b4136f Introduced a bridge's "say" attribute to offer more flexibility in what the bot says.
Charly COSTE <changaco@changaco.net>
parents: 20
diff changeset
711 def new_bridge(self, xmpp_room, irc_room, irc_server, mode, say_level, irc_port=6667):
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
712 """Create a bridge between xmpp_room and irc_room at irc_server."""
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
713 b = Bridge(self, xmpp_room, irc_room, irc_server, mode, say_level, irc_port=irc_port)
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
714 self.bridges.append(b)
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
715 return b
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
716
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
717
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
718 def findBridges(self, str_array):
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
719 # TODO: lock self.bridges for thread safety
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
720 bridges = [b for b in self.bridges]
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
721 for bridge in [b for b in bridges]:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
722 for s in str_array:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
723 if not s in str(bridge):
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
724 bridges.remove(bridge)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
725 break
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
726 return bridges
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
727
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
728
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
729 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
730 # 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
731 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
732 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
733 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
734 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
735 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
736 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
737 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
738 continue
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
739 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
740 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
741 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
742 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
743
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
744
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
745 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
746 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
747 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
748 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
749 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
750 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
751 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
752 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
753 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
754 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
755 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
756 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
757 c.nickname = nickname
90
965dd6f5fcc3 Tried to improve XMPP disconnections handling
Charly COSTE <changaco@changaco.net>
parents: 88
diff changeset
758 c.mucs = []
75
6034087b1d10 First hack at pings
Charly COSTE <changaco@changaco.net>
parents: 72
diff changeset
759 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
760 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
761 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
762 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
763 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
764 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
765 c.sendInitPresence()
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
766 if nickname == self.nickname:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
767 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
768 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
769 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
770
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
771
100
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
772 def reopen_xmpp_connection(self, c):
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
773 if not isinstance(c, xmpp.client.Client):
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
774 return
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
775 bot_connection = False
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
776 if c == self.xmpp_c:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
777 bot_connection = True
100
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
778 mucs = c.mucs
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
779 nickname = c.nickname
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
780 used_by = c.used_by
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
781 participants = []
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
782 for b in self.bridges:
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
783 for p in b.participants:
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
784 if p.xmpp_c == c:
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
785 participants.append(p)
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
786 p.xmpp_c = None
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
787 self.error('===> Debug: reopening XMPP connection for "'+nickname+'"', debug=True)
122
9e90e15913a7 bug fixes
Charly COSTE <changaco@changaco.net>
parents: 121
diff changeset
788 if self.xmpp_connections.has_key(nickname):
9e90e15913a7 bug fixes
Charly COSTE <changaco@changaco.net>
parents: 121
diff changeset
789 self.xmpp_connections.pop(nickname)
100
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
790 c.send(xmpp.protocol.Presence(typ='unavailable'))
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
791 del c
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
792 c = self.get_xmpp_connection(nickname)
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
793 c.used_by = used_by
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
794 if bot_connection:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
795 self.xmpp_c = c
100
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
796 for p in participants:
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
797 p.xmpp_c = c
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
798 c.mucs = mucs
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
799 for m in c.mucs:
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
800 m.rejoin()
122
9e90e15913a7 bug fixes
Charly COSTE <changaco@changaco.net>
parents: 121
diff changeset
801 return c
100
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
802
6289ac5a2db7 Reconnect when a connection is closed
Charly COSTE <changaco@changaco.net>
parents: 99
diff changeset
803
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
804 def close_xmpp_connection(self, nickname):
29
a694ffe6a973 Fixed nickname change.
Charly COSTE <changaco@changaco.net>
parents: 27
diff changeset
805 if not self.xmpp_connections.has_key(nickname):
a694ffe6a973 Fixed nickname change.
Charly COSTE <changaco@changaco.net>
parents: 27
diff changeset
806 return
37
7e500d4064fb Cosmetics.
Charly COSTE <changaco@changaco.net>
parents: 35
diff changeset
807 c = self.xmpp_connections[nickname]
42
b8c9ddf320f8 Thread safety for bot.close_xmpp_connection().
Charly COSTE <changaco@changaco.net>
parents: 41
diff changeset
808 c.lock.acquire()
37
7e500d4064fb Cosmetics.
Charly COSTE <changaco@changaco.net>
parents: 35
diff changeset
809 c.used_by -= 1
7e500d4064fb Cosmetics.
Charly COSTE <changaco@changaco.net>
parents: 35
diff changeset
810 if 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
811 self.error('===> Debug: closing XMPP connection for "'+nickname+'"', debug=True)
37
7e500d4064fb Cosmetics.
Charly COSTE <changaco@changaco.net>
parents: 35
diff changeset
812 self.xmpp_connections.pop(nickname)
52
5aabf124c78d Fixed XMPP connection closing and the XMPP loop
Charly COSTE <changaco@changaco.net>
parents: 51
diff changeset
813 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
814 c.lock.release()
37
7e500d4064fb Cosmetics.
Charly COSTE <changaco@changaco.net>
parents: 35
diff changeset
815 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
816 else:
42
b8c9ddf320f8 Thread safety for bot.close_xmpp_connection().
Charly COSTE <changaco@changaco.net>
parents: 41
diff changeset
817 c.lock.release()
37
7e500d4064fb Cosmetics.
Charly COSTE <changaco@changaco.net>
parents: 35
diff changeset
818 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
819
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
820
105
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
821 def removeBridge(self, bridge, message='Removing bridge'):
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
822 self.bridges.remove(bridge)
105
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
823 bridge.stop(message)
0
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
824
4c842d23d4ce Initial commit, version 0.1
Charly COSTE <changaco@changaco.net>
parents:
diff changeset
825
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
826 def respond(self, message, participant=None, bot_admin=False):
18
3cdf7bb580da Fixed bot.respond(), boosted XMPP thread to lower latency, fixed mode notice.
Charly COSTE <changaco@changaco.net>
parents: 17
diff changeset
827 ret = ''
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
828 command = shlex.split(message)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
829 args_array = []
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
830 if len(command) > 1:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
831 args_array = command[1:]
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
832 command = command[0]
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
833
126
eb65b875be0a isinstance(participant, participant) → isinstance(participant, Participant)
Charly COSTE <changaco@changaco.net>
parents: 124
diff changeset
834 if isinstance(participant, Participant) and bot_admin != participant.bot_admin:
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
835 bot_admin = participant.bot_admin
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
836
113
6daf0854aa9f added "--show-say-level" and "--show-participants" options to the "bridges" command, renamed {irc,xmpp}_participants commands
Charly COSTE <changaco@changaco.net>
parents: 112
diff changeset
837 if command == 'xmpp-participants':
126
eb65b875be0a isinstance(participant, participant) → isinstance(participant, Participant)
Charly COSTE <changaco@changaco.net>
parents: 124
diff changeset
838 if not isinstance(participant, Participant):
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
839 for b in self.bridges:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
840 xmpp_participants_nicknames = b.get_participants_nicknames_list(protocols=['xmpp'])
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
841 ret += '\nparticipants on '+b.xmpp_room_jid+' ('+str(len(xmpp_participants_nicknames))+'): '+' '.join(xmpp_participants_nicknames)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
842 return ret
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
843 else:
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
844 xmpp_participants_nicknames = participant.bridge.get_participants_nicknames_list(protocols=['xmpp'])
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
845 return '\nparticipants on '+participant.bridge.xmpp_room_jid+' ('+str(len(xmpp_participants_nicknames))+'): '+' '.join(xmpp_participants_nicknames)
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
846
113
6daf0854aa9f added "--show-say-level" and "--show-participants" options to the "bridges" command, renamed {irc,xmpp}_participants commands
Charly COSTE <changaco@changaco.net>
parents: 112
diff changeset
847 elif command == 'irc-participants':
126
eb65b875be0a isinstance(participant, participant) → isinstance(participant, Participant)
Charly COSTE <changaco@changaco.net>
parents: 124
diff changeset
848 if not isinstance(participant, Participant):
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
849 for b in self.bridges:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
850 irc_participants_nicknames = b.get_participants_nicknames_list(protocols=['irc'])
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
851 ret += '\nparticipants on '+b.irc_room+' at '+b.irc_server+' ('+str(len(irc_participants_nicknames))+'): '+' '.join(irc_participants_nicknames)
18
3cdf7bb580da Fixed bot.respond(), boosted XMPP thread to lower latency, fixed mode notice.
Charly COSTE <changaco@changaco.net>
parents: 17
diff changeset
852 return ret
3cdf7bb580da Fixed bot.respond(), boosted XMPP thread to lower latency, fixed mode notice.
Charly COSTE <changaco@changaco.net>
parents: 17
diff changeset
853 else:
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
854 irc_participants_nicknames = participant.bridge.get_participants_nicknames_list(protocols=['irc'])
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
855 return '\nparticipants on '+participant.bridge.irc_room+' at '+participant.bridge.irc_server+' ('+str(len(irc_participants_nicknames))+'): '+' '.join(irc_participants_nicknames)
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
856
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
857 elif command == 'bridges':
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
858 parser = ArgumentParser(prog=command)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
859 parser.add_argument('--show-mode', default=False, action='store_true')
113
6daf0854aa9f added "--show-say-level" and "--show-participants" options to the "bridges" command, renamed {irc,xmpp}_participants commands
Charly COSTE <changaco@changaco.net>
parents: 112
diff changeset
860 parser.add_argument('--show-say-level', default=False, action='store_true')
6daf0854aa9f added "--show-say-level" and "--show-participants" options to the "bridges" command, renamed {irc,xmpp}_participants commands
Charly COSTE <changaco@changaco.net>
parents: 112
diff changeset
861 parser.add_argument('--show-participants', default=False, action='store_true')
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
862 try:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
863 args = parser.parse_args(args_array)
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
864 except ArgumentParser.ParseException as e:
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
865 return '\n'+e.args[1]
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
866 ret = 'List of bridges:'
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
867 for i, b in enumerate(self.bridges):
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
868 ret += '\n'+str(i+1)+' - '+str(b)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
869 if args.show_mode:
113
6daf0854aa9f added "--show-say-level" and "--show-participants" options to the "bridges" command, renamed {irc,xmpp}_participants commands
Charly COSTE <changaco@changaco.net>
parents: 112
diff changeset
870 ret += ' - mode='+b.mode
6daf0854aa9f added "--show-say-level" and "--show-participants" options to the "bridges" command, renamed {irc,xmpp}_participants commands
Charly COSTE <changaco@changaco.net>
parents: 112
diff changeset
871 if args.show_say_level:
130
52d94261a406 minor fixes
Charly COSTE <changaco@changaco.net>
parents: 129
diff changeset
872 ret += ' - say_level='+Bridge._say_levels[b.say_level]
113
6daf0854aa9f added "--show-say-level" and "--show-participants" options to the "bridges" command, renamed {irc,xmpp}_participants commands
Charly COSTE <changaco@changaco.net>
parents: 112
diff changeset
873 if args.show_participants:
6daf0854aa9f added "--show-say-level" and "--show-participants" options to the "bridges" command, renamed {irc,xmpp}_participants commands
Charly COSTE <changaco@changaco.net>
parents: 112
diff changeset
874 xmpp_participants_nicknames = b.get_participants_nicknames_list(protocols=['xmpp'])
6daf0854aa9f added "--show-say-level" and "--show-participants" options to the "bridges" command, renamed {irc,xmpp}_participants commands
Charly COSTE <changaco@changaco.net>
parents: 112
diff changeset
875 ret += '\nparticipants on XMPP ('+str(len(xmpp_participants_nicknames))+'): '+' '.join(xmpp_participants_nicknames)
6daf0854aa9f added "--show-say-level" and "--show-participants" options to the "bridges" command, renamed {irc,xmpp}_participants commands
Charly COSTE <changaco@changaco.net>
parents: 112
diff changeset
876 irc_participants_nicknames = b.get_participants_nicknames_list(protocols=['irc'])
6daf0854aa9f added "--show-say-level" and "--show-participants" options to the "bridges" command, renamed {irc,xmpp}_participants commands
Charly COSTE <changaco@changaco.net>
parents: 112
diff changeset
877 ret += '\nparticipants on IRC ('+str(len(irc_participants_nicknames))+'): '+' '.join(irc_participants_nicknames)
108
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
878 if b.irc_connection == None:
dff9746aa508 XMPP room deletion (and server shut down) handling
Charly COSTE <changaco@changaco.net>
parents: 105
diff changeset
879 ret += ' - this bridge is stopped, use "restart-bridge '+str(i+1)+'" to restart it'
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
880 return ret
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
881
127
db3f648a9e9e bot → Bot
Charly COSTE <changaco@changaco.net>
parents: 126
diff changeset
882 elif command in Bot.admin_commands:
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
883 if bot_admin == False:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
884 return 'You have to be a bot admin to use this command.'
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
885
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
886 if command == 'add-bridge':
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
887 parser = ArgumentParser(prog=command)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
888 parser.add_argument('xmpp_room_jid', type=str)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
889 parser.add_argument('irc_chan', type=str)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
890 parser.add_argument('irc_server', type=str)
130
52d94261a406 minor fixes
Charly COSTE <changaco@changaco.net>
parents: 129
diff changeset
891 parser.add_argument('--mode', choices=Bridge._modes, default='normal')
52d94261a406 minor fixes
Charly COSTE <changaco@changaco.net>
parents: 129
diff changeset
892 parser.add_argument('--say-level', choices=Bridge._say_levels, default='all')
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
893 parser.add_argument('--irc-port', type=int, default=6667)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
894 try:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
895 args = parser.parse_args(args_array)
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
896 except ArgumentParser.ParseException as e:
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
897 return '\n'+e.args[1]
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
898
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
899 self.new_bridge(args.xmpp_room_jid, args.irc_chan, args.irc_server, args.mode, args.say_level, irc_port=args.irc_port)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
900
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
901 return 'Bridge added.'
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
902
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
903 elif command == 'add-xmpp-admin':
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
904 parser = ArgumentParser(prog=command)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
905 parser.add_argument('jid', type=str)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
906 try:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
907 args = parser.parse_args(args_array)
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
908 except ArgumentParser.ParseException as e:
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
909 return '\n'+e.args[1]
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
910 self.admins_jid.append(args.jid)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
911 for b in self.bridges:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
912 for p in b.participants:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
913 if p.real_jid != None and xmpp.protocol.JID(args.jid).bareMatch(p.real_jid):
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
914 p.bot_admin = True
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
915
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
916 return 'XMPP admin added.'
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
917
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
918 elif command == 'restart-bot':
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
919 self.restart()
105
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
920 return
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
921 elif command == 'halt':
129
b13ca9cefe1c tried to fix the halt command (added Bot.stop())
Charly COSTE <changaco@changaco.net>
parents: 127
diff changeset
922 self.stop()
105
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
923 return
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
924
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
925
110
ec4fbec1f160 new stop-bridge command
Charly COSTE <changaco@changaco.net>
parents: 108
diff changeset
926 elif command in ['remove-bridge', 'restart-bridge', 'stop-bridge']:
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
927 # we need to know which bridge the command is for
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
928 if len(args_array) == 0:
126
eb65b875be0a isinstance(participant, participant) → isinstance(participant, Participant)
Charly COSTE <changaco@changaco.net>
parents: 124
diff changeset
929 if isinstance(participant, Participant):
124
99f3dee1fad7 code cleaning
Charly COSTE <changaco@changaco.net>
parents: 122
diff changeset
930 b = participant.bridge
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
931 else:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
932 return 'You must specify a bridge. '+self.respond('bridges')
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
933 else:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
934 try:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
935 bn = int(args_array[0])
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
936 if bn < 1:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
937 raise IndexError
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
938 b = self.bridges[bn-1]
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
939 except IndexError:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
940 return 'Invalid bridge number "'+str(bn)+'". '+self.respond('bridges')
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
941 except ValueError:
130
52d94261a406 minor fixes
Charly COSTE <changaco@changaco.net>
parents: 129
diff changeset
942 bridges = self.findBridges(args_array[0])
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
943 if len(bridges) == 0:
130
52d94261a406 minor fixes
Charly COSTE <changaco@changaco.net>
parents: 129
diff changeset
944 return 'No bridge found matching "'+args_array[0]+'". '+self.respond('bridges')
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
945 elif len(bridges) == 1:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
946 b = bridges[0]
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
947 elif len(bridges) > 1:
130
52d94261a406 minor fixes
Charly COSTE <changaco@changaco.net>
parents: 129
diff changeset
948 return 'More than one bridge matches "'+args_array[0]+'", please be more specific. '+self.respond('bridges')
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
949
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
950 if command == 'remove-bridge':
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
951 self.removeBridge(b)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
952 return 'Bridge removed.'
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
953 elif command == 'restart-bridge':
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
954 b.restart()
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
955 return 'Bridge restarted.'
110
ec4fbec1f160 new stop-bridge command
Charly COSTE <changaco@changaco.net>
parents: 108
diff changeset
956 elif command == 'stop-bridge':
ec4fbec1f160 new stop-bridge command
Charly COSTE <changaco@changaco.net>
parents: 108
diff changeset
957 b.stop()
ec4fbec1f160 new stop-bridge command
Charly COSTE <changaco@changaco.net>
parents: 108
diff changeset
958 return 'Bridge stopped.'
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
959
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
960 else:
127
db3f648a9e9e bot → Bot
Charly COSTE <changaco@changaco.net>
parents: 126
diff changeset
961 ret = 'Error: "'+command+'" is not a valid command.\ncommands: '+' '.join(Bot.commands)
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
962 if bot_admin == True:
127
db3f648a9e9e bot → Bot
Charly COSTE <changaco@changaco.net>
parents: 126
diff changeset
963 return ret+'\n'+'admin commands: '+' '.join(Bot.admin_commands)
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
964 else:
18
3cdf7bb580da Fixed bot.respond(), boosted XMPP thread to lower latency, fixed mode notice.
Charly COSTE <changaco@changaco.net>
parents: 17
diff changeset
965 return ret
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
966
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
967
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
968 def restart(self):
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
969 # Stop the bridges
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
970 for b in self.bridges:
105
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
971 b.stop(message='Restarting bot')
103
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
972
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
973 # Reopen the bot's XMPP connection
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
974 self.reopen_xmpp_connection(self.xmpp_c)
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
975
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
976 # Restart the bridges
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
977 for b in self.bridges:
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
978 b.init2()
23416c27b592 New command system
Charly COSTE <changaco@changaco.net>
parents: 101
diff changeset
979
105
d8acff763731 Handle MUC error messages
Charly COSTE <changaco@changaco.net>
parents: 103
diff changeset
980 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
981
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
982
121
765e460bc20a Restart all bridges connected to a MUC server when it goes down
Charly COSTE <changaco@changaco.net>
parents: 119
diff changeset
983 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
984 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
985 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
986 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
987 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
988 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
989 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
990 else:
765e460bc20a Restart all bridges connected to a MUC server when it goes down
Charly COSTE <changaco@changaco.net>
parents: 119
diff changeset
991 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
992 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
993 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
994 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
995
765e460bc20a Restart all bridges connected to a MUC server when it goes down
Charly COSTE <changaco@changaco.net>
parents: 119
diff changeset
996 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
997
765e460bc20a Restart all bridges connected to a MUC server when it goes down
Charly COSTE <changaco@changaco.net>
parents: 119
diff changeset
998
129
b13ca9cefe1c tried to fix the halt command (added Bot.stop())
Charly COSTE <changaco@changaco.net>
parents: 127
diff changeset
999 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
1000 for bridge in self.bridges:
129
b13ca9cefe1c tried to fix the halt command (added Bot.stop())
Charly COSTE <changaco@changaco.net>
parents: 127
diff changeset
1001 self.removeBridge(bridge, message=message)
b13ca9cefe1c tried to fix the halt command (added Bot.stop())
Charly COSTE <changaco@changaco.net>
parents: 127
diff changeset
1002
b13ca9cefe1c tried to fix the halt command (added Bot.stop())
Charly COSTE <changaco@changaco.net>
parents: 127
diff changeset
1003
b13ca9cefe1c tried to fix the halt command (added Bot.stop())
Charly COSTE <changaco@changaco.net>
parents: 127
diff changeset
1004 def __del__(self):
b13ca9cefe1c tried to fix the halt command (added Bot.stop())
Charly COSTE <changaco@changaco.net>
parents: 127
diff changeset
1005 self.stop()