Merge branch 'master' into develop

This commit is contained in:
JackDandy 2017-11-12 18:45:53 +00:00
commit efd9095f3f
2 changed files with 61 additions and 11 deletions

View file

@ -155,6 +155,11 @@
* Add parse repack, proper level to recent search flow * Add parse repack, proper level to recent search flow
### 0.12.37 (2017-11-12 10:35:00 UTC)
* Change improve .nzb handling
### 0.12.36 (2017-11-01 11:45:00 UTC) ### 0.12.36 (2017-11-01 11:45:00 UTC)
* Change qBittorent to handle the change to its API success/fail response * Change qBittorent to handle the change to its API success/fail response

View file

@ -18,9 +18,16 @@
from __future__ import with_statement from __future__ import with_statement
import xml.etree.cElementTree as etree try:
import xml.etree from lxml import etree
except ImportError:
try:
import xml.etree.cElementTree as etree
except ImportError:
import xml.etree.ElementTree as etree
import re import re
import os
from name_parser.parser import NameParser, InvalidNameException, InvalidShowException from name_parser.parser import NameParser, InvalidNameException, InvalidShowException
@ -28,6 +35,32 @@ from sickbeard import logger, classes, helpers
from sickbeard.common import Quality from sickbeard.common import Quality
from sickbeard import encodingKludge as ek from sickbeard import encodingKludge as ek
from sickbeard.exceptions import ex from sickbeard.exceptions import ex
import sickbeard
SUBJECT_FN_MATCHER = re.compile(r'"([^"]*)"')
RE_NORMAL_NAME = re.compile(r'\.\w{1,5}$')
def platform_encode(p):
""" Return Unicode name, if not already Unicode, decode with UTF-8 or latin1 """
if isinstance(p, str):
try:
return p.decode('utf-8')
except:
return p.decode(sickbeard.SYS_ENCODING, errors='replace').replace('?', '!')
else:
return p
def name_extractor(subject):
""" Try to extract a file name from a subject line, return `subject` if in doubt """
result = subject
for name in re.findall(SUBJECT_FN_MATCHER, subject):
name = name.strip(' "')
if name and RE_NORMAL_NAME.search(name):
result = name
return platform_encode(result)
def getSeasonNZBs(name, urlData, season): def getSeasonNZBs(name, urlData, season):
@ -35,29 +68,31 @@ def getSeasonNZBs(name, urlData, season):
showXML = etree.ElementTree(etree.XML(urlData)) showXML = etree.ElementTree(etree.XML(urlData))
except SyntaxError: except SyntaxError:
logger.log(u"Unable to parse the XML of " + name + ", not splitting it", logger.ERROR) logger.log(u"Unable to parse the XML of " + name + ", not splitting it", logger.ERROR)
return ({}, '') return {}, ''
filename = name.replace(".nzb", "") filename = name.replace(".nzb", "")
nzbElement = showXML.getroot() nzbElement = showXML.getroot()
regex = '([\w\._\ ]+)[\. ]S%02d[\. ]([\w\._\-\ ]+)[\- ]([\w_\-\ ]+?)' % season regex = '([\w\._\ ]+)[\._ ]S%02d[\._ ]([\w\._\-\ ]+)' % season
sceneNameMatch = re.search(regex, filename, re.I) sceneNameMatch = re.search(regex, filename, re.I)
if sceneNameMatch: if sceneNameMatch:
showName, qualitySection, groupName = sceneNameMatch.groups() # @UnusedVariable showName, qualitySection = sceneNameMatch.groups() # @UnusedVariable
else: else:
logger.log(u"Unable to parse " + name + " into a scene name. If it's a valid one, log a bug.", logger.ERROR) logger.log("%s - Not a valid season pack scene name. If it's a valid one, log a bug." % name, logger.ERROR)
return ({}, '') return {}, ''
regex = '(' + re.escape(showName) + '\.S%02d(?:[E0-9]+)\.[\w\._]+\-\w+' % season + ')' regex = '(' + re.escape(showName) + '[\._]S%02d(?:[E0-9]+)\.[\w\._]+' % season + ')'
regex = regex.replace(' ', '.') regex = regex.replace(' ', '.')
epFiles = {} epFiles = {}
xmlns = None xmlns = None
for curFile in nzbElement.getchildren(): for curFile in nzbElement.getchildren():
xmlnsMatch = re.match("\{(http:\/\/[A-Za-z0-9_\.\/]+\/nzb)\}file", curFile.tag) if not isinstance(curFile.tag, basestring):
continue
xmlnsMatch = re.match("\{(https?:\/\/[A-Za-z0-9_\.\/]+\/nzb)\}file", curFile.tag)
if not xmlnsMatch: if not xmlnsMatch:
continue continue
else: else:
@ -67,12 +102,22 @@ def getSeasonNZBs(name, urlData, season):
#print curFile.get("subject"), "doesn't match", regex #print curFile.get("subject"), "doesn't match", regex
continue continue
curEp = match.group(1) curEp = match.group(1)
fn = name_extractor(curFile.get('subject', ''))
if curEp == re.sub(r'\+\d+\.par2$', '', fn, flags=re.I):
bn, ext = ek.ek(os.path.splitext, fn)
curEp = re.sub(r'\.(part\d+|vol\d+(\+\d+)?)$', '', bn, flags=re.I)
bn, ext = ek.ek(os.path.splitext, curEp)
if isinstance(ext, basestring) \
and re.search(r'^\.(nzb|r\d{2}|rar|7z|zip|par2|vol\d+|nfo|srt|txt|bat|sh|mkv|mp4|avi|wmv)$', ext,
flags=re.I):
logger.log('Unable to split %s into episode nzb\'s' % name, logger.WARNING)
return {}, ''
if curEp not in epFiles: if curEp not in epFiles:
epFiles[curEp] = [curFile] epFiles[curEp] = [curFile]
else: else:
epFiles[curEp].append(curFile) epFiles[curEp].append(curFile)
return (epFiles, xmlns) return epFiles, xmlns
def createNZBString(fileElements, xmlns): def createNZBString(fileElements, xmlns):
@ -83,7 +128,7 @@ def createNZBString(fileElements, xmlns):
for curFile in fileElements: for curFile in fileElements:
rootElement.append(stripNS(curFile, xmlns)) rootElement.append(stripNS(curFile, xmlns))
return xml.etree.ElementTree.tostring(rootElement, 'utf-8') return etree.tostring(rootElement, encoding='utf-8')
def saveNZB(nzbName, nzbString): def saveNZB(nzbName, nzbString):