mirror of
https://github.com/iio612/DEFENDER.git
synced 2026-02-14 19:54:21 +00:00
Compare commits
45 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
cea69c1580 | ||
|
|
f5ff9259e8 | ||
|
|
c404cc3234 | ||
|
|
12c7e5e832 | ||
|
|
3cdee5fddf | ||
|
|
80b329dd5d | ||
|
|
f2b5c48fc9 | ||
|
|
f7b49c151f | ||
|
|
e2a1ec5866 | ||
|
|
1ee9b7e3ff | ||
|
|
cc53eae875 | ||
|
|
4d0087623c | ||
|
|
dc20f5ec3c | ||
|
|
110cae3b84 | ||
|
|
857cbfc85d | ||
|
|
3518589e9c | ||
|
|
e14c97de03 | ||
|
|
69360be3ad | ||
|
|
bfa90c6bd5 | ||
|
|
5c8378a0e7 | ||
|
|
e3b212ea88 | ||
|
|
0c2a350d38 | ||
|
|
1cea8d0601 | ||
|
|
652b400d5e | ||
|
|
2f8b965b59 | ||
|
|
3c043cefd8 | ||
|
|
59a75cecd8 | ||
|
|
71053437a7 | ||
|
|
7796d05206 | ||
|
|
5f2567f9e5 | ||
|
|
aaa1dd9a1a | ||
|
|
a02f2f9a26 | ||
|
|
d73adb6f0b | ||
|
|
b812e64992 | ||
|
|
9bd1f68df2 | ||
|
|
f44b08bf36 | ||
|
|
1a19e1613a | ||
|
|
cdc15b7b47 | ||
|
|
31fe9f62ec | ||
|
|
f0853e3afb | ||
|
|
6dade09257 | ||
|
|
9533b010b2 | ||
|
|
824db73590 | ||
|
|
96bf4b6f80 | ||
|
|
922336363e |
@@ -591,7 +591,7 @@ class Base:
|
|||||||
)
|
)
|
||||||
'''
|
'''
|
||||||
|
|
||||||
table_core_channel = '''CREATE TABLE IF NOT EXISTS core_channel (
|
table_core_channel = f'''CREATE TABLE IF NOT EXISTS {self.Config.table_channel} (
|
||||||
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
||||||
datetime TEXT,
|
datetime TEXT,
|
||||||
module_name TEXT,
|
module_name TEXT,
|
||||||
|
|||||||
13
core/irc.py
13
core/irc.py
@@ -829,6 +829,13 @@ class Irc:
|
|||||||
self.sendPrivMsg(msg=f'[{self.Config.COLORS.green}INFORMATION{self.Config.COLORS.nogc}] >> Defender is ready', channel=self.Config.SERVICE_CHANLOG)
|
self.sendPrivMsg(msg=f'[{self.Config.COLORS.green}INFORMATION{self.Config.COLORS.nogc}] >> Defender is ready', channel=self.Config.SERVICE_CHANLOG)
|
||||||
self.INIT = 0
|
self.INIT = 0
|
||||||
|
|
||||||
|
# Send EOF to other modules
|
||||||
|
for classe_name, classe_object in self.loaded_classes.items():
|
||||||
|
classe_object.cmd(original_response)
|
||||||
|
|
||||||
|
# Stop here When EOS
|
||||||
|
return None
|
||||||
|
|
||||||
case _:
|
case _:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
@@ -1003,7 +1010,8 @@ class Irc:
|
|||||||
arg.remove(f':{self.Config.SERVICE_PREFIX}')
|
arg.remove(f':{self.Config.SERVICE_PREFIX}')
|
||||||
if not arg[0].lower() in self.commands:
|
if not arg[0].lower() in self.commands:
|
||||||
self.Base.logs.debug(f"This command {arg[0]} is not available")
|
self.Base.logs.debug(f"This command {arg[0]} is not available")
|
||||||
return False
|
self.sendNotice(f"This command [{self.Config.COLORS.bold}{arg[0]}{self.Config.COLORS.bold}] is not available", user_trigger)
|
||||||
|
return None
|
||||||
|
|
||||||
cmd_to_send = convert_to_string.replace(':','')
|
cmd_to_send = convert_to_string.replace(':','')
|
||||||
self.Base.log_cmd(user_trigger, cmd_to_send)
|
self.Base.log_cmd(user_trigger, cmd_to_send)
|
||||||
@@ -1348,9 +1356,10 @@ class Irc:
|
|||||||
batch_commands = ' | '.join(groupe)
|
batch_commands = ' | '.join(groupe)
|
||||||
self.send2socket(f':{dnickname} NOTICE {fromuser} : {batch_commands}')
|
self.send2socket(f':{dnickname} NOTICE {fromuser} : {batch_commands}')
|
||||||
|
|
||||||
count_level_definition += 1
|
|
||||||
self.send2socket(f':{dnickname} NOTICE {fromuser} : ')
|
self.send2socket(f':{dnickname} NOTICE {fromuser} : ')
|
||||||
|
|
||||||
|
count_level_definition += 1
|
||||||
|
|
||||||
self.send2socket(f':{dnickname} NOTICE {fromuser} : ***************** FIN DES COMMANDES *****************')
|
self.send2socket(f':{dnickname} NOTICE {fromuser} : ***************** FIN DES COMMANDES *****************')
|
||||||
|
|
||||||
case 'load':
|
case 'load':
|
||||||
|
|||||||
@@ -60,6 +60,7 @@ class Clone():
|
|||||||
|
|
||||||
self.Base.db_query_channel(action='add', module_name=self.module_name, channel_name=self.Config.CLONE_CHANNEL)
|
self.Base.db_query_channel(action='add', module_name=self.module_name, channel_name=self.Config.CLONE_CHANNEL)
|
||||||
self.Irc.send2socket(f":{self.Config.SERVICE_NICKNAME} JOIN {self.Config.CLONE_CHANNEL}")
|
self.Irc.send2socket(f":{self.Config.SERVICE_NICKNAME} JOIN {self.Config.CLONE_CHANNEL}")
|
||||||
|
self.Irc.send2socket(f":{self.Config.SERVICE_NICKNAME} SAMODE {self.Config.CLONE_CHANNEL} +o {self.Config.SERVICE_NICKNAME}")
|
||||||
self.Irc.send2socket(f":{self.Config.SERVICE_NICKNAME} MODE {self.Config.CLONE_CHANNEL} +nts")
|
self.Irc.send2socket(f":{self.Config.SERVICE_NICKNAME} MODE {self.Config.CLONE_CHANNEL} +nts")
|
||||||
self.Irc.send2socket(f":{self.Config.SERVICE_NICKNAME} MODE {self.Config.CLONE_CHANNEL} +k {self.Config.CLONE_CHANNEL_PASSWORD}")
|
self.Irc.send2socket(f":{self.Config.SERVICE_NICKNAME} MODE {self.Config.CLONE_CHANNEL} +k {self.Config.CLONE_CHANNEL_PASSWORD}")
|
||||||
|
|
||||||
@@ -126,6 +127,8 @@ class Clone():
|
|||||||
self.Irc.send2socket(f':{self.Config.SERVICE_NICKNAME} PRIVMSG {clone} :KILL')
|
self.Irc.send2socket(f':{self.Config.SERVICE_NICKNAME} PRIVMSG {clone} :KILL')
|
||||||
|
|
||||||
self.Base.db_query_channel(action='del', module_name=self.module_name, channel_name=self.Config.CLONE_CHANNEL)
|
self.Base.db_query_channel(action='del', module_name=self.module_name, channel_name=self.Config.CLONE_CHANNEL)
|
||||||
|
self.Irc.send2socket(f":{self.Config.SERVICE_NICKNAME} MODE {self.Config.CLONE_CHANNEL} -nts")
|
||||||
|
self.Irc.send2socket(f":{self.Config.SERVICE_NICKNAME} MODE {self.Config.CLONE_CHANNEL} -k {self.Config.CLONE_CHANNEL_PASSWORD}")
|
||||||
self.Irc.send2socket(f":{self.Config.SERVICE_NICKNAME} PART {self.Config.CLONE_CHANNEL}")
|
self.Irc.send2socket(f":{self.Config.SERVICE_NICKNAME} PART {self.Config.CLONE_CHANNEL}")
|
||||||
return None
|
return None
|
||||||
|
|
||||||
|
|||||||
@@ -35,10 +35,14 @@ class Command():
|
|||||||
# Create module commands (Mandatory)
|
# Create module commands (Mandatory)
|
||||||
self.commands_level = {
|
self.commands_level = {
|
||||||
1: ['join', 'part'],
|
1: ['join', 'part'],
|
||||||
2: ['owner', 'deowner', 'op', 'deop', 'halfop', 'dehalfop', 'voice',
|
2: ['owner', 'deowner', 'protect', 'deprotect', 'op', 'deop', 'halfop', 'dehalfop', 'voice',
|
||||||
'devoice', 'opall', 'deopall', 'devoiceall', 'voiceall', 'ban',
|
'devoice', 'opall', 'deopall', 'devoiceall', 'voiceall', 'ban',
|
||||||
'unban','kick', 'kickban', 'umode', 'svsjoin', 'svspart', 'svsnick', 'topic',
|
'unban','kick', 'kickban', 'umode', 'mode', 'svsjoin', 'svspart', 'svsnick', 'topic',
|
||||||
'wallops', 'globops','gnotice','whois', 'names', 'invite', 'inviteme']
|
'wallops', 'globops','gnotice','whois', 'names', 'invite', 'inviteme',
|
||||||
|
'sajoin', 'sapart',
|
||||||
|
'kill', 'gline', 'ungline', 'kline', 'unkline', 'shun', 'unshun',
|
||||||
|
'glinelist', 'shunlist', 'klinelist'],
|
||||||
|
3: ['map']
|
||||||
}
|
}
|
||||||
|
|
||||||
# Init the module
|
# Init the module
|
||||||
@@ -59,6 +63,9 @@ class Command():
|
|||||||
self.__load_module_configuration()
|
self.__load_module_configuration()
|
||||||
# End of mandatory methods you can start your customization #
|
# End of mandatory methods you can start your customization #
|
||||||
|
|
||||||
|
self.user_to_notice: str = ''
|
||||||
|
self.show_219: bool = True
|
||||||
|
|
||||||
return None
|
return None
|
||||||
|
|
||||||
def __set_commands(self, commands:dict[int, list[str]]) -> None:
|
def __set_commands(self, commands:dict[int, list[str]]) -> None:
|
||||||
@@ -123,49 +130,14 @@ class Command():
|
|||||||
|
|
||||||
return None
|
return None
|
||||||
|
|
||||||
def add_defender_channel(self, channel:str) -> bool:
|
|
||||||
"""Cette fonction ajoute les salons de join de Defender
|
|
||||||
|
|
||||||
Args:
|
|
||||||
channel (str): le salon à enregistrer.
|
|
||||||
"""
|
|
||||||
mes_donnees = {'channel': channel}
|
|
||||||
response = self.Base.db_execute_query("SELECT id FROM def_channels WHERE channel = :channel", mes_donnees)
|
|
||||||
|
|
||||||
isChannelExist = response.fetchone()
|
|
||||||
|
|
||||||
if isChannelExist is None:
|
|
||||||
mes_donnees = {'datetime': self.Base.get_datetime(), 'channel': channel}
|
|
||||||
insert = self.Base.db_execute_query(f"INSERT INTO def_channels (datetime, channel) VALUES (:datetime, :channel)", mes_donnees)
|
|
||||||
if insert.rowcount >=0:
|
|
||||||
return True
|
|
||||||
else:
|
|
||||||
return False
|
|
||||||
else:
|
|
||||||
return False
|
|
||||||
|
|
||||||
def delete_defender_channel(self, channel:str) -> bool:
|
|
||||||
"""Cette fonction supprime les salons de join de Defender
|
|
||||||
|
|
||||||
Args:
|
|
||||||
channel (str): le salon à enregistrer.
|
|
||||||
"""
|
|
||||||
mes_donnes = {'channel': channel}
|
|
||||||
response = self.Base.db_execute_query("DELETE FROM def_channels WHERE channel = :channel", mes_donnes)
|
|
||||||
|
|
||||||
affected_row = response.rowcount
|
|
||||||
|
|
||||||
if affected_row > 0:
|
|
||||||
return True
|
|
||||||
else:
|
|
||||||
return False
|
|
||||||
|
|
||||||
def cmd(self, data:list) -> None:
|
def cmd(self, data:list) -> None:
|
||||||
|
|
||||||
service_id = self.Config.SERVICE_ID # Defender serveur id
|
service_id = self.Config.SERVICE_ID
|
||||||
dnickname = self.Config.SERVICE_NICKNAME
|
dnickname = self.Config.SERVICE_NICKNAME
|
||||||
dchanlog = self.Config.SERVICE_CHANLOG
|
dchanlog = self.Config.SERVICE_CHANLOG
|
||||||
red = self.Config.COLORS.red
|
red = self.Config.COLORS.red
|
||||||
|
green = self.Config.COLORS.green
|
||||||
|
bold = self.Config.COLORS.bold
|
||||||
nogc = self.Config.COLORS.nogc
|
nogc = self.Config.COLORS.nogc
|
||||||
cmd = list(data).copy()
|
cmd = list(data).copy()
|
||||||
|
|
||||||
@@ -176,8 +148,57 @@ class Command():
|
|||||||
# [':irc.deb.biz.st', '403', 'Dev-PyDefender', '#Z', ':No', 'such', 'channel']
|
# [':irc.deb.biz.st', '403', 'Dev-PyDefender', '#Z', ':No', 'such', 'channel']
|
||||||
case '403' | '401':
|
case '403' | '401':
|
||||||
try:
|
try:
|
||||||
message = ' '.join(cmd[2:])
|
message = ' '.join(cmd[3:])
|
||||||
self.Irc.send2socket(f":{dnickname} PRIVMSG {dchanlog} :[{red}ERROR MSG{nogc}] {message}")
|
self.Irc.send2socket(f":{dnickname} NOTICE {self.user_to_notice} :[{red}ERROR MSG{nogc}] {message}")
|
||||||
|
except KeyError as ke:
|
||||||
|
self.Base.logs.error(ke)
|
||||||
|
except Exception as err:
|
||||||
|
self.Logs.warning(f'Unknown Error: {str(err)}')
|
||||||
|
|
||||||
|
case '006' | '018':
|
||||||
|
try:
|
||||||
|
# [':irc.deb.biz.st', '006', 'Dev-PyDefender', ':`-services.deb.biz.st', '------', '|', 'Users:', '9', '(47.37%)', '[00B]']
|
||||||
|
# [':irc.deb.biz.st', '018', 'Dev-PyDefender', ':4', 'servers', 'and', '19', 'users,', 'average', '4.75', 'users', 'per', 'server']
|
||||||
|
message = ' '.join(cmd[3:])
|
||||||
|
self.Irc.send2socket(f":{dnickname} NOTICE {self.user_to_notice} : [{green}SERVER MSG{nogc}] {message}")
|
||||||
|
except KeyError as ke:
|
||||||
|
self.Base.logs.error(ke)
|
||||||
|
except Exception as err:
|
||||||
|
self.Logs.warning(f'Unknown Error: {str(err)}')
|
||||||
|
|
||||||
|
case '219':
|
||||||
|
try:
|
||||||
|
# [':irc.deb.biz.st', '219', 'Dev-PyDefender', 's', ':End', 'of', '/STATS', 'report']
|
||||||
|
if not self.show_219:
|
||||||
|
# If there is a result in 223 then stop here
|
||||||
|
self.show_219 = True
|
||||||
|
return None
|
||||||
|
|
||||||
|
type_of_stats = str(cmd[3])
|
||||||
|
|
||||||
|
match type_of_stats:
|
||||||
|
case 's':
|
||||||
|
self.Irc.send2socket(f":{dnickname} NOTICE {self.user_to_notice} : No shun")
|
||||||
|
case 'G':
|
||||||
|
self.Irc.send2socket(f":{dnickname} NOTICE {self.user_to_notice} : No gline")
|
||||||
|
case 'k':
|
||||||
|
self.Irc.send2socket(f":{dnickname} NOTICE {self.user_to_notice} : No kline")
|
||||||
|
|
||||||
|
except KeyError as ke:
|
||||||
|
self.Base.logs.error(ke)
|
||||||
|
except Exception as err:
|
||||||
|
self.Logs.warning(f'Unknown Error: {str(err)}')
|
||||||
|
|
||||||
|
case '223':
|
||||||
|
try:
|
||||||
|
# [':irc.deb.biz.st', '223', 'Dev-PyDefender', 'G', '*@162.142.125.217', '67624', '18776', 'irc.deb.biz.st', ':Proxy/Drone', 'detected.', 'Check', 'https://dronebl.org/lookup?ip=162.142.125.217', 'for', 'details.']
|
||||||
|
self.show_219 = False
|
||||||
|
host = str(cmd[4])
|
||||||
|
author = str(cmd[7])
|
||||||
|
reason = ' '.join(cmd[8:])
|
||||||
|
|
||||||
|
self.Irc.send2socket(f":{dnickname} NOTICE {self.user_to_notice} : {bold}Author{nogc}: {author} - {bold}Host{nogc}: {host} - {bold}Reason{nogc}: {reason}")
|
||||||
|
|
||||||
except KeyError as ke:
|
except KeyError as ke:
|
||||||
self.Base.logs.error(ke)
|
self.Base.logs.error(ke)
|
||||||
except Exception as err:
|
except Exception as err:
|
||||||
@@ -368,6 +389,60 @@ class Command():
|
|||||||
except Exception as err:
|
except Exception as err:
|
||||||
self.Logs.warning(f'Unknown Error: {str(err)}')
|
self.Logs.warning(f'Unknown Error: {str(err)}')
|
||||||
|
|
||||||
|
case 'protect':
|
||||||
|
# /mode #channel +a user
|
||||||
|
# .protect #channel user
|
||||||
|
try:
|
||||||
|
if fromchannel is None:
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : Right command : /msg {dnickname} {command.upper()} [#SALON] [NICKNAME]')
|
||||||
|
return False
|
||||||
|
|
||||||
|
if len(cmd) == 1:
|
||||||
|
self.Irc.send2socket(f":{service_id} MODE {fromchannel} +a {fromuser}")
|
||||||
|
return True
|
||||||
|
|
||||||
|
# deowner nickname
|
||||||
|
if len(cmd) == 2:
|
||||||
|
nickname = cmd[1]
|
||||||
|
self.Irc.send2socket(f":{service_id} MODE {fromchannel} +a {nickname}")
|
||||||
|
return True
|
||||||
|
|
||||||
|
nickname = cmd[2]
|
||||||
|
self.Irc.send2socket(f":{service_id} MODE {fromchannel} +a {nickname}")
|
||||||
|
|
||||||
|
except IndexError as e:
|
||||||
|
self.Logs.warning(f'_hcmd DEOWNER: {str(e)}')
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : Right command : /msg {dnickname} {command.upper()} [#SALON] [NICKNAME]')
|
||||||
|
except Exception as err:
|
||||||
|
self.Logs.warning(f'Unknown Error: {str(err)}')
|
||||||
|
|
||||||
|
case 'deprotect':
|
||||||
|
# /mode #channel -a user
|
||||||
|
# .deprotect #channel user
|
||||||
|
try:
|
||||||
|
if fromchannel is None:
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : Right command : /msg {dnickname} {command.upper()} [#SALON] [NICKNAME]')
|
||||||
|
return False
|
||||||
|
|
||||||
|
if len(cmd) == 1:
|
||||||
|
self.Irc.send2socket(f":{service_id} MODE {fromchannel} -a {fromuser}")
|
||||||
|
return True
|
||||||
|
|
||||||
|
# deowner nickname
|
||||||
|
if len(cmd) == 2:
|
||||||
|
nickname = cmd[1]
|
||||||
|
self.Irc.send2socket(f":{service_id} MODE {fromchannel} -a {nickname}")
|
||||||
|
return True
|
||||||
|
|
||||||
|
nickname = cmd[2]
|
||||||
|
self.Irc.send2socket(f":{service_id} MODE {fromchannel} -a {nickname}")
|
||||||
|
|
||||||
|
except IndexError as e:
|
||||||
|
self.Logs.warning(f'_hcmd DEOWNER: {str(e)}')
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : Right command : /msg {dnickname} {command.upper()} [#SALON] [NICKNAME]')
|
||||||
|
except Exception as err:
|
||||||
|
self.Logs.warning(f'Unknown Error: {str(err)}')
|
||||||
|
|
||||||
case 'halfop':
|
case 'halfop':
|
||||||
# /mode #channel +h user
|
# /mode #channel +h user
|
||||||
# .halfop #channel user
|
# .halfop #channel user
|
||||||
@@ -481,7 +556,7 @@ class Command():
|
|||||||
try:
|
try:
|
||||||
sentchannel = str(cmd[1]) if self.Base.Is_Channel(cmd[1]) else None
|
sentchannel = str(cmd[1]) if self.Base.Is_Channel(cmd[1]) else None
|
||||||
if sentchannel is None:
|
if sentchannel is None:
|
||||||
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : Right command : /msg {dnickname} ban [#SALON] [NICKNAME]')
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : Right command : /msg {dnickname} {command.upper()} [#SALON] [NICKNAME]')
|
||||||
return False
|
return False
|
||||||
|
|
||||||
nickname = cmd[2]
|
nickname = cmd[2]
|
||||||
@@ -490,7 +565,7 @@ class Command():
|
|||||||
self.Logs.debug(f'{fromuser} has banned {nickname} from {sentchannel}')
|
self.Logs.debug(f'{fromuser} has banned {nickname} from {sentchannel}')
|
||||||
except IndexError as e:
|
except IndexError as e:
|
||||||
self.Logs.warning(f'_hcmd BAN: {str(e)}')
|
self.Logs.warning(f'_hcmd BAN: {str(e)}')
|
||||||
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : Right command : /msg {dnickname} ban [#SALON] [NICKNAME]')
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : Right command : /msg {dnickname} {command.upper()} [#SALON] [NICKNAME]')
|
||||||
except Exception as err:
|
except Exception as err:
|
||||||
self.Logs.warning(f'Unknown Error: {str(err)}')
|
self.Logs.warning(f'Unknown Error: {str(err)}')
|
||||||
|
|
||||||
@@ -679,6 +754,7 @@ class Command():
|
|||||||
|
|
||||||
case 'whois':
|
case 'whois':
|
||||||
try:
|
try:
|
||||||
|
self.user_to_notice = fromuser
|
||||||
if len(cmd) == 1:
|
if len(cmd) == 1:
|
||||||
self.Irc.send2socket(f":{dnickname} NOTICE {fromuser} :/msg {dnickname} {str(cmd[0]).upper()} NICKNAME")
|
self.Irc.send2socket(f":{dnickname} NOTICE {fromuser} :/msg {dnickname} {str(cmd[0]).upper()} NICKNAME")
|
||||||
return None
|
return None
|
||||||
@@ -756,6 +832,16 @@ class Command():
|
|||||||
except Exception as err:
|
except Exception as err:
|
||||||
self.Logs.warning(f'Unknown Error: {str(err)}')
|
self.Logs.warning(f'Unknown Error: {str(err)}')
|
||||||
|
|
||||||
|
case 'map':
|
||||||
|
try:
|
||||||
|
self.user_to_notice = fromuser
|
||||||
|
self.Irc.send2socket(f':{dnickname} MAP')
|
||||||
|
|
||||||
|
except KeyError as ke:
|
||||||
|
self.Base.logs.error(ke)
|
||||||
|
except Exception as err:
|
||||||
|
self.Logs.warning(f'Unknown Error: {str(err)}')
|
||||||
|
|
||||||
case 'umode':
|
case 'umode':
|
||||||
try:
|
try:
|
||||||
# .umode nickname +mode
|
# .umode nickname +mode
|
||||||
@@ -768,6 +854,39 @@ class Command():
|
|||||||
except Exception as err:
|
except Exception as err:
|
||||||
self.Logs.warning(f'Unknown Error: {str(err)}')
|
self.Logs.warning(f'Unknown Error: {str(err)}')
|
||||||
|
|
||||||
|
case 'mode':
|
||||||
|
# .mode #channel +/-mode
|
||||||
|
# .mode +/-mode
|
||||||
|
try:
|
||||||
|
|
||||||
|
if len(cmd) < 2:
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : Right command : /msg {dnickname} {command.upper()} [#CHANNEL] [+/-]mode')
|
||||||
|
return None
|
||||||
|
|
||||||
|
if fromchannel is None:
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : Right command : /msg {dnickname} {command.upper()} [#CHANNEL] [+/-]mode')
|
||||||
|
return None
|
||||||
|
|
||||||
|
if len(cmd) == 2:
|
||||||
|
channel_mode = cmd[1]
|
||||||
|
if self.Base.Is_Channel(fromchannel):
|
||||||
|
self.Irc.send2socket(f":{dnickname} MODE {fromchannel} {channel_mode}")
|
||||||
|
else:
|
||||||
|
self.Irc.send2socket(f":{dnickname} NOTICE {fromuser} : Right command : Channel [{fromchannel}] is not correct should start with #")
|
||||||
|
return None
|
||||||
|
|
||||||
|
if len(cmd) == 3:
|
||||||
|
provided_channel = cmd[1]
|
||||||
|
channel_mode = cmd[2]
|
||||||
|
self.Irc.send2socket(f":{service_id} MODE {provided_channel} {channel_mode}")
|
||||||
|
return None
|
||||||
|
|
||||||
|
except IndexError as e:
|
||||||
|
self.Logs.warning(f'_hcmd OP: {str(e)}')
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : Right command : /msg {dnickname} {command.upper()} [#CHANNEL] [+/-]mode')
|
||||||
|
except Exception as err:
|
||||||
|
self.Logs.warning(f'Unknown Error: {str(err)}')
|
||||||
|
|
||||||
case 'svsjoin':
|
case 'svsjoin':
|
||||||
try:
|
try:
|
||||||
# .svsjoin nickname #channel
|
# .svsjoin nickname #channel
|
||||||
@@ -800,6 +919,38 @@ class Command():
|
|||||||
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : /msg {dnickname} SVSPART nickname #channel')
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : /msg {dnickname} SVSPART nickname #channel')
|
||||||
self.Logs.warning(f'Unknown Error: {str(err)}')
|
self.Logs.warning(f'Unknown Error: {str(err)}')
|
||||||
|
|
||||||
|
case 'sajoin':
|
||||||
|
try:
|
||||||
|
# .sajoin nickname #channel
|
||||||
|
nickname = str(cmd[1])
|
||||||
|
channel = str(cmd[2])
|
||||||
|
if len(cmd) < 3:
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : /msg {dnickname} {command.upper()} nickname #channel')
|
||||||
|
return None
|
||||||
|
|
||||||
|
self.Irc.send2socket(f':{self.Config.SERVEUR_ID} SAJOIN {nickname} {channel}')
|
||||||
|
except KeyError as ke:
|
||||||
|
self.Base.logs.error(ke)
|
||||||
|
except Exception as err:
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : /msg {dnickname} {command.upper()} nickname #channel')
|
||||||
|
self.Logs.warning(f'Unknown Error: {str(err)}')
|
||||||
|
|
||||||
|
case 'sapart':
|
||||||
|
try:
|
||||||
|
# .sapart nickname #channel
|
||||||
|
nickname = str(cmd[1])
|
||||||
|
channel = str(cmd[2])
|
||||||
|
if len(cmd) < 3:
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : /msg {dnickname} {command.upper()} nickname #channel')
|
||||||
|
return None
|
||||||
|
|
||||||
|
self.Irc.send2socket(f':{self.Config.SERVEUR_ID} SAPART {nickname} {channel}')
|
||||||
|
except KeyError as ke:
|
||||||
|
self.Base.logs.error(ke)
|
||||||
|
except Exception as err:
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : /msg {dnickname} {command.upper()} nickname #channel')
|
||||||
|
self.Logs.warning(f'Unknown Error: {str(err)}')
|
||||||
|
|
||||||
case 'svsnick':
|
case 'svsnick':
|
||||||
try:
|
try:
|
||||||
# .svsnick nickname newnickname
|
# .svsnick nickname newnickname
|
||||||
@@ -812,12 +963,203 @@ class Command():
|
|||||||
return None
|
return None
|
||||||
|
|
||||||
if len(cmd) != 3:
|
if len(cmd) != 3:
|
||||||
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : /msg {dnickname} SVSNICK nickname newnickname')
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : /msg {dnickname} {command.upper()} nickname newnickname')
|
||||||
return None
|
return None
|
||||||
|
|
||||||
self.Irc.send2socket(f':{self.Config.SERVEUR_ID} SVSNICK {nickname} {newnickname} {unixtime}')
|
self.Irc.send2socket(f':{self.Config.SERVEUR_ID} SVSNICK {nickname} {newnickname} {unixtime}')
|
||||||
|
|
||||||
|
except KeyError as ke:
|
||||||
|
self.Base.logs.error(ke)
|
||||||
|
except Exception as err:
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : /msg {dnickname} {command.upper()} nickname newnickname')
|
||||||
|
self.Logs.warning(f'Unknown Error: {str(err)}')
|
||||||
|
|
||||||
|
case 'kill':
|
||||||
|
try:
|
||||||
|
# 'kill', 'gline', 'ungline', 'shun', 'unshun'
|
||||||
|
# .kill nickname reason
|
||||||
|
if len(cmd) < 3:
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : /msg {dnickname} {command.upper()} nickname reason')
|
||||||
|
return None
|
||||||
|
|
||||||
|
nickname = str(cmd[1])
|
||||||
|
kill_reason = ' '.join(cmd[2:])
|
||||||
|
|
||||||
|
self.Irc.send2socket(f":{service_id} KILL {nickname} {kill_reason} ({self.Config.COLORS.red}{dnickname}{self.Config.COLORS.nogc})")
|
||||||
except KeyError as ke:
|
except KeyError as ke:
|
||||||
self.Base.logs.error(ke)
|
self.Base.logs.error(ke)
|
||||||
except Exception as err:
|
except Exception as err:
|
||||||
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : /msg {dnickname} SVSNICK nickname newnickname')
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : /msg {dnickname} SVSNICK nickname newnickname')
|
||||||
self.Logs.warning(f'Unknown Error: {str(err)}')
|
self.Logs.warning(f'Unknown Error: {str(err)}')
|
||||||
|
|
||||||
|
case 'gline':
|
||||||
|
try:
|
||||||
|
# TKL + G user host set_by expire_timestamp set_at_timestamp :reason
|
||||||
|
# .gline [nickname] [host] [reason]
|
||||||
|
if len(cmd) < 4:
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : /msg {dnickname} {command.upper()} nickname host reason')
|
||||||
|
return None
|
||||||
|
|
||||||
|
nickname = str(cmd[1])
|
||||||
|
hostname = str(cmd[2])
|
||||||
|
set_at_timestamp = self.Base.get_unixtime()
|
||||||
|
expire_time = (60 * 60 * 24) + set_at_timestamp
|
||||||
|
gline_reason = ' '.join(cmd[3:])
|
||||||
|
|
||||||
|
if nickname == '*' and hostname == '*':
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : You want to close the server ? i would recommand ./unrealircd stop :)')
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : /msg {dnickname} {command.upper()} nickname host reason')
|
||||||
|
return None
|
||||||
|
|
||||||
|
self.Irc.send2socket(f":{self.Config.SERVEUR_ID} TKL + G {nickname} {hostname} {dnickname} {expire_time} {set_at_timestamp} :{gline_reason}")
|
||||||
|
except KeyError as ke:
|
||||||
|
self.Base.logs.error(ke)
|
||||||
|
except Exception as err:
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : /msg {dnickname} {command.upper()} nickname host reason')
|
||||||
|
self.Logs.warning(f'Unknown Error: {str(err)}')
|
||||||
|
|
||||||
|
case 'ungline':
|
||||||
|
try:
|
||||||
|
# 'shun', 'unshun'
|
||||||
|
# TKL + G user host set_by expire_timestamp set_at_timestamp :reason
|
||||||
|
# .ungline nickname host
|
||||||
|
if len(cmd) < 2:
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : /msg {dnickname} {command.upper()} nickname hostname')
|
||||||
|
return None
|
||||||
|
|
||||||
|
nickname = str(cmd[1])
|
||||||
|
hostname = str(cmd[2])
|
||||||
|
|
||||||
|
self.Irc.send2socket(f":{self.Config.SERVEUR_ID} TKL - G {nickname} {hostname} {dnickname}")
|
||||||
|
|
||||||
|
except KeyError as ke:
|
||||||
|
self.Base.logs.error(ke)
|
||||||
|
except Exception as err:
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : /msg {dnickname} {command.upper()} nickname hostname')
|
||||||
|
self.Logs.warning(f'Unknown Error: {str(err)}')
|
||||||
|
|
||||||
|
case 'kline':
|
||||||
|
try:
|
||||||
|
# TKL + k user host set_by expire_timestamp set_at_timestamp :reason
|
||||||
|
# .gline [nickname] [host] [reason]
|
||||||
|
if len(cmd) < 4:
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : /msg {dnickname} {command.upper()} nickname host reason')
|
||||||
|
return None
|
||||||
|
|
||||||
|
nickname = str(cmd[1])
|
||||||
|
hostname = str(cmd[2])
|
||||||
|
set_at_timestamp = self.Base.get_unixtime()
|
||||||
|
expire_time = (60 * 60 * 24) + set_at_timestamp
|
||||||
|
gline_reason = ' '.join(cmd[3:])
|
||||||
|
|
||||||
|
if nickname == '*' and hostname == '*':
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : You want to close the server ? i would recommand ./unrealircd stop :)')
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : /msg {dnickname} {command.upper()} nickname host reason')
|
||||||
|
return None
|
||||||
|
|
||||||
|
self.Irc.send2socket(f":{self.Config.SERVEUR_ID} TKL + k {nickname} {hostname} {dnickname} {expire_time} {set_at_timestamp} :{gline_reason}")
|
||||||
|
except KeyError as ke:
|
||||||
|
self.Base.logs.error(ke)
|
||||||
|
except Exception as err:
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : /msg {dnickname} {command.upper()} nickname host reason')
|
||||||
|
self.Logs.warning(f'Unknown Error: {str(err)}')
|
||||||
|
|
||||||
|
case 'unkline':
|
||||||
|
try:
|
||||||
|
# 'shun', 'unshun'
|
||||||
|
# TKL + G user host set_by expire_timestamp set_at_timestamp :reason
|
||||||
|
# .ungline nickname host
|
||||||
|
if len(cmd) < 2:
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : /msg {dnickname} {command.upper()} nickname hostname')
|
||||||
|
return None
|
||||||
|
|
||||||
|
nickname = str(cmd[1])
|
||||||
|
hostname = str(cmd[2])
|
||||||
|
|
||||||
|
self.Irc.send2socket(f":{self.Config.SERVEUR_ID} TKL - k {nickname} {hostname} {dnickname}")
|
||||||
|
|
||||||
|
except KeyError as ke:
|
||||||
|
self.Base.logs.error(ke)
|
||||||
|
except Exception as err:
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : /msg {dnickname} {command.upper()} nickname hostname')
|
||||||
|
self.Logs.warning(f'Unknown Error: {str(err)}')
|
||||||
|
|
||||||
|
case 'shun':
|
||||||
|
try:
|
||||||
|
# TKL + G user host set_by expire_timestamp set_at_timestamp :reason
|
||||||
|
# .shun [nickname] [host] [reason]
|
||||||
|
|
||||||
|
if len(cmd) < 4:
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : /msg {dnickname} {command.upper()} nickname host reason')
|
||||||
|
return None
|
||||||
|
|
||||||
|
nickname = str(cmd[1])
|
||||||
|
hostname = str(cmd[2])
|
||||||
|
set_at_timestamp = self.Base.get_unixtime()
|
||||||
|
expire_time = (60 * 60 * 24) + set_at_timestamp
|
||||||
|
shun_reason = ' '.join(cmd[3:])
|
||||||
|
|
||||||
|
if nickname == '*' and hostname == '*':
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : You want to close the server ? i would recommand ./unrealircd stop :)')
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : /msg {dnickname} {command.upper()} nickname host reason')
|
||||||
|
return None
|
||||||
|
|
||||||
|
self.Irc.send2socket(f":{self.Config.SERVEUR_ID} TKL + s {nickname} {hostname} {dnickname} {expire_time} {set_at_timestamp} :{shun_reason}")
|
||||||
|
except KeyError as ke:
|
||||||
|
self.Base.logs.error(ke)
|
||||||
|
except Exception as err:
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : /msg {dnickname} {command.upper()} nickname host reason')
|
||||||
|
self.Logs.warning(f'Unknown Error: {str(err)}')
|
||||||
|
|
||||||
|
case 'unshun':
|
||||||
|
try:
|
||||||
|
# 'shun', 'unshun'
|
||||||
|
# TKL + G user host set_by expire_timestamp set_at_timestamp :reason
|
||||||
|
# .unshun nickname host
|
||||||
|
if len(cmd) < 2:
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : /msg {dnickname} {command.upper()} nickname hostname')
|
||||||
|
return None
|
||||||
|
|
||||||
|
nickname = str(cmd[1])
|
||||||
|
hostname = str(cmd[2])
|
||||||
|
|
||||||
|
self.Irc.send2socket(f":{self.Config.SERVEUR_ID} TKL - s {nickname} {hostname} {dnickname}")
|
||||||
|
|
||||||
|
except KeyError as ke:
|
||||||
|
self.Base.logs.error(ke)
|
||||||
|
except Exception as err:
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : /msg {dnickname} {command.upper()} nickname hostname')
|
||||||
|
self.Logs.warning(f'Unknown Error: {str(err)}')
|
||||||
|
|
||||||
|
case 'glinelist':
|
||||||
|
try:
|
||||||
|
self.user_to_notice = fromuser
|
||||||
|
self.Irc.send2socket(f":{self.Config.SERVICE_ID} STATS G")
|
||||||
|
|
||||||
|
except KeyError as ke:
|
||||||
|
self.Base.logs.error(ke)
|
||||||
|
except Exception as err:
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : /msg {dnickname} {command.upper()}')
|
||||||
|
self.Logs.warning(f'Unknown Error: {str(err)}')
|
||||||
|
|
||||||
|
case 'shunlist':
|
||||||
|
try:
|
||||||
|
self.user_to_notice = fromuser
|
||||||
|
self.Irc.send2socket(f":{self.Config.SERVICE_ID} STATS s")
|
||||||
|
|
||||||
|
except KeyError as ke:
|
||||||
|
self.Base.logs.error(ke)
|
||||||
|
except Exception as err:
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : /msg {dnickname} {command.upper()}')
|
||||||
|
self.Logs.warning(f'Unknown Error: {str(err)}')
|
||||||
|
|
||||||
|
case 'klinelist':
|
||||||
|
try:
|
||||||
|
self.user_to_notice = fromuser
|
||||||
|
self.Irc.send2socket(f":{self.Config.SERVICE_ID} STATS k")
|
||||||
|
|
||||||
|
except KeyError as ke:
|
||||||
|
self.Base.logs.error(ke)
|
||||||
|
except Exception as err:
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} : /msg {dnickname} {command.upper()}')
|
||||||
|
self.Logs.warning(f'Unknown Error: {str(err)}')
|
||||||
@@ -111,9 +111,6 @@ class Defender():
|
|||||||
self.__load_module_configuration()
|
self.__load_module_configuration()
|
||||||
# End of mandatory methods you can start your customization #
|
# End of mandatory methods you can start your customization #
|
||||||
|
|
||||||
# # Rejoindre les salons
|
|
||||||
# self.join_saved_channels()
|
|
||||||
|
|
||||||
self.timeout = self.Config.API_TIMEOUT
|
self.timeout = self.Config.API_TIMEOUT
|
||||||
|
|
||||||
# Listes qui vont contenir les ip a scanner avec les différentes API
|
# Listes qui vont contenir les ip a scanner avec les différentes API
|
||||||
@@ -150,7 +147,8 @@ class Defender():
|
|||||||
self.Base.create_thread(func=self.thread_reputation_timer)
|
self.Base.create_thread(func=self.thread_reputation_timer)
|
||||||
|
|
||||||
if self.ModConfig.reputation == 1:
|
if self.ModConfig.reputation == 1:
|
||||||
self.Irc.send2socket(f":{self.Config.SERVICE_ID} SAMODE {self.Config.SALON_JAIL} +{self.Config.SERVICE_UMODES} {self.Config.SERVICE_NICKNAME}")
|
self.Irc.send2socket(f":{self.Config.SERVEUR_ID} SJOIN {self.Base.get_unixtime()} {self.Config.SALON_JAIL} + :{self.Config.SERVICE_NICKNAME}")
|
||||||
|
self.Irc.send2socket(f":{self.Config.SERVICE_NICKNAME} SAMODE {self.Config.SALON_JAIL} +o {self.Config.SERVICE_NICKNAME}")
|
||||||
|
|
||||||
return None
|
return None
|
||||||
|
|
||||||
@@ -249,40 +247,6 @@ class Defender():
|
|||||||
self.reputationTimer_isRunning:bool = False
|
self.reputationTimer_isRunning:bool = False
|
||||||
return None
|
return None
|
||||||
|
|
||||||
def add_defender_channel(self, channel:str) -> bool:
|
|
||||||
"""Cette fonction ajoute les salons de join de Defender
|
|
||||||
|
|
||||||
Args:
|
|
||||||
channel (str): le salon à enregistrer.
|
|
||||||
"""
|
|
||||||
mes_donnees = {'channel': channel}
|
|
||||||
response = self.Base.db_execute_query("SELECT id FROM def_channels WHERE channel = :channel", mes_donnees)
|
|
||||||
|
|
||||||
isChannelExist = response.fetchone()
|
|
||||||
|
|
||||||
if isChannelExist is None:
|
|
||||||
mes_donnees = {'datetime': self.Base.get_datetime(), 'channel': channel}
|
|
||||||
insert = self.Base.db_execute_query(f"INSERT INTO def_channels (datetime, channel) VALUES (:datetime, :channel)", mes_donnees)
|
|
||||||
return True
|
|
||||||
else:
|
|
||||||
return False
|
|
||||||
|
|
||||||
def delete_defender_channel(self, channel:str) -> bool:
|
|
||||||
"""Cette fonction supprime les salons de join de Defender
|
|
||||||
|
|
||||||
Args:
|
|
||||||
channel (str): le salon à enregistrer.
|
|
||||||
"""
|
|
||||||
mes_donnes = {'channel': channel}
|
|
||||||
response = self.Base.db_execute_query("DELETE FROM def_channels WHERE channel = :channel", mes_donnes)
|
|
||||||
|
|
||||||
affected_row = response.rowcount
|
|
||||||
|
|
||||||
if affected_row > 0:
|
|
||||||
return True
|
|
||||||
else:
|
|
||||||
return False
|
|
||||||
|
|
||||||
def reputation_insert(self, reputationModel: ReputationModel) -> bool:
|
def reputation_insert(self, reputationModel: ReputationModel) -> bool:
|
||||||
|
|
||||||
response = False
|
response = False
|
||||||
@@ -372,7 +336,7 @@ class Defender():
|
|||||||
|
|
||||||
def join_saved_channels(self) -> None:
|
def join_saved_channels(self) -> None:
|
||||||
|
|
||||||
result = self.Base.db_execute_query("SELECT id, channel FROM def_channels")
|
result = self.Base.db_execute_query(f"SELECT distinct channel_name FROM {self.Config.table_channel}")
|
||||||
channels = result.fetchall()
|
channels = result.fetchall()
|
||||||
jail_chan = self.Config.SALON_JAIL
|
jail_chan = self.Config.SALON_JAIL
|
||||||
jail_chan_mode = self.Config.SALON_JAIL_MODES
|
jail_chan_mode = self.Config.SALON_JAIL_MODES
|
||||||
@@ -383,7 +347,7 @@ class Defender():
|
|||||||
unixtime = self.Base.get_unixtime()
|
unixtime = self.Base.get_unixtime()
|
||||||
|
|
||||||
for channel in channels:
|
for channel in channels:
|
||||||
id, chan = channel
|
chan = channel[0]
|
||||||
self.Irc.send2socket(f":{self.Config.SERVEUR_ID} SJOIN {unixtime} {chan} + :{self.Config.SERVICE_ID}")
|
self.Irc.send2socket(f":{self.Config.SERVEUR_ID} SJOIN {unixtime} {chan} + :{self.Config.SERVICE_ID}")
|
||||||
if chan == jail_chan:
|
if chan == jail_chan:
|
||||||
self.Irc.send2socket(f":{service_id} SAMODE {jail_chan} +{dumodes} {dnickname}")
|
self.Irc.send2socket(f":{service_id} SAMODE {jail_chan} +{dumodes} {dnickname}")
|
||||||
@@ -1000,19 +964,12 @@ class Defender():
|
|||||||
self.Logs.error(f"Thread_cloudfilt_scan Error : {ve}")
|
self.Logs.error(f"Thread_cloudfilt_scan Error : {ve}")
|
||||||
|
|
||||||
def cmd(self, data: list) -> None:
|
def cmd(self, data: list) -> None:
|
||||||
|
try:
|
||||||
service_id = self.Config.SERVICE_ID # Defender serveur id
|
service_id = self.Config.SERVICE_ID # Defender serveur id
|
||||||
cmd = list(data).copy()
|
cmd = list(data).copy()
|
||||||
|
|
||||||
if len(cmd) < 2:
|
|
||||||
return None
|
|
||||||
|
|
||||||
match cmd[1]:
|
match cmd[1]:
|
||||||
|
|
||||||
case 'EOS':
|
|
||||||
if self.Irc.INIT == 0:
|
|
||||||
self.Irc.send2socket(f":{service_id} SAMODE {self.Config.SALON_JAIL} +{self.Config.SERVICE_UMODES} {self.Config.SERVICE_NICKNAME}")
|
|
||||||
|
|
||||||
case 'REPUTATION':
|
case 'REPUTATION':
|
||||||
# :001 REPUTATION 91.168.141.239 118
|
# :001 REPUTATION 91.168.141.239 118
|
||||||
try:
|
try:
|
||||||
@@ -1029,8 +986,23 @@ class Defender():
|
|||||||
except IndexError as ie:
|
except IndexError as ie:
|
||||||
self.Logs.error(f'cmd reputation: index error: {ie}')
|
self.Logs.error(f'cmd reputation: index error: {ie}')
|
||||||
|
|
||||||
|
if len(cmd) < 3:
|
||||||
|
return None
|
||||||
|
|
||||||
match cmd[2]:
|
match cmd[2]:
|
||||||
|
|
||||||
|
case 'MODE':
|
||||||
|
# ['...', ':001XSCU0Q', 'MODE', '#jail', '+b', '~security-group:unknown-users']
|
||||||
|
channel = str(cmd[3])
|
||||||
|
mode = str(cmd[4])
|
||||||
|
group_to_check = str(cmd[5:])
|
||||||
|
group_to_unban = '~security-group:unknown-users'
|
||||||
|
|
||||||
|
if self.Config.SALON_JAIL == channel:
|
||||||
|
if mode == '+b' and group_to_unban in group_to_check:
|
||||||
|
self.Irc.send2socket(f":{service_id} MODE {self.Config.SALON_JAIL} -b ~security-group:unknown-users")
|
||||||
|
self.Irc.send2socket(f":{service_id} MODE {self.Config.SALON_JAIL} -eee ~security-group:webirc-users ~security-group:known-users ~security-group:websocket-users")
|
||||||
|
|
||||||
case 'PRIVMSG':
|
case 'PRIVMSG':
|
||||||
cmd.pop(0)
|
cmd.pop(0)
|
||||||
user_trigger = str(cmd[0]).replace(':','')
|
user_trigger = str(cmd[0]).replace(':','')
|
||||||
@@ -1096,6 +1068,7 @@ class Defender():
|
|||||||
|
|
||||||
get_reputation = self.reputation_get_Reputation(parsed_UID)
|
get_reputation = self.reputation_get_Reputation(parsed_UID)
|
||||||
|
|
||||||
|
if parsed_chan != self.Config.SALON_JAIL:
|
||||||
self.Irc.send2socket(f":{service_id} MODE {parsed_chan} +b ~security-group:unknown-users")
|
self.Irc.send2socket(f":{service_id} MODE {parsed_chan} +b ~security-group:unknown-users")
|
||||||
self.Irc.send2socket(f":{service_id} MODE {parsed_chan} +eee ~security-group:webirc-users ~security-group:known-users ~security-group:websocket-users")
|
self.Irc.send2socket(f":{service_id} MODE {parsed_chan} +eee ~security-group:webirc-users ~security-group:known-users ~security-group:websocket-users")
|
||||||
|
|
||||||
@@ -1185,6 +1158,13 @@ class Defender():
|
|||||||
self.Irc.send2socket(f":{service_id} MODE {chan.name} -b {final_nickname}!*@*")
|
self.Irc.send2socket(f":{service_id} MODE {chan.name} -b {final_nickname}!*@*")
|
||||||
self.reputation_delete(final_UID)
|
self.reputation_delete(final_UID)
|
||||||
|
|
||||||
|
except KeyError as ke:
|
||||||
|
self.Logs.error(f"{ke} / {cmd} / length {str(len(cmd))}")
|
||||||
|
except IndexError as ie:
|
||||||
|
self.Logs.error(f"{ie} / {cmd} / length {str(len(cmd))}")
|
||||||
|
except Exception as err:
|
||||||
|
self.Logs.error(f"General Error: {err}")
|
||||||
|
|
||||||
def _hcmds(self, user:str, channel: any, cmd: list, fullcmd: list = []) -> None:
|
def _hcmds(self, user:str, channel: any, cmd: list, fullcmd: list = []) -> None:
|
||||||
|
|
||||||
command = str(cmd[0]).lower()
|
command = str(cmd[0]).lower()
|
||||||
|
|||||||
@@ -76,6 +76,9 @@ class Jsonrpc():
|
|||||||
if self.Rpc.Error.code != 0:
|
if self.Rpc.Error.code != 0:
|
||||||
self.Irc.sendPrivMsg(f"[{self.Config.COLORS.red}ERROR{self.Config.COLORS.nogc}] {self.Rpc.Error.message}", self.Config.SERVICE_CHANLOG)
|
self.Irc.sendPrivMsg(f"[{self.Config.COLORS.red}ERROR{self.Config.COLORS.nogc}] {self.Rpc.Error.message}", self.Config.SERVICE_CHANLOG)
|
||||||
|
|
||||||
|
if self.UnrealIrcdRpcLive.Error.code != 0:
|
||||||
|
self.Irc.sendPrivMsg(f"[{self.Config.COLORS.red}ERROR{self.Config.COLORS.nogc}] {self.UnrealIrcdRpcLive.Error.message}", self.Config.SERVICE_CHANLOG)
|
||||||
|
|
||||||
return None
|
return None
|
||||||
|
|
||||||
def __set_commands(self, commands:dict[int, list[str]]) -> None:
|
def __set_commands(self, commands:dict[int, list[str]]) -> None:
|
||||||
@@ -116,13 +119,29 @@ class Jsonrpc():
|
|||||||
|
|
||||||
dnickname = self.Config.SERVICE_NICKNAME
|
dnickname = self.Config.SERVICE_NICKNAME
|
||||||
dchanlog = self.Config.SERVICE_CHANLOG
|
dchanlog = self.Config.SERVICE_CHANLOG
|
||||||
|
green = self.Config.COLORS.green
|
||||||
|
nogc = self.Config.COLORS.nogc
|
||||||
|
bold = self.Config.COLORS.bold
|
||||||
|
red = self.Config.COLORS.red
|
||||||
|
|
||||||
self.Irc.sendPrivMsg(msg=json_response, channel=dchanlog)
|
if json_response.result == True:
|
||||||
|
self.Irc.sendPrivMsg(msg=f"[{bold}{green}JSONRPC{nogc}{bold}] Event activated", channel=dchanlog)
|
||||||
|
return None
|
||||||
|
|
||||||
|
level = json_response.result.level
|
||||||
|
subsystem = json_response.result.subsystem
|
||||||
|
event_id = json_response.result.event_id
|
||||||
|
log_source = json_response.result.log_source
|
||||||
|
msg = json_response.result.msg
|
||||||
|
|
||||||
|
build_msg = f"{green}{log_source}{nogc}: [{bold}{level}{bold}] {subsystem}.{event_id} - {msg}"
|
||||||
|
|
||||||
|
self.Irc.sendPrivMsg(msg=build_msg, channel=dchanlog)
|
||||||
|
|
||||||
def thread_start_jsonrpc(self):
|
def thread_start_jsonrpc(self):
|
||||||
|
|
||||||
if self.UnrealIrcdRpcLive.Error.code == 0:
|
if self.UnrealIrcdRpcLive.Error.code == 0:
|
||||||
self.UnrealIrcdRpcLive.subscribe()
|
self.UnrealIrcdRpcLive.subscribe(["all"])
|
||||||
self.subscribed = True
|
self.subscribed = True
|
||||||
else:
|
else:
|
||||||
self.Irc.sendPrivMsg(f"[{self.Config.COLORS.red}ERROR{self.Config.COLORS.nogc}] {self.UnrealIrcdRpcLive.Error.message}", self.Config.SERVICE_CHANLOG)
|
self.Irc.sendPrivMsg(f"[{self.Config.COLORS.red}ERROR{self.Config.COLORS.nogc}] {self.UnrealIrcdRpcLive.Error.message}", self.Config.SERVICE_CHANLOG)
|
||||||
@@ -211,24 +230,25 @@ class Jsonrpc():
|
|||||||
return None
|
return None
|
||||||
|
|
||||||
chan_list = []
|
chan_list = []
|
||||||
for chan in UserInfo.channels:
|
for chan in UserInfo.user.channels:
|
||||||
chan_list.append(chan["name"])
|
chan_list.append(chan.name)
|
||||||
|
|
||||||
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :UID : {UserInfo.id}')
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :UID : {UserInfo.id}')
|
||||||
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :NICKNAME : {UserInfo.name}')
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :NICKNAME : {UserInfo.name}')
|
||||||
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :USERNAME : {UserInfo.username}')
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :USERNAME : {UserInfo.user.username}')
|
||||||
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :REALNAME : {UserInfo.realname}')
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :REALNAME : {UserInfo.user.realname}')
|
||||||
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :MODES : {UserInfo.user.modes}')
|
||||||
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :CHANNELS : {chan_list}')
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :CHANNELS : {chan_list}')
|
||||||
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :SECURITY GROUP : {UserInfo.security_groups}')
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :SECURITY GROUP : {UserInfo.user.security_groups}')
|
||||||
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :REPUTATION : {UserInfo.reputation}')
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :REPUTATION : {UserInfo.user.reputation}')
|
||||||
|
|
||||||
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :IP : {UserInfo.ip}')
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :IP : {UserInfo.ip}')
|
||||||
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :COUNTRY CODE : {UserInfo.country_code}')
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :COUNTRY CODE : {UserInfo.geoip.country_code}')
|
||||||
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :ASN : {UserInfo.asn}')
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :ASN : {UserInfo.geoip.asn}')
|
||||||
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :ASNAME : {UserInfo.asname}')
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :ASNAME : {UserInfo.geoip.asname}')
|
||||||
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :CLOAKED HOST : {UserInfo.cloakedhost}')
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :CLOAKED HOST : {UserInfo.user.cloakedhost}')
|
||||||
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :HOSTNAME : {UserInfo.hostname}')
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :HOSTNAME : {UserInfo.hostname}')
|
||||||
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :VHOST : {UserInfo.vhost}')
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :VHOST : {UserInfo.user.vhost}')
|
||||||
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :CLIENT PORT : {UserInfo.client_port}')
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :CLIENT PORT : {UserInfo.client_port}')
|
||||||
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :SERVER PORT : {UserInfo.server_port}')
|
self.Irc.send2socket(f':{dnickname} NOTICE {fromuser} :SERVER PORT : {UserInfo.server_port}')
|
||||||
|
|
||||||
|
|||||||
@@ -124,8 +124,16 @@ class Test():
|
|||||||
return None
|
return None
|
||||||
|
|
||||||
def cmd(self, data:list) -> None:
|
def cmd(self, data:list) -> None:
|
||||||
|
try:
|
||||||
|
cmd = list(data).copy()
|
||||||
|
|
||||||
return None
|
return None
|
||||||
|
except KeyError as ke:
|
||||||
|
self.Base.logs.error(f"Key Error: {ke}")
|
||||||
|
except IndexError as ie:
|
||||||
|
self.Base.logs.error(f"{ie} / {cmd} / length {str(len(cmd))}")
|
||||||
|
except Exception as err:
|
||||||
|
self.Base.logs.error(f"General Error: {err}")
|
||||||
|
|
||||||
def _hcmds(self, user:str, channel: any, cmd: list, fullcmd: list = []) -> None:
|
def _hcmds(self, user:str, channel: any, cmd: list, fullcmd: list = []) -> None:
|
||||||
|
|
||||||
|
|||||||
@@ -242,16 +242,17 @@ class Votekick():
|
|||||||
return None
|
return None
|
||||||
|
|
||||||
def cmd(self, data:list) -> None:
|
def cmd(self, data:list) -> None:
|
||||||
|
try:
|
||||||
cmd = list(data).copy()
|
cmd = list(data).copy()
|
||||||
|
|
||||||
match cmd[2]:
|
|
||||||
case 'SJOIN':
|
|
||||||
pass
|
|
||||||
case _:
|
|
||||||
pass
|
|
||||||
|
|
||||||
return None
|
return None
|
||||||
|
|
||||||
|
except KeyError as ke:
|
||||||
|
self.Base.logs.error(f"Key Error: {ke}")
|
||||||
|
except IndexError as ie:
|
||||||
|
self.Base.logs.error(f"{ie} / {cmd} / length {str(len(cmd))}")
|
||||||
|
except Exception as err:
|
||||||
|
self.Base.logs.error(f"General Error: {err}")
|
||||||
|
|
||||||
def _hcmds(self, user:str, channel: any, cmd: list, fullcmd: list = []) -> None:
|
def _hcmds(self, user:str, channel: any, cmd: list, fullcmd: list = []) -> None:
|
||||||
# cmd is the command starting from the user command
|
# cmd is the command starting from the user command
|
||||||
# full cmd is sending the entire server response
|
# full cmd is sending the entire server response
|
||||||
|
|||||||
@@ -1,3 +1,3 @@
|
|||||||
{
|
{
|
||||||
"version": "5.3.2"
|
"version": "5.3.6"
|
||||||
}
|
}
|
||||||
Reference in New Issue
Block a user