From 35f2fe63df4473e2aa8e8f82dd3f95a1ef7fc413 Mon Sep 17 00:00:00 2001 From: Tulir Asokan Date: Sat, 30 Apr 2022 21:14:19 +0300 Subject: [PATCH] Add support for old SQLites Closes #31 --- rss/db.py | 22 ++++++++++++++++++---- 1 file changed, 18 insertions(+), 4 deletions(-) diff --git a/rss/db.py b/rss/db.py index 69c930c..c7cea64 100644 --- a/rss/db.py +++ b/rss/db.py @@ -23,7 +23,7 @@ from attr import dataclass import attr from mautrix.types import RoomID, UserID -from mautrix.util.async_db import Database, Scheme +from mautrix.util.async_db import Database, Scheme, SQLiteCursor @dataclass @@ -182,9 +182,23 @@ class DBManager: "INSERT INTO feed (url, title, subtitle, link, next_retry) " "VALUES ($1, $2, $3, $4, $5) RETURNING (id)" ) - info.id = await self.db.fetchval( - q, info.url, info.title, info.subtitle, info.link, info.next_retry - ) + # SQLite only gained RETURNING support in v3.35 (2021-03-12) + # TODO remove this special case in a couple of years + if self.db.scheme == Scheme.SQLITE: + cur = await self.db.execute( + q.replace(" RETURNING (id)", ""), + info.url, + info.title, + info.subtitle, + info.link, + info.next_retry, + ) + assert isinstance(cur, SQLiteCursor) + info.id = cur.lastrowid + else: + info.id = await self.db.fetchval( + q, info.url, info.title, info.subtitle, info.link, info.next_retry + ) return info async def set_backoff(self, info: Feed, error_count: int, next_retry: int) -> None: