Changed a few SQL statements and added oldnotes command.

This commit is contained in:
Jeremy Fincher 2003-04-19 21:40:04 +00:00
parent ab7fd51ddd
commit 747d48c7ab

View File

@ -176,12 +176,18 @@ class Notes(callbacks.Privmsg):
Retrieves a single note by unique note id. Retrieves a single note by unique note id.
""" """
noteid = privmsgs.getArgs(args) noteid = privmsgs.getArgs(args)
sender = ircdb.users.getUserName(msg.prefix) try:
senderID = self.getUserID(sender) sender = ircdb.users.getUserName(msg.prefix)
self.cursor.execute("""SELECT note, to_id, from_id, added_at, public except KeyError:
FROM notes irc.error(msg, conf.replyNoUser)
WHERE id=%s return
LIMIT 1""", noteid) self.cursor.execute("""SELECT notes.note, notes.from_id,
notes.added_at, notes.public
FROM users, notes
WHERE users.name=%s AND
notes.to_id=users.id AND
notes.id=%s
LIMIT 1""", sender, noteid)
if self.cursor.rowcount == 0: if self.cursor.rowcount == 0:
irc.error(msg, 'That\'s not a valid note id.') irc.error(msg, 'That\'s not a valid note id.')
return return
@ -200,19 +206,21 @@ class Notes(callbacks.Privmsg):
self.setAsRead(noteid) self.setAsRead(noteid)
def notes(self, irc, msg, args): def notes(self, irc, msg, args):
"""<takes no arguments> """takes no arguments
Retrieves all unread notes for the requesting user. Retrieves all your unread notes.
""" """
try: try:
sender = ircdb.users.getUserName(msg.prefix) sender = ircdb.users.getUserName(msg.prefix)
except KeyError: except KeyError:
irc.error(msg, conf.replyNoUser) irc.error(msg, conf.replyNoUser)
return return
senderID = self.getUserID(sender) self.cursor.execute("""SELECT notes.id, notes.from_id,
self.cursor.execute("""SELECT id, from_id, public, read FROM notes notes.public, notes.read
WHERE to_id=%s FROM users, notes
AND read=0""", senderID) WHERE users.name=%s AND
notes.to_id=users.id AND
notes.read=0""", sender)
count = self.cursor.rowcount count = self.cursor.rowcount
notes = self.cursor.fetchall() notes = self.cursor.fetchall()
L = [] L = []
@ -234,6 +242,31 @@ class Notes(callbacks.Privmsg):
shrinkList(L, ', ', 450) shrinkList(L, ', ', 450)
irc.reply(msg, ', '.join(L)) irc.reply(msg, ', '.join(L))
def oldnotes(self, irc, msg, args):
"""takes no arguments
Returns a list of your most recent old notes.
"""
try:
sender = ircdb.users.getUserName(msg.prefix)
except KeyError:
irc.error(msg, conf.replyNoUser)
return
cursor = self.db.cursor()
cursor.execute("""SELECT notes.id FROM users, notes
WHERE notes.to_id=users.id AND
users.name=%s AND
notes.read=1""", sender)
if cursor.rowcount == 0:
irc.reply(msg, 'I could find no notes for your user.')
else:
ids = [str(t[0]) for t in cursor.fetchall()]
ids.reverse()
utils.shrinkList(ids, ', ', 425)
ids.reverse()
irc.reply(msg, ', '.join(ids))
Class = Notes Class = Notes