Compare commits
No commits in common. "af5cd6b741010b6578c4cb437936f3b3bcac1067" and "badeccca0def95457a38d731c564df71285117c8" have entirely different histories.
af5cd6b741
...
badeccca0d
1 changed files with 5 additions and 40 deletions
45
server.py
45
server.py
|
@ -79,10 +79,7 @@ def session(connection, client):
|
||||||
if command == "NICK":
|
if command == "NICK":
|
||||||
pending = text.split(" ")[1]
|
pending = text.split(" ")[1]
|
||||||
if pending[0] == ":": pending[1:]
|
if pending[0] == ":": pending[1:]
|
||||||
if "!" in pending or ":" in pending or "#" in pending or "*" in pending:
|
if pending.lower() in lower_nicks or pending in reserved:
|
||||||
connection.sendall(bytes(f":{server} 432 * {pending} :Erroneus nickname\r\n","UTF-8"))
|
|
||||||
pending = "*"
|
|
||||||
elif pending.lower() in lower_nicks or pending in reserved:
|
|
||||||
connection.sendall(bytes(f":{server} 433 * {pending} :Nickname is already in use.\r\n","UTF-8"))
|
connection.sendall(bytes(f":{server} 433 * {pending} :Nickname is already in use.\r\n","UTF-8"))
|
||||||
pending = "*"
|
pending = "*"
|
||||||
else:
|
else:
|
||||||
|
@ -192,16 +189,10 @@ def session(connection, client):
|
||||||
who_user = property_list[target]["username"]
|
who_user = property_list[target]["username"]
|
||||||
who_realname = property_list[target]["realname"]
|
who_realname = property_list[target]["realname"]
|
||||||
who_host = property_list[target]["host"]
|
who_host = property_list[target]["host"]
|
||||||
try:
|
|
||||||
who_flags = property_list[target]["modes"]
|
|
||||||
except:
|
|
||||||
who_flags = None
|
|
||||||
connection.sendall(bytes(f":{server} 311 {pending} {target} ~{who_user} {who_host} * :{who_realname}\r\n","UTF-8"))
|
connection.sendall(bytes(f":{server} 311 {pending} {target} ~{who_user} {who_host} * :{who_realname}\r\n","UTF-8"))
|
||||||
connection.sendall(bytes(f":{server} 312 {pending} {target} {server} :{identifier}\r\n","UTF-8"))
|
connection.sendall(bytes(f":{server} 312 {pending} {target} {server} :{identifier}\r\n","UTF-8"))
|
||||||
#connection.sendall(bytes(f":{server} 313 {target} :is an IRC operator\r\n","UTF-8")) # I haven't implemented modes yet.
|
#connection.sendall(bytes(f":{server} 313 {target} :is an IRC operator\r\n","UTF-8")) # I haven't implemented modes yet.
|
||||||
#connection.sendall(bytes(f":{server} 317 {target} {time} :seconds idle\r\n","UTF-8")) # I haven't implemented idle time yet.
|
#connection.sendall(bytes(f":{server} 317 {target} {time} :seconds idle\r\n","UTF-8")) # I haven't implemented idle time yet.
|
||||||
if who_flags != None and who_flags != "iw":
|
|
||||||
connection.sendall(bytes(f":{server} 379 {pending} {target} :Is using modes +{who_flags}\r\n","UTF-8"))
|
|
||||||
connection.sendall(bytes(f":{server} 318 {pending} {target} :End of /WHOIS list\r\n","UTF-8"))
|
connection.sendall(bytes(f":{server} 318 {pending} {target} :End of /WHOIS list\r\n","UTF-8"))
|
||||||
else:
|
else:
|
||||||
connection.sendall(bytes(f":{server} 401 {pending} {target} :No such nick/channel\r\n","UTF-8"))
|
connection.sendall(bytes(f":{server} 401 {pending} {target} :No such nick/channel\r\n","UTF-8"))
|
||||||
|
@ -279,37 +270,11 @@ def session(connection, client):
|
||||||
try:
|
try:
|
||||||
connection.sendall(bytes(f":{pending}!~{username}@{hostname} {text}\r\n","UTF-8"))
|
connection.sendall(bytes(f":{pending}!~{username}@{hostname} {text}\r\n","UTF-8"))
|
||||||
connection.sendall(bytes(f"ERROR :Closing Link: {hostname} ({msg})\r\n","UTF-8"))
|
connection.sendall(bytes(f"ERROR :Closing Link: {hostname} ({msg})\r\n","UTF-8"))
|
||||||
finally:
|
except:
|
||||||
connection.close()
|
|
||||||
safe_quit = True
|
|
||||||
break
|
break
|
||||||
elif command == "MODE":
|
connection.close()
|
||||||
if len(args) == 0:
|
safe_quit = True
|
||||||
connection.sendall(bytes(f":{server} {pending} 461 {command} :Not enough parameters\r\n","UTF-8"))
|
break
|
||||||
elif len(args) == 1:
|
|
||||||
if args[0] == pending:
|
|
||||||
yourmodes = property_list[pending]["modes"]
|
|
||||||
connection.sendall(bytes(f":{server} {pending} 221 +{yourmodes}\r\n","UTF-8"))
|
|
||||||
elif args[0] in channels_list:
|
|
||||||
target = args[0]
|
|
||||||
if args[0] in property_list:
|
|
||||||
if "modes" in property_list[args[0]]:
|
|
||||||
# Get the modes + parameters, then print them out.
|
|
||||||
modes = property_list[args[0]]["modes"]
|
|
||||||
params = property_list[args[0]]["params"]
|
|
||||||
connection.sendall(bytes(f":{server} {pending} {target} +{modes} {params}\r\n","UTF-8"))
|
|
||||||
else:
|
|
||||||
# Default channel mode
|
|
||||||
connection.sendall(bytes(f":{server} {pending} {target} +n\r\n","UTF-8"))
|
|
||||||
else:
|
|
||||||
# Default channel mode
|
|
||||||
connection.sendall(bytes(f":{server} {pending} {target} +n\r\n","UTF-8"))
|
|
||||||
else:
|
|
||||||
if args[0][0] == "#":
|
|
||||||
connection.sendall(bytes(f":{server} 403 {pending} {target} :No such channel\r\n","UTF-8"))
|
|
||||||
else:
|
|
||||||
connection.sendall(bytes(f":{server} {pending} 505 :Cant change mode for other users\r\n","UTF-8"))
|
|
||||||
|
|
||||||
elif command == "GITSERV":
|
elif command == "GITSERV":
|
||||||
if len(args) == 0:
|
if len(args) == 0:
|
||||||
connection.sendall(bytes(f":{server} {pending} 461 {command} :Not enough parameters\r\n","UTF-8"))
|
connection.sendall(bytes(f":{server} {pending} 461 {command} :Not enough parameters\r\n","UTF-8"))
|
||||||
|
|
Loading…
Reference in a new issue