This commit is contained in:
parent
7f42363072
commit
7794ed874a
1 changed files with 39 additions and 5 deletions
|
@ -1,7 +1,7 @@
|
||||||
# Replacement for services bots.
|
# Replacement for services bots.
|
||||||
import traceback
|
import traceback, smtplib, uuid
|
||||||
__ircat_type__ = "command"
|
__ircat_type__ = "command"
|
||||||
__ircat_requires__ = []
|
__ircat_requires__ = ["name", "smtp_host", "smtp_port", "smtp_starttls", "smtp_username", "smtp_password"]
|
||||||
__ircat_giveme__ = ["sql"] # Only command and allsocket have these.
|
__ircat_giveme__ = ["sql"] # Only command and allsocket have these.
|
||||||
__ircat_fakeusers__ = {
|
__ircat_fakeusers__ = {
|
||||||
"NickServ": {
|
"NickServ": {
|
||||||
|
@ -19,8 +19,15 @@ __ircat_fakeusers__ = {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
class IRCatModule:
|
class IRCatModule:
|
||||||
def __init__(self, sql):
|
def __init__(self, sql, smtp_host, smtp_port, smtp_starttls, smtp_username, smtp_password, name):
|
||||||
self.sql = sql
|
self.sql = sql
|
||||||
|
self.smtp_host = smtp_host
|
||||||
|
self.smtp_port = smtp_port
|
||||||
|
self.smtp_starttls = smtp_starttls
|
||||||
|
self.smtp_username = smtp_username
|
||||||
|
self.smtp_password = smtp_password
|
||||||
|
self.net_name = name
|
||||||
|
self.memory = {} # {nick: [authtoken, password, email]}
|
||||||
print("PawServ loaded!")
|
print("PawServ loaded!")
|
||||||
def command(self, command, args, ip, nick, connection, user):
|
def command(self, command, args, ip, nick, connection, user):
|
||||||
try:
|
try:
|
||||||
|
@ -28,15 +35,42 @@ class IRCatModule:
|
||||||
if command == "PRIVMSG":
|
if command == "PRIVMSG":
|
||||||
args = args[1:]
|
args = args[1:]
|
||||||
args[0] = args[0][1:] if args[0][0] == ":" else args[0]
|
args[0] = args[0][1:] if args[0][0] == ":" else args[0]
|
||||||
|
if len(args) > 0 and args[0].lower() == "verify":
|
||||||
|
if len(args) == 3:
|
||||||
|
if args[1] in self.memory:
|
||||||
|
if args[2] == self.memory[args[1]][0]:
|
||||||
|
self.sql.nickserv_register(nick=args[1], password=self.memory[args[1]][1], email=self.memory[args[1]][2])
|
||||||
|
else:
|
||||||
|
connection.sendall(bytes(f":NickServ!Meow@PawServ NOTICE {nick} :Nickname doesn't exist, try registering again?\r\n", "UTF-8"))
|
||||||
|
else:
|
||||||
|
connection.sendall(bytes(f":NickServ!Meow@PawServ NOTICE {nick} :Invalid verification.\r\n", "UTF-8"))
|
||||||
|
if len(args) > 0 and args[0].lower() == "register":
|
||||||
|
if len(args) == 3:
|
||||||
|
context = ssl.create_default_context()
|
||||||
|
token = str(uuid.uuid4())
|
||||||
|
message = f"\\nSubject: {self.net_name} Account Verification\n\nHi,\nIt appears you have tried to register an account ({nick}) with this email,\nIf you did not register an account, feel free to delete this email.\nIf you did, use this command:\n/nickserv verify {nick} {token}"
|
||||||
|
with smtplib.SMTP(self.smtp_server, self.smtp_port) as server:
|
||||||
|
server.ehlo()
|
||||||
|
server.starttls(context=context)
|
||||||
|
server.ehlo()
|
||||||
|
server.login(self.smtp_username, self.smtp_password)
|
||||||
|
server.sendmail(self.smtp_username, args[2], message)
|
||||||
|
memory[nick] = [token, args[1], args[2]]
|
||||||
|
else:
|
||||||
|
connection.sendall(bytes(f":NickServ!Meow@PawServ NOTICE {nick} :Needs 3 arguments, nickname, password, and email.\r\n", "UTF-8"))
|
||||||
if len(args) > 0 and args[0].lower() == "identify":
|
if len(args) > 0 and args[0].lower() == "identify":
|
||||||
temp = self.sql.nickserv_identify(nick=nick if len(args) == 2 else args[2], password=args[1])
|
temp = self.sql.nickserv_identify(nick=nick if len(args) == 2 else args[2], password=args[1])
|
||||||
if temp:
|
if temp:
|
||||||
pass
|
connection.sendall(bytes(f":NickServ!Meow@PawServ NOTICE {nick} :Now, it would've been a successful identification, but this is work in progress.\r\n", "UTF-8"))
|
||||||
else:
|
else:
|
||||||
connection.sendall(bytes(f":NickServ!Meow@PawServ NOTICE {nick} :Invalid username/password.\r\n", "UTF-8"))
|
if nick in self.memory:
|
||||||
|
connection.sendall(bytes(f":NickServ!Meow@PawServ NOTICE {nick} :Your account isn't verified, please verify now.\r\n", "UTF-8"))
|
||||||
|
else:
|
||||||
|
connection.sendall(bytes(f":NickServ!Meow@PawServ NOTICE {nick} :Invalid username/password.\r\n", "UTF-8"))
|
||||||
else:
|
else:
|
||||||
connection.sendall(bytes(f":NickServ!Meow@PawServ NOTICE {nick} :NickServ Usage:\r\n","UTF-8"))
|
connection.sendall(bytes(f":NickServ!Meow@PawServ NOTICE {nick} :NickServ Usage:\r\n","UTF-8"))
|
||||||
connection.sendall(bytes(f":NickServ!Meow@PawServ NOTICE {nick} :IDENTIFY pass <nick> - Identifies your nickname\r\n","UTF-8"))
|
connection.sendall(bytes(f":NickServ!Meow@PawServ NOTICE {nick} :IDENTIFY pass <nick> - Identifies your nickname\r\n","UTF-8"))
|
||||||
|
connection.sendall(bytes(f":NickServ!Meow@PawServ NOTICE {nick} :REGISTER pass email - Register your nickname\r\n","UTF-8"))
|
||||||
return True
|
return True
|
||||||
else:
|
else:
|
||||||
return False
|
return False
|
||||||
|
|
Loading…
Add table
Reference in a new issue