2021-06-06 18:29:09 +08:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
# coding=utf-8
|
|
|
|
|
|
|
|
import logging
|
|
|
|
|
2022-11-24 08:48:17 +08:00
|
|
|
import prawcore
|
|
|
|
|
2021-06-06 18:29:09 +08:00
|
|
|
from bdfr.archiver import Archiver
|
|
|
|
from bdfr.configuration import Configuration
|
|
|
|
from bdfr.downloader import RedditDownloader
|
|
|
|
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
|
|
|
|
class RedditCloner(RedditDownloader, Archiver):
|
|
|
|
def __init__(self, args: Configuration):
|
|
|
|
super(RedditCloner, self).__init__(args)
|
|
|
|
|
|
|
|
def download(self):
|
|
|
|
for generator in self.reddit_lists:
|
|
|
|
for submission in generator:
|
2022-11-24 08:48:17 +08:00
|
|
|
try:
|
|
|
|
self._download_submission(submission)
|
|
|
|
self.write_entry(submission)
|
|
|
|
except prawcore.PrawcoreException as e:
|
2022-12-03 13:11:17 +08:00
|
|
|
logger.error(f"Submission {submission.id} failed to be cloned due to a PRAW exception: {e}")
|