Mercurial > hg > Feedworm
view backend/sqlalchemy/Feed.py @ 180:a4832a180c69
allow setting the URL to the database via command line
author | dirk |
---|---|
date | Sat, 10 Sep 2011 04:43:40 +0200 |
parents | a3c945ce434c |
children | 7157bfd3f4d4 |
line wrap: on
line source
from datetime import datetime, timedelta import FeedEntry class Feed(object): @staticmethod def all(session): return session.query(Feed).order_by(Feed.title).all() def __init__(self, rss_url, title=None): self.rss_url = rss_url self.title = title # default: update every 60 minutes self.update_interval = 60 self.incrementNextUpdateDate() self.auto_load_entry_link = False self.always_open_in_browser = False def __repr__(self): return "<Feed (%d) %s>" % (self.pk, self.title) def userPresentableString(self): return self.title def entriesSortedByUpdateDate(self, hideReadEntries=False): if hideReadEntries: sortedEntries = self._unreadEntries() else: sortedEntries = list(self.entries) sortedEntries.sort(FeedEntry.compareByUpdateDate) return sortedEntries def _unreadEntries(self): retValue = [] for entry in self.entries: if not entry.read: retValue.append(entry) return retValue def incrementNextUpdateDate(self): delta = timedelta(minutes=self.update_interval) self.next_update = datetime.now() + delta def markAllEntriesRead(self): for entry in self.entries: entry.markRead() def takeChangesFrom(self, changes): for key in changes.keys(): setattr(self, key, changes[key])