mirror of
https://github.com/codl/forget
synced 2025-01-01 01:48:29 +01:00
Merge branch 'fix-refresh'
This commit is contained in:
commit
61131f4298
@ -3,6 +3,7 @@
|
||||
* implemented a more robust fetching algorithm, which should prevent accounts getting stuck with only a fraction of their posts fetched ([GH-13](https://github.com/codl/forget/issues/13))
|
||||
* fix: picture tags having an extra comma
|
||||
* fix: outdated joke in about page
|
||||
* fix: posts' status not getting refreshed (ie whether or not they were faved, or deleted externally)
|
||||
* internals: removed `x-` prefix from custom headers, as per [section 8.3.1 of RFC7231](https://httpwg.org/specs/rfc7231.html#considerations.for.new.header.fields)
|
||||
|
||||
## v1.4.1 (security update)
|
||||
|
@ -1,6 +1,7 @@
|
||||
from mastodon import Mastodon
|
||||
from mastodon.Mastodon import MastodonAPIError,\
|
||||
MastodonNetworkError,\
|
||||
MastodonNotFoundError,\
|
||||
MastodonRatelimitError,\
|
||||
MastodonUnauthorizedError
|
||||
from model import MastodonApp, Account, OAuthToken, Post, MastodonInstance
|
||||
@ -164,16 +165,14 @@ def refresh_posts(posts):
|
||||
status = api.status(post.mastodon_id)
|
||||
new_post = db.session.merge(
|
||||
post_from_api_object(status, post.mastodon_instance))
|
||||
new_post.touch()
|
||||
new_posts.append(new_post)
|
||||
except MastodonNotFoundError:
|
||||
db.session.delete(post)
|
||||
except (MastodonAPIError,
|
||||
MastodonNetworkError,
|
||||
MastodonRatelimitError) as e:
|
||||
if any([
|
||||
err in str(e)
|
||||
for err in ('Endpoint not found', 'Record not found')]):
|
||||
db.session.delete(post)
|
||||
else:
|
||||
raise TemporaryError(e)
|
||||
raise TemporaryError(e)
|
||||
|
||||
return new_posts
|
||||
|
||||
|
@ -167,6 +167,7 @@ def refresh_posts(posts):
|
||||
db.session.delete(post)
|
||||
else:
|
||||
post = db.session.merge(post_from_api_tweet_object(tweet))
|
||||
post.touch()
|
||||
refreshed_posts.append(post)
|
||||
|
||||
return refreshed_posts
|
||||
|
Loading…
Reference in New Issue
Block a user