on_pubmsg.py 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839
  1. import datetime
  2. from events.common import Replyto, Lastact
  3. def process_event(self, connection, event):
  4. # Update last act.
  5. Lastact.update(self, event.source.nick, "msg", channel=event.target, lastact=event.arguments[0])
  6. # Save statistic to database.
  7. if not self.db.one("SELECT id FROM \"users\" WHERE name='" + event.source.nick + "' AND network='" + self.network + "'"): # Not on record.
  8. self.db.run("INSERT INTO \"users\" (name, network) VALUES ('" + event.source.nick + "', '" + self.network + "')") # Create record.
  9. self.db.run("UPDATE \"users\" SET messages=messages+1, messages_words=messages_words+" + str(len(event.arguments[0].split())) + ", messages_characters=messages_characters+" + str(len(event.arguments[0])) + " WHERE name='" + event.source.nick + "' AND network='" + self.network + "'") # Increment record.
  10. if connection.get_nickname().lower() in event.arguments[0].lower() and event.source.nick is not connection.get_nickname(): # Bot's name was mentioned
  11. if event.arguments[0].startswith(self.cmdchar):
  12. return # Stop if it's a command.
  13. if not self.db.one("SELECT chat FROM channels WHERE name='" + event.target + "' AND network='" + self.network + "'"):
  14. return # Stop if channelfunction chat if off.
  15. Replyto.name(connection, event)
  16. # Character lame.
  17. elif event.arguments[0] == len(event.arguments[0]) * event.arguments[0][0]: # Trigger exclusively same character.
  18. # Stop if chat channel function is off.
  19. if not self.db.one("SELECT chat FROM channels WHERE name='" + event.target + "' AND network='" + self.network + "'"):
  20. return
  21. # Stop if lamed recently.
  22. lastlame = self.db.one("SELECT last_lame FROM channels WHERE name='" + event.target + "' AND network='" + self.network + "'")
  23. if lastlame and lastlame > datetime.datetime.now() - datetime.timedelta(minutes=2): # In the last 2 minutes.
  24. return
  25. # Update lastlame.
  26. self.db.run("UPDATE channels SET last_lame='" + str(datetime.datetime.now()) + "' WHERE name='" + event.target + "' AND network='" + self.network + "'")
  27. connection.privmsg(event.target, event.arguments[0] + event.arguments[0][:1])