···
···
FEED_URI = 'at://did:plc:4nsduwlpivpuur4mqkbfvm6a/app.bsky.feed.generator/nz-interesting'
-
self.db_cnx = apsw.Connection('db/nz-interesting.db')
-
self.db_cnx.pragma('journal_mode', 'WAL')
-
self.db_cnx.pragma('wal_autocheckpoint', '0')
-
self.db_cnx.execute("""
-
create table if not exists posts (uri text, create_ts timestamp);
-
create index if not exists create_ts_idx on posts(create_ts);
-
self.logger = logging.getLogger('feeds.nz_interesting')
def process_commit(self, commit):
-
if commit['opType'] != 'c':
-
if commit['collection'] != 'app.bsky.feed.post':
-
record = commit.get('record')
-
embed = record.get('embed')
-
inner_record = embed.get('record')
-
if inner_record is None:
-
if inner_record.get('uri') == TARGET_QUOTE_URI:
-
self.transaction_begin(self.db_cnx)
-
self.logger.debug('found quote post of target, adding to feed')
-
uri = 'at://{repo}/app.bsky.feed.post/{rkey}'.format(
-
ts = self.safe_timestamp(record.get('createdAt')).timestamp()
-
'insert into posts (uri, create_ts) values (:uri, :ts)',
def commit_changes(self):
-
self.logger.debug('committing changes')
-
self.transaction_commit(self.db_cnx)
-
self.wal_checkpoint(self.db_cnx, 'RESTART')
-
def serve_feed(self, limit, offset, langs):
-
cur = self.db_cnx.execute(
-
'select uri from posts order by create_ts desc limit :limit offset :offset',
-
dict(limit=limit, offset=offset)
-
return [uri for (uri,) in cur]
-
def serve_feed_debug(self, limit, offset, langs):
-
query = 'select * from posts order by create_ts desc limit :limit offset :offset'
-
bindings = dict(limit=limit, offset=offset)
-
return apsw.ext.format_query_table(
-
self.db_cnx, query, bindings,
-
string_sanitize=2, text_width=9999, use_unicode=True