2014-05-04 17:26:43 +00:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
# vi:si:et:sw=4:sts=4:ts=4
|
|
|
|
from __future__ import division
|
|
|
|
|
|
|
|
from threading import Thread
|
|
|
|
import time
|
2014-05-17 14:26:59 +00:00
|
|
|
import logging
|
2014-05-04 17:26:43 +00:00
|
|
|
|
|
|
|
import state
|
|
|
|
|
2014-05-17 14:26:59 +00:00
|
|
|
logger = logging.getLogger('oml.downloads')
|
|
|
|
|
2014-05-04 17:26:43 +00:00
|
|
|
class Downloads(Thread):
|
|
|
|
|
|
|
|
def __init__(self, app):
|
|
|
|
self._app = app
|
|
|
|
self._running = True
|
|
|
|
Thread.__init__(self)
|
|
|
|
self.daemon = True
|
|
|
|
self.start()
|
|
|
|
|
|
|
|
def download_next(self):
|
|
|
|
import item.models
|
2014-05-21 22:41:29 +00:00
|
|
|
for t in item.models.Transfer.query.filter(
|
|
|
|
item.models.Transfer.added!=None,
|
|
|
|
item.models.Transfer.progress<1).order_by(item.models.Transfer.added):
|
|
|
|
for u in t.item.users:
|
|
|
|
if state.nodes.is_online(u.id):
|
|
|
|
logger.debug('DOWNLOAD %s %s', t.item, u)
|
|
|
|
r = state.nodes.download(u.id, t.item)
|
2014-05-17 14:26:59 +00:00
|
|
|
logger.debug('download ok? %s', r)
|
2014-05-04 17:26:43 +00:00
|
|
|
return True
|
|
|
|
return False
|
|
|
|
|
|
|
|
def run(self):
|
|
|
|
time.sleep(2)
|
|
|
|
with self._app.app_context():
|
|
|
|
while self._running:
|
|
|
|
if state.online:
|
|
|
|
self.download_next()
|
2014-05-21 00:02:21 +00:00
|
|
|
time.sleep(0.5)
|
2014-05-04 17:26:43 +00:00
|
|
|
else:
|
|
|
|
time.sleep(20)
|
|
|
|
|
|
|
|
def join(self):
|
|
|
|
self._running = False
|
|
|
|
self._q.put(None)
|
|
|
|
return Thread.join(self)
|
|
|
|
|