on_kick.py 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. from common.networkservices import ChanServ
  2. from common import userstatus, do_everything_to
  3. bold = "\x02"
  4. italic = "\x1D"
  5. underline = "\x1F"
  6. reverse = "\x16" # swap background and foreground colors ("reverse video")
  7. reset = "\x0F"
  8. blue = "\x0302"
  9. green = "\x0303"
  10. red = "\x0304"
  11. grey = "\x0314"
  12. def process_event(self, connection, event):
  13. kicker = event.source.nick
  14. channel = event.target
  15. kicked = event.arguments[0]
  16. reason = event.arguments[1]
  17. # Create user records if they don't exist.
  18. if not self.db.one("SELECT id FROM users WHERE name='" + kicker + "' AND network='" + self.network + "'"): # Kicker does not have a user record.
  19. self.db.run("INSERT INTO \"users\" (name, network) VALUES ('" + kicker + "', '" + self.network + "')") # Create user record.
  20. if not self.db.one("SELECT id FROM users WHERE name='" + kicked + "' AND network='" + self.network + "'"): # Kicked does not have a user record.
  21. self.db.run("INSERT INTO \"users\" (name, network) VALUES ('" + kicked + "', '" + self.network + "')") # Create user record.
  22. # Create kick records if they don't exist.
  23. if not self.db.one("SELECT id FROM kicks WHERE channel='" + channel + "'AND channel_network='" + self.network + "' AND \"user\"='" + kicker + "' AND user_network='" + self.network + "'"): # No records for kicker channel combination.
  24. self.db.run("INSERT INTO kicks (channel, channel_network, \"user\", user_network) VALUES ('" + channel + "', '" + self.network + "', '" + kicker + "', '" + self.network + "')")
  25. if not self.db.one("SELECT id FROM kicks WHERE channel='" + channel + "'AND channel_network='" + self.network + "' AND \"user\"='" + kicked + "' AND user_network='" + self.network + "'"): # No records for kicked channel combination.
  26. self.db.run("INSERT INTO kicks (channel, channel_network, \"user\", user_network) VALUES ('" + channel + "', '" + self.network + "', '" + kicked + "', '" + self.network + "')")
  27. # Save statistic.
  28. self.db.run("UPDATE kicks SET given = given + 1 WHERE channel='" + channel + "'AND channel_network='" + self.network + "' AND \"user\"='" + kicker + "' AND user_network='" + self.network + "'")
  29. self.db.run("UPDATE kicks SET received = received + 1 WHERE channel='" + channel + "'AND channel_network='" + self.network + "' AND \"user\"='" + kicked + "' AND user_network='" + self.network + "'")
  30. # Update protectees if needed.
  31. if channel == self.homechannel: # Kicked from home channel
  32. if event.source.nick in self.protectees: # Protectee kicked.
  33. del self.protectees[event.source.nick] # Remove old nick from list.
  34. # Do nothing more when user is not protected.
  35. if not userstatus.atleast_halfop(self, kicked, self.homechannel) and not kicked == connection.get_nickname():
  36. return
  37. # Report.
  38. if not channel == self.homechannel: # Not kicked from homechannel.
  39. if reason:
  40. connection.privmsg(self.homechannel, red + kicked + reset + " has been kicked from " + red + channel + reset + " by " + red + kicker + reset + ": " + green + reason)
  41. else:
  42. connection.privmsg(self.homechannel, red + kicked + reset + " has been kicked from " + red + channel + reset + " by " + red + kicker + reset + ".")
  43. # React.
  44. behaviour = self.db.one("SELECT aggressiveness FROM channels WHERE name='" + channel + "' AND network='" + self.network + "'")
  45. if behaviour == "passive": # Passive behaviour.
  46. if kicked == connection.get_nickname() and channel == self.homechannel: # Bot was kicked from it's home channel.
  47. ChanServ.unban(connection, channel, kicked)
  48. ChanServ.akick_del(connection, channel, kicked)
  49. connection.privmsg("ChanServ", "UNBAN " + channel)
  50. do_everything_to.join(self, connection, self.homechannel)
  51. elif behaviour == "defense_only": # Defensive behaviour.
  52. ChanServ.unban(connection, channel, kicked)
  53. ChanServ.akick_del(connection, channel, kicked)
  54. if kicked == connection.get_nickname(): # Bot was kicked.
  55. connection.privmsg("ChanServ", "UNBAN " + channel)
  56. do_everything_to.join(self, connection, channel)
  57. elif behaviour == "equal_retalliation": # Equal retalitory behaviour.
  58. ChanServ.unban(connection, channel, kicked)
  59. ChanServ.akick_del(connection, channel, kicked)
  60. # Rejoin if bot was kicked.
  61. if kicked == connection.get_nickname():
  62. connection.privmsg("ChanServ", "UNBAN " + channel)
  63. do_everything_to.join(self, connection, self.homechannel)
  64. # Stop if offender is bot.
  65. if event.source.nick == connection.get_nickname():
  66. print("stop")
  67. return
  68. # Only continue if offended is owner and offender is not also owner.
  69. if userstatus.atleast_halfop(self, kicker, self.homechannel): # Offender is bot operator.
  70. if self.channels[self.homechannel].is_owner(kicked) and not self.channels[self.homechannel].is_owner(kicker): # Offended is owner and offender is not also owner.
  71. pass
  72. else:
  73. print("STOP")
  74. return
  75. # Kick.
  76. ChanServ.kick(connection, channel, kicker, "Aggression channel function = equal_retalliation: " + kicked + " is an operator of " + connection.get_nickname() + ".")
  77. connection.kick(channel, kicker, "Aggression channel function = equal_retalliation: " + kicked + " is an operator of " + connection.get_nickname() + ".")
  78. # Battlebot behaviour.
  79. elif behaviour == "battlebot":
  80. ChanServ.unban(connection, channel, kicked)
  81. ChanServ.akick_del(connection, channel, kicked)
  82. # Rejoin if bot was kicked.
  83. if kicked == connection.get_nickname():
  84. connection.privmsg("ChanServ", "UNBAN " + channel)
  85. do_everything_to.join(self, connection, self.homechannel)
  86. # Stop if offender is bot.
  87. if event.source.nick == connection.get_nickname():
  88. print("stop")
  89. return
  90. # Only continue if offended is owner and offender is not also owner.
  91. if userstatus.atleast_halfop(self, kicker, self.homechannel): # Offender is bot operator.
  92. if self.channels[self.homechannel].is_owner(kicked) and not self.channels[self.homechannel].is_owner(kicker): # Offended is owner and offender is not also owner.
  93. pass
  94. else:
  95. print("STOP")
  96. return
  97. # Ban.
  98. ChanServ.tempban(connection, channel, kicker, "1h", "Aggression channel function = equal_retalliation: " + kicked + " is an operator of " + connection.get_nickname() + ".")
  99. connection.mode(channel, "+b " + event.source)
  100. connection.mode(channel, "+e " + event.source) # Excempt operator.
  101. ChanServ.akick_add(connection, channel, kicker) # Add kicker to ChanServs autokick.
  102. # Kick.
  103. ChanServ.kick(connection, channel, kicker, "Aggression channel function = equal_retalliation: " + kicked + " is an operator of " + connection.get_nickname() + ".")
  104. connection.kick(channel, kicker, "Aggression channel function = equal_retalliation: " + kicked + " is an operator of " + connection.get_nickname() + ".")