def query(self): if self.where == "messages": q = queries.get_inbox_messages(c.user) elif self.where == "comments": q = queries.get_inbox_comments(c.user) elif self.where == "selfreply": q = queries.get_inbox_selfreply(c.user) elif self.where == "inbox": q = queries.get_inbox(c.user) elif self.where == "unread": q = queries.get_unread_inbox(c.user) elif self.where == "sent": q = queries.get_sent(c.user) elif self.where == "moderator" and self.subwhere == "unread": if c.default_sr: srids = Subreddit.reverse_moderator_ids(c.user) srs = Subreddit._byID(srids, data=False, return_dict=False) q = queries.merge_results(*[queries.get_unread_subreddit_messages(s) for s in srs]) else: q = queries.get_unread_subreddit_messages(c.site) elif self.where == "moderator": if c.have_mod_messages and self.mark != "false": c.user.modmsgtime = False c.user._commit() # the query is handled by the builder on the moderator page return else: return self.abort404() if self.where != "sent": # reset the inbox if c.have_messages and self.mark != "false": c.user.msgtime = False c.user._commit() return q
def query(self): if self.where == 'messages': q = queries.get_inbox_messages(c.user) elif self.where == 'comments': q = queries.get_inbox_comments(c.user) elif self.where == 'selfreply': q = queries.get_inbox_selfreply(c.user) elif self.where == 'inbox': q = queries.get_inbox(c.user) elif self.where == 'unread': q = queries.get_unread_inbox(c.user) elif self.where == 'sent': q = queries.get_sent(c.user) elif self.where == 'multi' and self.subwhere == 'unread': q = queries.get_unread_subreddit_messages_multi(c.site.kept_sr_ids) elif self.where == 'moderator' and self.subwhere == 'unread': if c.default_sr: srids = Subreddit.reverse_moderator_ids(c.user) srs = [sr for sr in Subreddit._byID(srids, data=False, return_dict=False) if sr.is_moderator_with_perms(c.user, 'mail')] q = queries.get_unread_subreddit_messages_multi(srs) else: q = queries.get_unread_subreddit_messages(c.site) elif self.where in ('moderator', 'multi'): if self.mark != 'false': c.user.clear_moderator_message_count() # the query is handled by the builder on the moderator page return elif self.where == 'notifications': if self.mark != 'false': c.user.clear_notification_count() q = queries.get_unread_notifications(c.user) elif self.where == 'reset_message_counts': g.log.debug("resetting message count") c.user.message_count = 2 c.user.moderator_message_count = 1 c.user.notification_count = 7 c.user._commit() q = queries.get_inbox(c.user) else: return self.abort404() # Clear the message count under most circumstances... if self.where not in ('sent', 'reset_message_counts', 'notifications'): if self.mark != 'false': c.user.clear_message_count() return q
def query(self): if self.where == 'messages': q = queries.get_inbox_messages(c.user) elif self.where == 'comments': q = queries.get_inbox_comments(c.user) elif self.where == 'selfreply': q = queries.get_inbox_selfreply(c.user) elif self.where == 'mentions': q = queries.get_inbox_comment_mentions(c.user) elif self.where == 'inbox': q = queries.get_inbox(c.user) elif self.where == 'unread': q = queries.get_unread_inbox(c.user) elif self.where == 'sent': q = queries.get_sent(c.user) elif self.where == 'multi' and self.subwhere == 'unread': q = queries.get_unread_subreddit_messages_multi(c.site.kept_sr_ids) elif self.where == 'moderator' and self.subwhere == 'unread': if c.default_sr: srids = Subreddit.reverse_moderator_ids(c.user) srs = [ sr for sr in Subreddit._byID( srids, data=False, return_dict=False) if sr.is_moderator_with_perms(c.user, 'mail') ] q = queries.get_unread_subreddit_messages_multi(srs) else: q = queries.get_unread_subreddit_messages(c.site) elif self.where in ('moderator', 'multi'): if c.have_mod_messages and self.mark != 'false': c.have_mod_messages = False c.user.modmsgtime = False c.user._commit() # the query is handled by the builder on the moderator page return else: return self.abort404() if self.where != 'sent': #reset the inbox if c.have_messages and self.mark != 'false': c.have_messages = False c.user.msgtime = False c.user._commit() return q
def query(self): if self.where == "messages": q = queries.get_inbox_messages(c.user) elif self.where == "comments": q = queries.get_inbox_comments(c.user) elif self.where == "selfreply": q = queries.get_inbox_selfreply(c.user) elif self.where == "mentions": q = queries.get_inbox_comment_mentions(c.user) elif self.where == "inbox": q = queries.get_inbox(c.user) elif self.where == "unread": q = queries.get_unread_inbox(c.user) elif self.where == "sent": q = queries.get_sent(c.user) elif self.where == "multi" and self.subwhere == "unread": q = queries.get_unread_subreddit_messages_multi(c.site.kept_sr_ids) elif self.where == "moderator" and self.subwhere == "unread": if c.default_sr: srids = Subreddit.reverse_moderator_ids(c.user) srs = [ sr for sr in Subreddit._byID(srids, data=False, return_dict=False) if sr.is_moderator_with_perms(c.user, "mail") ] q = queries.get_unread_subreddit_messages_multi(srs) else: q = queries.get_unread_subreddit_messages(c.site) elif self.where in ("moderator", "multi"): if c.have_mod_messages and self.mark != "false": c.have_mod_messages = False c.user.modmsgtime = False c.user._commit() # the query is handled by the builder on the moderator page return else: return self.abort404() if self.where != "sent": # reset the inbox if c.have_messages and self.mark != "false": c.have_messages = False c.user.msgtime = False c.user._commit() return q
def query(self): if self.where == 'messages': q = queries.get_inbox_messages(c.user) elif self.where == 'comments': q = queries.get_inbox_comments(c.user) elif self.where == 'selfreply': q = queries.get_inbox_selfreply(c.user) elif self.where == 'mentions': q = queries.get_inbox_comment_mentions(c.user) elif self.where == 'inbox': q = queries.get_inbox(c.user) elif self.where == 'unread': q = queries.get_unread_inbox(c.user) elif self.where == 'sent': q = queries.get_sent(c.user) elif self.where == 'multi' and self.subwhere == 'unread': q = queries.get_unread_subreddit_messages_multi(c.site.kept_sr_ids) elif self.where == 'moderator' and self.subwhere == 'unread': if c.default_sr: srids = Subreddit.reverse_moderator_ids(c.user) srs = [sr for sr in Subreddit._byID(srids, data=False, return_dict=False) if sr.is_moderator_with_perms(c.user, 'mail')] q = queries.get_unread_subreddit_messages_multi(srs) else: q = queries.get_unread_subreddit_messages(c.site) elif self.where in ('moderator', 'multi'): if c.have_mod_messages and self.mark != 'false': c.have_mod_messages = False c.user.modmsgtime = False c.user._commit() # the query is handled by the builder on the moderator page return else: return self.abort404() if self.where != 'sent': #reset the inbox if c.have_messages and self.mark != 'false': c.have_messages = False c.user.msgtime = False c.user._commit() return q
def query(self): if self.where == 'messages': q = queries.get_inbox_messages(c.user) elif self.where == 'comments': q = queries.get_inbox_comments(c.user) elif self.where == 'selfreply': q = queries.get_inbox_selfreply(c.user) elif self.where == 'inbox': q = queries.get_inbox(c.user) elif self.where == 'unread': q = queries.get_unread_inbox(c.user) elif self.where == 'sent': q = queries.get_sent(c.user) elif self.where == 'multi' and self.subwhere == 'unread': q = queries.merge_results( *[queries.get_unread_subreddit_messages(s) for s in self.srs]) elif self.where == 'moderator' and self.subwhere == 'unread': if c.default_sr: srids = Subreddit.reverse_moderator_ids(c.user) srs = Subreddit._byID(srids, data=False, return_dict=False) q = queries.merge_results( *[queries.get_unread_subreddit_messages(s) for s in srs]) else: q = queries.get_unread_subreddit_messages(c.site) elif self.where in ('moderator', 'multi'): if c.have_mod_messages and self.mark != 'false': c.user.modmsgtime = False c.user._commit() # the query is handled by the builder on the moderator page return else: return self.abort404() if self.where != 'sent': #reset the inbox if c.have_messages and self.mark != 'false': c.user.msgtime = False c.user._commit() return q
def query(self): if self.where == 'messages': q = queries.get_inbox_messages(c.user) elif self.where == 'comments': q = queries.get_inbox_comments(c.user) elif self.where == 'selfreply': q = queries.get_inbox_selfreply(c.user) elif self.where == 'inbox': q = queries.get_inbox(c.user) elif self.where == 'unread': q = queries.get_unread_inbox(c.user) elif self.where == 'sent': q = queries.get_sent(c.user) elif self.where == 'multi' and self.subwhere == 'unread': q = queries.merge_results(*[queries.get_unread_subreddit_messages(s) for s in self.srs]) elif self.where == 'moderator' and self.subwhere == 'unread': if c.default_sr: srids = Subreddit.reverse_moderator_ids(c.user) srs = Subreddit._byID(srids, data = False, return_dict = False) q = queries.merge_results( *[queries.get_unread_subreddit_messages(s) for s in srs]) else: q = queries.get_unread_subreddit_messages(c.site) elif self.where in ('moderator', 'multi'): if c.have_mod_messages and self.mark != 'false': c.user.modmsgtime = False c.user._commit() # the query is handled by the builder on the moderator page return else: return self.abort404() if self.where != 'sent': #reset the inbox if c.have_messages and self.mark != 'false': c.user.msgtime = False c.user._commit() return q
def add_props(cls, user, wrapped): from r2.lib.db import queries #TODO global-ish functions that shouldn't be here? #reset msgtime after this request msgtime = c.have_messages # make sure there is a sr_id set: for w in wrapped: if not hasattr(w, "sr_id"): w.sr_id = None # load the to fields if one exists to_ids = set(w.to_id for w in wrapped if w.to_id is not None) tos = Account._byID(to_ids, True) if to_ids else {} # load the subreddit field if one exists: sr_ids = set(w.sr_id for w in wrapped if w.sr_id is not None) m_subreddits = Subreddit._byID(sr_ids, data=True, return_dict=True) # load the links and their subreddits (if comment-as-message) links = Link._byID( set(l.link_id for l in wrapped if l.was_comment), data=True, return_dict=True) # subreddits of the links (for comment-as-message) l_subreddits = Subreddit._byID( set(l.sr_id for l in links.values()), data=True, return_dict=True) parents = Comment._byID( set(l.parent_id for l in wrapped if l.parent_id and l.was_comment), data=True, return_dict=True) # load the unread list to determine message newness unread = set(queries.get_unread_inbox(user)) msg_srs = set( m_subreddits[x.sr_id] for x in wrapped if x.sr_id is not None and isinstance(x.lookups[0], Message)) # load the unread mod list for the same reason mod_unread = set( queries.merge_results( *[queries.get_unread_subreddit_messages(sr) for sr in msg_srs])) for item in wrapped: item.to = tos.get(item.to_id) if item.sr_id: item.recipient = (item.author_id != c.user._id) else: item.recipient = (item.to_id == c.user._id) # new-ness is stored on the relation if item.author_id == c.user._id: item.new = False elif item._fullname in unread: item.new = True # wipe new messages if preferences say so, and this isn't a feed # and it is in the user's personal inbox if (item.new and c.user.pref_mark_messages_read and c.extension not in ("rss", "xml", "api", "json")): queries.set_unread(item.lookups[0], c.user, False) else: item.new = (item._fullname in mod_unread) item.score_fmt = Score.none item.message_style = "" # comment as message: if item.was_comment: link = links[item.link_id] sr = l_subreddits[link.sr_id] item.to_collapse = False item.author_collapse = False item.link_title = link.title item.permalink = item.lookups[0].make_permalink(link, sr=sr) item.link_permalink = link.make_permalink(sr) if item.parent_id: item.subject = _('comment reply') item.message_style = "comment-reply" parent = parents[item.parent_id] item.parent = parent._fullname item.parent_permalink = parent.make_permalink(link, sr) else: item.subject = _('post reply') item.message_style = "post-reply" elif item.sr_id is not None: item.subreddit = m_subreddits[item.sr_id] if c.user.pref_no_profanity: item.subject = profanity_filter(item.subject) item.is_collapsed = None if not item.new: if item.recipient: item.is_collapsed = item.to_collapse if item.author_id == c.user._id: item.is_collapsed = item.author_collapse if c.user.pref_collapse_read_messages: item.is_collapsed = (item.is_collapsed is not False) # Run this last Printable.add_props(user, wrapped)
# don't show user their own unread stuff if msg.author_id == account._id: return False return True resume_id = long(sys.argv[1]) if len(sys.argv) > 1 else None msg_accounts = Account._query(sort=desc("_date"), data=True) if resume_id: msg_accounts._filter(Account.c._id < resume_id) for account in progress(fetch_things2(msg_accounts), estimate=resume_id): current_inbox_count = account.inbox_count unread_messages = list(queries.get_unread_inbox(account)) if account._id % 100000 == 0: g.reset_caches() if not len(unread_messages): if current_inbox_count: account._incr('inbox_count', -current_inbox_count) else: msgs = Message._by_fullname( unread_messages, data=True, return_dict=False, ignore_missing=True, ) kept_msgs = sum(1 for msg in msgs if _keep(msg, account))
def add_props(cls, user, wrapped): from r2.lib.db import queries #TODO global-ish functions that shouldn't be here? #reset msgtime after this request msgtime = c.have_messages # make sure there is a sr_id set: for w in wrapped: if not hasattr(w, "sr_id"): w.sr_id = None # load the to fields if one exists to_ids = set(w.to_id for w in wrapped if w.to_id is not None) tos = Account._byID(to_ids, True) if to_ids else {} # load the subreddit field if one exists: sr_ids = set(w.sr_id for w in wrapped if w.sr_id is not None) m_subreddits = Subreddit._byID(sr_ids, data = True, return_dict = True) # load the links and their subreddits (if comment-as-message) links = Link._byID(set(l.link_id for l in wrapped if l.was_comment), data = True, return_dict = True) # subreddits of the links (for comment-as-message) l_subreddits = Subreddit._byID(set(l.sr_id for l in links.values()), data = True, return_dict = True) parents = Comment._byID(set(l.parent_id for l in wrapped if l.parent_id and l.was_comment), data = True, return_dict = True) # load the unread list to determine message newness unread = set(queries.get_unread_inbox(user)) msg_srs = set(m_subreddits[x.sr_id] for x in wrapped if x.sr_id is not None and isinstance(x.lookups[0], Message)) # load the unread mod list for the same reason mod_unread = set(queries.get_unread_subreddit_messages_multi(msg_srs)) for item in wrapped: item.to = tos.get(item.to_id) if item.sr_id: item.recipient = (item.author_id != c.user._id) else: item.recipient = (item.to_id == c.user._id) # new-ness is stored on the relation if item.author_id == c.user._id: item.new = False elif item._fullname in unread: item.new = True # wipe new messages if preferences say so, and this isn't a feed # and it is in the user's personal inbox if (item.new and c.user.pref_mark_messages_read and c.extension not in ("rss", "xml", "api", "json")): queries.set_unread(item.lookups[0], c.user, False) else: item.new = (item._fullname in mod_unread and not item.to_id) item.score_fmt = Score.none item.message_style = "" # comment as message: if item.was_comment: link = links[item.link_id] sr = l_subreddits[link.sr_id] item.to_collapse = False item.author_collapse = False item.link_title = link.title item.permalink = item.lookups[0].make_permalink(link, sr=sr) item.link_permalink = link.make_permalink(sr) if item.parent_id: item.subject = _('comment reply') item.message_style = "comment-reply" parent = parents[item.parent_id] item.parent = parent._fullname item.parent_permalink = parent.make_permalink(link, sr) else: item.subject = _('post reply') item.message_style = "post-reply" elif item.sr_id is not None: item.subreddit = m_subreddits[item.sr_id] item.hide_author = False if getattr(item, "from_sr", False): if not (item.subreddit.is_moderator(c.user) or c.user_is_admin): item.author = item.subreddit item.hide_author = True item.is_collapsed = None if not item.new: if item.recipient: item.is_collapsed = item.to_collapse if item.author_id == c.user._id: item.is_collapsed = item.author_collapse if c.user.pref_collapse_read_messages: item.is_collapsed = (item.is_collapsed is not False) if item.author_id in c.user.enemies and not item.was_comment: item.is_collapsed = True if not c.user_is_admin: item.subject = _('[message from blocked user]') item.body = _('[unblock user to see this message]') taglinetext = '' if item.hide_author: taglinetext = _("subreddit message %(author)s sent %(when)s ago") elif item.author_id == c.user._id: taglinetext = _("to %(dest)s sent %(when)s ago") elif item.to_id == c.user._id or item.to_id is None: taglinetext = _("from %(author)s sent %(when)s ago") else: taglinetext = _("to %(dest)s from %(author)s sent %(when)s ago") item.taglinetext = taglinetext item.dest = item.to.name if item.to else "" if item.sr_id: if item.hide_author: item.updated_author = _("via %(subreddit)s") else: item.updated_author = _("%(author)s via %(subreddit)s") else: item.updated_author = '' # Run this last Printable.add_props(user, wrapped)
if msg.author_id == account._id: return False return True resume_id = long(sys.argv[1]) if len(sys.argv) > 1 else None msg_accounts = Account._query(sort=desc("_date"), data=True) if resume_id: msg_accounts._filter(Account.c._id < resume_id) for account in progress(fetch_things2(msg_accounts), estimate=resume_id): current_inbox_count = account.inbox_count unread_messages = list(queries.get_unread_inbox(account)) if account._id % 100000 == 0: g.reset_caches() if not len(unread_messages): if current_inbox_count: account._incr('inbox_count', -current_inbox_count) else: msgs = Message._by_fullname( unread_messages, data=True, return_dict=False, ignore_missing=True, ) kept_msgs = sum(1 for msg in msgs if _keep(msg, account))
def add_props(cls, user, wrapped): from r2.lib.db import queries #TODO global-ish functions that shouldn't be here? #reset msgtime after this request msgtime = c.have_messages # make sure there is a sr_id set: for w in wrapped: if not hasattr(w, "sr_id"): w.sr_id = None # load the to fields if one exists to_ids = set(w.to_id for w in wrapped if w.to_id is not None) tos = Account._byID(to_ids, True) if to_ids else {} # load the subreddit field if one exists: sr_ids = set(w.sr_id for w in wrapped if w.sr_id is not None) m_subreddits = Subreddit._byID(sr_ids, data=True, return_dict=True) # load the links and their subreddits (if comment-as-message) links = Link._byID(set(l.link_id for l in wrapped if l.was_comment), data=True, return_dict=True) # subreddits of the links (for comment-as-message) l_subreddits = Subreddit._byID(set(l.sr_id for l in links.values()), data=True, return_dict=True) parents = Comment._byID(set(l.parent_id for l in wrapped if l.parent_id and l.was_comment), data=True, return_dict=True) # load the unread list to determine message newness unread = set(queries.get_unread_inbox(user)) msg_srs = set( m_subreddits[x.sr_id] for x in wrapped if x.sr_id is not None and isinstance(x.lookups[0], Message)) # load the unread mod list for the same reason mod_unread = set( queries.merge_results( *[queries.get_unread_subreddit_messages(sr) for sr in msg_srs])) for item in wrapped: item.to = tos.get(item.to_id) if item.sr_id: item.recipient = (item.author_id != c.user._id) else: item.recipient = (item.to_id == c.user._id) # new-ness is stored on the relation if item.author_id == c.user._id: item.new = False elif item._fullname in unread: item.new = True # wipe new messages if preferences say so, and this isn't a feed # and it is in the user's personal inbox if (item.new and c.user.pref_mark_messages_read and c.extension not in ("rss", "xml", "api", "json")): queries.set_unread(item.lookups[0], c.user, False) else: item.new = (item._fullname in mod_unread) item.score_fmt = Score.none item.message_style = "" # comment as message: if item.was_comment: link = links[item.link_id] sr = l_subreddits[link.sr_id] item.to_collapse = False item.author_collapse = False item.link_title = link.title item.permalink = item.lookups[0].make_permalink(link, sr=sr) item.link_permalink = link.make_permalink(sr) if item.parent_id: item.subject = _('comment reply') item.message_style = "comment-reply" parent = parents[item.parent_id] item.parent = parent._fullname item.parent_permalink = parent.make_permalink(link, sr) else: item.subject = _('post reply') item.message_style = "post-reply" elif item.sr_id is not None: item.subreddit = m_subreddits[item.sr_id] item.is_collapsed = None if not item.new: if item.recipient: item.is_collapsed = item.to_collapse if item.author_id == c.user._id: item.is_collapsed = item.author_collapse if c.user.pref_collapse_read_messages: item.is_collapsed = (item.is_collapsed is not False) if item.author_id in c.user.enemies and not item.was_comment: item.is_collapsed = True if not c.user_is_admin: item.subject = _('[message from blocked user]') item.body = _('[unblock user to see this message]') # Run this last Printable.add_props(user, wrapped)