diff options
| -rw-r--r-- | module/ConfigParser.py | 2 | ||||
| -rw-r--r-- | module/PluginManager.py | 2 | ||||
| -rw-r--r-- | module/ThreadManager.py | 50 | ||||
| -rwxr-xr-x | module/network/Request.py | 11 | ||||
| -rw-r--r-- | module/plugins/container/DLC_25.pyc | bin | 7765 -> 8193 bytes | |||
| -rw-r--r-- | module/plugins/container/DLC_26.pyc | bin | 7757 -> 8166 bytes | 
6 files changed, 49 insertions, 16 deletions
| diff --git a/module/ConfigParser.py b/module/ConfigParser.py index 859136572..b9b46176b 100644 --- a/module/ConfigParser.py +++ b/module/ConfigParser.py @@ -39,7 +39,6 @@ class ConfigParser:          self.password = ""          #stored outside and may not modified -        #@TODO start setup..          self.checkVersion() @@ -192,7 +191,6 @@ class ConfigParser:      #----------------------------------------------------------------------      def saveConfig(self, config, filename):          """saves config to filename""" -        #@TODO save username and config          with open(filename, "wb") as f:              for section in config.iterkeys(): diff --git a/module/PluginManager.py b/module/PluginManager.py index bace9807d..e2e3c934b 100644 --- a/module/PluginManager.py +++ b/module/PluginManager.py @@ -134,7 +134,7 @@ class PluginManager():                      for item in config:                          self.core.config.addPluginConfig([name]+item) -        #@TODO replace with plugins in homedir, plugin updater                     +        # replace with plugins in homedir, plugin updater                              return plugins diff --git a/module/ThreadManager.py b/module/ThreadManager.py index a49885297..a48d7e729 100644 --- a/module/ThreadManager.py +++ b/module/ThreadManager.py @@ -19,10 +19,13 @@  """  from threading import Event -import PluginThread - +from subprocess import Popen +from os.path import exists  from time import sleep +from module.network.Request import getURL +import PluginThread +  ########################################################################  class ThreadManager:  	"""manages the download threads, assign jobs, reconnect etc""" @@ -68,33 +71,58 @@ class ThreadManager:  	def work(self):  		"""run all task which have to be done (this is for repetivive call by core)""" -		self.checkReconnect() +		self.tryReconnect()  		self.checkThreadCount()  		self.assignJob()  	#---------------------------------------------------------------------- -	def checkReconnect(self): +	def tryReconnect(self):  		"""checks if reconnect needed"""  		if not (self.core.server_methods.is_time_reconnect() and self.core.config["reconnect"]["activated"] ):  			return False -		 +						  		active = [x.active.plugin.wantReconnect and x.active.plugin.waiting for x in self.threads if x.active] -		print active +  		if active.count(True) > 0 and len(active) == active.count(True): +		 +			if not exists(self.core.config['reconnect']['method']): +				if exists(join(pypath, self.core.config['reconnect']['method'])): +					self.core.config['reconnect']['method'] = join(pypath, self.core.config['reconnect']['method']) +				else: +					self.core.config["reconnect"]["activated"] = False +					self.log.warning(_("Reconnect script not found!")) +					return +				 +				  			self.reconnecting.set()  			#Do reconnect -			self.log.info(_("Reconnecting")) +			self.log.info(_("Starting reconnect")) +  			while [x.active.plugin.waiting for x in self.threads if x.active].count(True) != 0:  				sleep(0.25) -							 -			print "wating finsihed" +						 +			ip = re.match(".*Current IP Address: (.*)</body>.*", getURL("http://checkip.dyndns.org/")).group(1) -			print "do reconnect" -				 +			self.core.hookManager.beforeReconnecting(ip) +			reconn = Popen(self.core.config['reconnect']['method'])#, stdout=subprocess.PIPE) +			reconn.wait() +			sleep(1) +			ip = "" +			while ip == "": +					try: +							ip = re.match(".*Current IP Address: (.*)</body>.*", getURL("http://checkip.dyndns.org/")).group(1) #get new ip +					except: +							ip = "" +					sleep(1) +			self.core.hookManager.afterReconnecting(ip) +			 +			self.log.info(_("Reconnected, new IP: %s") % ip) +	 +					  			self.reconnecting.clear()  	#---------------------------------------------------------------------- diff --git a/module/network/Request.py b/module/network/Request.py index f3e399c1d..012d01ddf 100755 --- a/module/network/Request.py +++ b/module/network/Request.py @@ -85,7 +85,7 @@ class Request:          self.pycurl.setopt(pycurl.CONNECTTIMEOUT, 30)          self.pycurl.setopt(pycurl.NOSIGNAL, 1)          self.pycurl.setopt(pycurl.NOPROGRESS, 0) -        self.pycurl.setopt(pycurl.PROGRESSFUNCTION, self.progress) +        self.pycurl.setopt(pycurl.PROGRESSFUNCTION, self.noprogress)          self.pycurl.setopt(pycurl.AUTOREFERER, 1)          self.pycurl.setopt(pycurl.HEADERFUNCTION, self.write_header)          self.pycurl.setopt(pycurl.BUFFERSIZE, self.bufferSize) @@ -125,6 +125,7 @@ class Request:      def load(self, url, get={}, post={}, ref=True, cookies=True, just_header=False, no_post_encode=False): +                  url = str(url)          if post: @@ -198,6 +199,8 @@ class Request:          url = str(url) +        self.pycurl.setopt(pycurl.PROGRESSFUNCTION, self.progress) +                  if post:              if not no_post_encode:                  post = urllib.urlencode(post) @@ -351,7 +354,11 @@ class Request:              return False          self.dl_arrived = int(dl_d)          self.dl_size = int(dl_t) - +     +    def noprogress(self, dl_t, dl_d, up_t, up_d): +        if self.abort: +            return False +              def get_free_name(self, folder, file_name):          file_count = 0          file_name = join(folder, file_name) diff --git a/module/plugins/container/DLC_25.pyc b/module/plugins/container/DLC_25.pycBinary files differ index a2f396dc6..512ceda08 100644 --- a/module/plugins/container/DLC_25.pyc +++ b/module/plugins/container/DLC_25.pyc diff --git a/module/plugins/container/DLC_26.pyc b/module/plugins/container/DLC_26.pycBinary files differ index 5c8c98088..60378b5a8 100644 --- a/module/plugins/container/DLC_26.pyc +++ b/module/plugins/container/DLC_26.pyc | 
