mirror of https://gitlab.com/bashrc2/epicyon
Tidying of post deletion
parent
0335e52458
commit
021556ccee
71
utils.py
71
utils.py
|
@ -1228,20 +1228,60 @@ def _isReplyToBlogPost(baseDir: str, nickname: str, domain: str,
|
|||
return False
|
||||
|
||||
|
||||
def deletePost(baseDir: str, httpPrefix: str,
|
||||
nickname: str, domain: str, postFilename: str,
|
||||
debug: bool, recentPostsCache: {}) -> None:
|
||||
"""Recursively deletes a post and its replies and attachments
|
||||
def _deletePostRemoveReplies(baseDir: str, nickname: str, domain: str,
|
||||
httpPrefix: str, postFilename: str,
|
||||
recentPostsCache: {}, debug: bool) -> None:
|
||||
"""Removes replies when deleting a post
|
||||
"""
|
||||
repliesFilename = postFilename.replace('.json', '.replies')
|
||||
if not os.path.isfile(repliesFilename):
|
||||
return
|
||||
if debug:
|
||||
print('DEBUG: removing replies to ' + postFilename)
|
||||
with open(repliesFilename, 'r') as f:
|
||||
for replyId in f:
|
||||
replyFile = locatePost(baseDir, nickname, domain, replyId)
|
||||
if not replyFile:
|
||||
continue
|
||||
if os.path.isfile(replyFile):
|
||||
deletePost(baseDir, httpPrefix,
|
||||
nickname, domain, replyFile, debug,
|
||||
recentPostsCache)
|
||||
# remove the replies file
|
||||
os.remove(repliesFilename)
|
||||
|
||||
|
||||
def _isBookmarked(baseDir: str, nickname: str, domain: str,
|
||||
postFilename: str) -> bool:
|
||||
"""Returns True if the given post is bookmarked
|
||||
"""
|
||||
postJsonObject = loadJson(postFilename, 1)
|
||||
if postJsonObject:
|
||||
# don't allow deletion of bookmarked posts
|
||||
bookmarksIndexFilename = \
|
||||
baseDir + '/accounts/' + nickname + '@' + domain + \
|
||||
'/bookmarks.index'
|
||||
if os.path.isfile(bookmarksIndexFilename):
|
||||
bookmarkIndex = postFilename.split('/')[-1] + '\n'
|
||||
if bookmarkIndex in open(bookmarksIndexFilename).read():
|
||||
return True
|
||||
return False
|
||||
|
||||
|
||||
def deletePost(baseDir: str, httpPrefix: str,
|
||||
nickname: str, domain: str, postFilename: str,
|
||||
debug: bool, recentPostsCache: {}) -> None:
|
||||
"""Recursively deletes a post and its replies and attachments
|
||||
"""
|
||||
postJsonObject = loadJson(postFilename, 1)
|
||||
if not postJsonObject:
|
||||
# remove any replies
|
||||
_deletePostRemoveReplies(baseDir, nickname, domain,
|
||||
httpPrefix, postFilename,
|
||||
recentPostsCache, debug)
|
||||
# finally, remove the post itself
|
||||
os.remove(postFilename)
|
||||
return
|
||||
|
||||
# don't allow deletion of bookmarked posts
|
||||
if _isBookmarked(baseDir, nickname, domain, postFilename):
|
||||
return
|
||||
|
||||
# don't remove replies to blog posts
|
||||
|
@ -1333,20 +1373,9 @@ def deletePost(baseDir: str, httpPrefix: str,
|
|||
f.write(newlines)
|
||||
|
||||
# remove any replies
|
||||
repliesFilename = postFilename.replace('.json', '.replies')
|
||||
if os.path.isfile(repliesFilename):
|
||||
if debug:
|
||||
print('DEBUG: removing replies to ' + postFilename)
|
||||
with open(repliesFilename, 'r') as f:
|
||||
for replyId in f:
|
||||
replyFile = locatePost(baseDir, nickname, domain, replyId)
|
||||
if replyFile:
|
||||
if os.path.isfile(replyFile):
|
||||
deletePost(baseDir, httpPrefix,
|
||||
nickname, domain, replyFile, debug,
|
||||
recentPostsCache)
|
||||
# remove the replies file
|
||||
os.remove(repliesFilename)
|
||||
_deletePostRemoveReplies(baseDir, nickname, domain,
|
||||
httpPrefix, postFilename,
|
||||
recentPostsCache, debug)
|
||||
# finally, remove the post itself
|
||||
os.remove(postFilename)
|
||||
|
||||
|
|
Loading…
Reference in New Issue