Add Mastodon API functionality
This commit is contained in:
parent
556ad7a468
commit
1c72557230
1 changed files with 24 additions and 3 deletions
27
main.py
27
main.py
|
@ -1,6 +1,7 @@
|
|||
import feedparser
|
||||
import json
|
||||
from markdownify import markdownify
|
||||
from mastodon import Mastodon
|
||||
import re
|
||||
import sys
|
||||
import time
|
||||
|
@ -28,6 +29,20 @@ def split_notes(text: str, limit: int) -> list[str]:
|
|||
return notes
|
||||
|
||||
|
||||
def post_note(client: Mastodon, content: str, in_reply_to_id: str | None) -> str:
|
||||
note = client.status_post(content, in_reply_to_id, visibility="unlisted")
|
||||
print("Posted:", note["url"])
|
||||
return note["id"]
|
||||
|
||||
|
||||
def post_notes(client: Mastodon, notes: list[str]):
|
||||
ids = []
|
||||
for note in notes:
|
||||
in_reply_to_id = ids[-1] if len(ids) != 0 else None
|
||||
posted_note = post_note(client, note, in_reply_to_id)
|
||||
ids.append(posted_note)
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
if len(sys.argv) < 3:
|
||||
print("Usage:", sys.argv[0], "<account> <config>")
|
||||
|
@ -36,6 +51,12 @@ if __name__ == "__main__":
|
|||
account = sys.argv[1]
|
||||
config_path = sys.argv[2]
|
||||
|
||||
client = Mastodon(access_token=f"accounts/{account}.secret")
|
||||
creds = client.account_verify_credentials()
|
||||
print(f"Logged in: {creds["display_name"]} (@{creds["fqn"]})")
|
||||
instance = client.instance()
|
||||
char_limit = instance["configuration"]["statuses"]["max_characters"]
|
||||
|
||||
config_file = open(config_path, "r")
|
||||
config = json.load(config_file)
|
||||
config_file.close()
|
||||
|
@ -56,9 +77,9 @@ if __name__ == "__main__":
|
|||
continue
|
||||
|
||||
notes = split_notes("[" + entry.title + "](" + entry.link + ")\n" + process_html(
|
||||
entry.content[0].value) + "\n\n" + entry.link, 500)
|
||||
[print(note) for note in notes]
|
||||
print()
|
||||
entry.content[0].value) + "\n\n" + entry.link, char_limit)
|
||||
|
||||
post_notes(client, notes)
|
||||
|
||||
config[url] = time.mktime(rss.entries[-1].published_parsed)
|
||||
|
||||
|
|
Loading…
Reference in a new issue