Close database connection when command is finished instead of waiting for GC

This commit is contained in:
2021-12-13 20:01:45 +01:00
parent 71e8769e75
commit 75a4a27dcd

View File

@ -1,4 +1,4 @@
from typing import Optional
from contextlib import closing
import typer
from dhooks import Webhook
@ -6,9 +6,8 @@ from reader import FeedExistsError, make_reader
from discord_rss_bot.settings import Settings
app = typer.Typer() # For CLI (https://typer.tiangolo.com/)
hook = Webhook(Settings.webhook_url) # For Webhooks (https://github.com/kyb3r/dhooks)
reader = make_reader(Settings.db_file) # For RSS (https://github.com/lemon24/reader)
app = typer.Typer()
hook = Webhook(Settings.webhook_url)
@app.command()
@ -20,71 +19,74 @@ def add(
Args:
feed_url (str): The url of the feed to add
notify_discord (bool): Whether to send a message to Discord when the feed is added
"""
try:
# Add the feed to the database
reader.add_feed(feed_url)
with closing(make_reader(Settings.db_file)) as reader:
try:
# Add the feed to the database
reader.add_feed(feed_url)
except FeedExistsError:
# If the feed already exists, print a message
typer.echo(f"{feed_url} already exists")
raise typer.Exit()
except FeedExistsError:
# If the feed already exists, print a message
typer.echo(f"{feed_url} already exists")
raise typer.Exit()
# Update the feeds
reader.update_feeds()
# Update the feeds
reader.update_feeds()
# Mark the feed as read
entries = reader.get_entries(feed=feed_url, read=False)
for entry in entries:
reader.mark_entry_as_read(entry)
# Mark the feed as read
entries = reader.get_entries(feed=feed_url, read=False)
for entry in entries:
reader.mark_entry_as_read(entry)
if notify_discord:
# Send a message to Discord
hook.send(
f"discord-rss-bot: {feed_url} added to the database.\nYou now have "
f"{reader.get_feed_counts()} feeds."
)
if notify_discord:
# Send a message to Discord
hook.send(
f"discord-rss-bot: {feed_url} added to the database.\nYou now have "
f"{reader.get_feed_counts()} feeds."
)
typer.echo(f"{feed_url} added")
typer.echo(f"{feed_url} added")
@app.command()
def check() -> None:
"""Check new entries for every feed"""
feed_count = reader.get_feed_counts()
entry_count = reader.get_entry_counts()
with closing(make_reader(Settings.db_file)) as reader:
feed_count = reader.get_feed_counts()
entry_count = reader.get_entry_counts()
print(
f"""Feeds:
Total: {feed_count.total}
Broken: {feed_count.broken}
Enabled: {feed_count.updates_enabled}"""
)
print(
f"""Feeds:
Total: {feed_count.total}
Broken: {feed_count.broken}
Enabled: {feed_count.updates_enabled}"""
)
print(
f"""Entries:
Total: {entry_count.total} feeds
Read: {entry_count.read} feeds
Important: {entry_count.important} feeds
Has enclosures: {entry_count.has_enclosures} feeds
Average number of entries per day:
1 Month: {entry_count.averages[0]:.2f} feeds per day
3 Months: {entry_count.averages[1]:.2f} feeds per day
12 Months: {entry_count.averages[2]:.2f} feeds per day"""
)
print(
f"""Entries:
Total: {entry_count.total} feeds
Read: {entry_count.read} feeds
Important: {entry_count.important} feeds
Has enclosures: {entry_count.has_enclosures} feeds
Average number of entries per day:
1 Month: {entry_count.averages[0]:.2f} feeds per day
3 Months: {entry_count.averages[1]:.2f} feeds per day
12 Months: {entry_count.averages[2]:.2f} feeds per day"""
)
# Update the feeds
reader.update_feeds()
# Update the feeds
reader.update_feeds()
# Get new entries that are not read
entries = reader.get_entries(read=False)
# Get new entries that are not read
entries = reader.get_entries(read=False)
for entry in entries:
# Mark the entry as read
reader.mark_entry_as_read(entry)
for entry in entries:
# Mark the entry as read
reader.mark_entry_as_read(entry)
# Send the entries to Discord
hook.send(f":robot: :mega: {entry.title}")
# Send the entries to Discord
hook.send(f":robot: :mega: {entry.title}")
if __name__ == "__main__":