summaryrefslogtreecommitdiff
path: root/icq_roombot.py
diff options
context:
space:
mode:
authoryvesf <yvesf@d0e8fea9-7529-0410-93fb-d39fd5b9c1dd>2009-11-16 21:11:18 +0000
committeryvesf <yvesf@d0e8fea9-7529-0410-93fb-d39fd5b9c1dd>2009-11-16 21:11:18 +0000
commitd47b17d4883773fd1f91d7d87420ec751875279a (patch)
treec746a66c366b51ab6e2b1e33af60b0f2ecc6d332 /icq_roombot.py
parent1c6184dc389a4bb04270cd4376c9049eaebe1670 (diff)
downloadomegle-d47b17d4883773fd1f91d7d87420ec751875279a.tar.gz
omegle-d47b17d4883773fd1f91d7d87420ec751875279a.zip
bla
git-svn-id: http://xapek.org/svn/common/omegle@1453 d0e8fea9-7529-0410-93fb-d39fd5b9c1dd
Diffstat (limited to 'icq_roombot.py')
-rw-r--r--icq_roombot.py87
1 files changed, 72 insertions, 15 deletions
diff --git a/icq_roombot.py b/icq_roombot.py
index c2a07fb..1cba8f9 100644
--- a/icq_roombot.py
+++ b/icq_roombot.py
@@ -1,12 +1,14 @@
#!/usr/bin/python
-import struct
+import struct,sys
+from twisted.python import log
from twisted.words.protocols import oscar
from twisted.internet import reactor, protocol
from random import randint
uin = '370496181'
password = 'megahal123'
+host, port = ('login.oscar.aol.com', 5190)
class Member(object):
def __init__(self,id,name):
@@ -47,6 +49,10 @@ class Room(object):
CAP_TYPING = '\x56\x3f\xc8\x09\x0b\x6f\x41\xbd\x9f\x79\x42\x26\x09\xdf\xa2\xf3'
class icqBot( oscar.BOSConnection ):
capabilities = [oscar.CAP_CHAT,CAP_TYPING]
+
+ def __init__(self,*args,**kwargs):
+ print "__INI",args,kwargs
+ oscar.BOSConnection.__init__(self,*args,**kwargs)
def initDone( self ):
self.requestSelfInfo()
@@ -104,28 +110,43 @@ class icqBot( oscar.BOSConnection ):
self.sendMessage(user.name, 'You left')
for otherMember in self.room.members:
self.sendMessage(otherMember.id, "===== %s/%s left"%(member.name,member.id) )
- elif message.strip() == "/invite":
- self.sendMessage(member.id, "===== geht nicht")
- elif message.strip() == "/nick":
- member.name = message.strip().split("/nick")[1]
- elif message.strip() == "/msg":
- self.sendMessage(member.id, "===== geht nicht")
+ elif message.strip().startswith("/invite"):
+ otherUin = message.strip().split("/invite")[1].strip()
+ self.sendMessage(otherUin, "Youre invited by %s to join this room!, Type \" /join nickname\""%(user.name))
+ self.sendMessage(member.id, "Invitation sent to %s"%otherUin)
+ elif message.strip().startswith("/nick"):
+ newNick = message.strip().split("/nick")[1]
+ for otherMember in self.room.members:
+ self.sendMessage(otherMember.id, "===== %s now known as %s" % (member.name,newNick))
+ member.name = newNick
+ elif message.strip().startswith("/msg"):
+ otherNick = message.strip().split("/msg")[1].strip().split(" ")[0]
+ otherMember = filter(lambda m: m.name == otherNick, self.room.members)
+ if len(otherMember) == 0:
+ self.sendMessage(member.id, "===== Nick %s gibts nicht!" % otherNick)
+ else:
+ self.sendMessage(otherMember[0].id, "=== Privat von %s/%s: %s" % (member.name,member.id,message))
elif message.strip() == "/list":
self.sendMessage(member.id, "===== List: %s"%", ".join(map(lambda m: "%s/%s"%(m.id,m.name),self.room.members)) )
elif message.strip().startswith("/"):
self.sendMessage(member.id, "===== kennich nicht")
else:
+ i=0
for otherMember in self.room.members:
+ i += 1
if otherMember.id == user.name:
continue
- self.sendMessage(otherMember.id, message.strip())
+ reactor.callLater(i, self.sendMessage, otherMember.id, "%s: %s" %(member.name, message.strip()))
else:
if message.strip().startswith("/join"):
- nick = "%s/%s"%(message.strip().split("/join")[1],user.name)
+ nick = message.strip().split("/join")[1].strip()
member = Member(user.name, nick)
self.room.join(member)
+ i=0
for otherMember in self.room.members:
- self.sendMessage(otherMember.id, "===== %s/%s joined" % (member.name,member.id))
+ i += 1
+ reactor.callLater(i, self.sendMessage, otherMember.id, "===== %s/%s joined" % (member.name,member.id))
+# self.sendMessage(otherMember.id, "===== %s/%s joined" % (member.name,member.id))
else:
if randint(0,5) == 3:
self.sendMessage(user.name, "Use '/join Nickname' or ' /join Nickname'")
@@ -155,13 +176,49 @@ class icqBot( oscar.BOSConnection ):
print "Connection lost"
oscar.BOSConnection.connectionLost(self,*args,**kwargs)
-
+class ReconnectingOSCARFactory(protocol.ClientFactory):
+ delay = 10.0
+ protocol = icqBot
+ def __init__(self, un, cookie):
+ self.un = un
+ self.cookie = cookie
-class OscarCrap( oscar.OscarAuthenticator ):
- BOSClass = icqBot
+ def buildProtocol(self, addr):
+ p = self.protocol(self.un, self.cookie)
+ p.factory = self
+ return p
+ def clientConnectionLost(self, connector, reason):
+ reactor.callLater(self.delay, self._reconnect)
-protocol.ClientCreator( reactor, OscarCrap, uin, password, icq=1 ).connectTCP( 'login.icq.com', 5238 )
-reactor.run()
+ def _reconnect(self):
+ f = ReconnectingOSCARLoginFactory(uin, password)
+ return reactor.connectTCP(host, port, f)
+
+class OscarCrap( oscar.OscarAuthenticator ):
+ BOSClass = icqBot
+ connectfactory = ReconnectingOSCARFactory
+ def connectToBOS(self, server, port):
+ f = self.connectfactory(self.username, self.cookie)
+ return reactor.connectTCP(server, int(port), f)
+
+class ReconnectingOSCARLoginFactory(protocol.ReconnectingClientFactory):
+ protocol = OscarCrap
+ def __init__(self, sn, pass_):
+ self.sn = sn
+ self.pass_ = pass_
+ def buildProtocol(self, addr):
+ p = self.protocol(self.sn, self.pass_, icq=1)
+ p.factory = self
+ return p
+ ## only reconnect on *failures*
+ def clientConnectionLost(self, con, reason):
+ pass
+
+if __name__ == '__main__':
+ log.startLogging(sys.stdout)
+ f = ReconnectingOSCARLoginFactory(uin, password)
+ reactor.connectTCP(host, port, f)
+ reactor.run()