-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathupload_manager.py
86 lines (69 loc) · 2.76 KB
/
upload_manager.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
__copyright__ = '2020, BookFusion <[email protected]>'
__license__ = 'GPL v3'
from PyQt5.Qt import QObject, pyqtSignal, QThread, QNetworkAccessManager
from calibre_plugins.bookfusion.config import prefs
from calibre_plugins.bookfusion.book_format import BookFormat
from calibre_plugins.bookfusion.upload_worker import UploadWorker
class UploadManager(QObject):
finished = pyqtSignal()
readyForNext = pyqtSignal()
progress = pyqtSignal(int)
uploadProgress = pyqtSignal(int, int, int)
started = pyqtSignal(int)
uploaded = pyqtSignal(int)
updated = pyqtSignal(int)
skipped = pyqtSignal(int)
failed = pyqtSignal(int, str)
aborted = pyqtSignal(str)
def __init__(self, db, logger, book_ids, reupload):
QObject.__init__(self)
self.db = db
self.logger = logger
self.pending_book_ids = book_ids
self.reupload = reupload
self.canceled = False
self.api_key = prefs['api_key']
self.finished_count = 0
self.workers = []
def start(self):
self.readyForNext.connect(self.sync)
self.network = QNetworkAccessManager(self)
self.count = 0
for index in range(prefs['threads']):
worker = UploadWorker(index, self.reupload, self.db, self.logger, self.network)
worker.readyForNext.connect(self.sync)
worker.uploadProgress.connect(self.uploadProgress)
worker.uploaded.connect(self.uploaded)
worker.updated.connect(self.updated)
worker.skipped.connect(self.skipped)
worker.failed.connect(self.failed)
worker.aborted.connect(self.abort)
self.workers.append(worker)
self.logger.info('starting worker %s' % index)
worker.start()
def cancel(self):
self.canceled = True
for worker in self.workers:
worker.cancel()
self.finished.emit()
def sync(self, index):
if len(self.pending_book_ids) == 0:
self.finished_count += 1
if self.finished_count == len(self.workers):
self.finished.emit()
return
self.progress.emit(self.count)
self.count += 1
book_id = self.pending_book_ids.pop()
self.logger.info('Upload book: book_id={}; title={}'.format(book_id, self.db.get_proxy_metadata(book_id).title))
book_format = BookFormat(self.db, book_id)
if book_format.file_path:
self.started.emit(book_id)
worker = self.workers[index]
worker.syncRequested.emit(book_id, book_format.file_path)
else:
self.failed.emit(book_id, 'unsupported format')
self.readyForNext.emit(index)
def abort(self, msg):
self.cancel()
self.aborted.emit(msg)