From c58e54802472f6a5d3bad7752d57be3cfa43f771 Mon Sep 17 00:00:00 2001
From: adaur <adaur.underground@gmail.com>
Date: Thu, 16 Jul 2015 22:27:39 +0200
Subject: [PATCH] Add Cpasbien provider

French public tracker - no urllib :-)
---
 gui/slick/images/providers/cpasbien.png | Bin 0 -> 665 bytes
 sickbeard/__init__.py                   |   2 +-
 sickbeard/providers/__init__.py         |   1 +
 sickbeard/providers/cpasbien.py         | 217 ++++++++++++++++++++++++
 4 files changed, 219 insertions(+), 1 deletion(-)
 create mode 100644 gui/slick/images/providers/cpasbien.png
 create mode 100644 sickbeard/providers/cpasbien.py

diff --git a/gui/slick/images/providers/cpasbien.png b/gui/slick/images/providers/cpasbien.png
new file mode 100644
index 0000000000000000000000000000000000000000..6b8b1d29194ad1158570cb97a23dc5786953030c
GIT binary patch
literal 665
zcmeAS@N?(olHy`uVBq!ia0y~yU=RRd4mJh`2Kmqb6B!s7BuiW)N`mv#O3D+9QW+dm
z@{>{(JaZG%Q-e|yQz{EjrrIztFj;%LIEGZ*S`zG=A?zqoJNfP(lb33Ss&4$3z65wy
zb634s*;*mIgo}}1)X}viNMK33lWjGJ)BAaQIx04VG_&i9c?)(W`CSVNzwNBM@#Y0J
zv)swPyXN0dnS4V-<CVeYGw1fauYF%@tlYuz|MC%5#VC7Gg-VtgC7-SSZ!^@s^V#8{
zWkGJgN4}tnG>c4+@qt%ockYzSkb3c8fo-rm`zda23tO{q6`dM4W5Tx{J95zWQOPdB
z&H_EwN9oye{5B5_B;;-O#Ha^U?s!^Y!ErNZ?t|&iJ~LWde_#reK4|!F#y0mIDG$Dx
zWhdHRYTEKV?NyQFjQPjkz0qOnb(k42E2KIyYhq)hr^3Njrso^pBxEM1vU)7vxcc>v
zLo?2`HJ#pLfB3f+=f#s3gn7PlD$Y6a^v#>4LL2t*6exWA{*b#>AeH-ImT3X^i~hn-
znGY79ayPyu&T&Vw>!`^3>9SI7x;rDbh@M#Fm6~%pbJmWy)x00h2`OJ-jtQK{ICD;B
zp4#Gzn~%G@y<sXk`mm^w@2Z)OXy|Hz99^ZiA8lA|Dj1ifyv>^5ac^Hte7${&#Nmer
z9k=>jSkuUp#}~HYlv!Rx*sIRe-c!G}pL?xsUAJZ9#}bF@=gZZFq<%bF5R}RNZ^JgX
z=Uz)!=j*(Fw@~`m;<t>mjepksN>Q8qqWgINDd|Y{hgEx`V*ZpBX1~6azNo#vMxjgK
z*4~5<roKJ`z5SO<!lyrE_xt<SIXLh4-|x$v7MA<jJ*%%;b=T=gb*scb*=M^Mm>H_t
XZ|3Zdu+(N?U|{fc^>bP0l+XkKX_qZ;

literal 0
HcmV?d00001

diff --git a/sickbeard/__init__.py b/sickbeard/__init__.py
index b78c52401..2a8b868f3 100644
--- a/sickbeard/__init__.py
+++ b/sickbeard/__init__.py
@@ -37,7 +37,7 @@ from github import Github
 from sickbeard import providers, metadata, config, webserveInit
 from sickbeard.providers.generic import GenericProvider
 from providers import btn, newznab, womble, thepiratebay, torrentleech, kat, iptorrents, \
-    omgwtfnzbs, scc, hdtorrents, torrentday, hdbits, hounddawgs, nextgen, speedcd, nyaatorrents, animenzb, bluetigers, fnt, torrentbytes, animezb, \
+    omgwtfnzbs, scc, hdtorrents, torrentday, hdbits, hounddawgs, nextgen, speedcd, nyaatorrents, animenzb, bluetigers, cpasbien, fnt, torrentbytes, animezb, \
     frenchtorrentdb, freshontv, libertalia, morethantv, bitsoup, t411, tokyotoshokan, shazbat, rarbg, alpharatio, tntvillage, binsearch, scenetime, btdigg
 from sickbeard.config import CheckSection, check_setting_int, check_setting_str, check_setting_float, ConfigMigrator, \
     naming_ep_type
diff --git a/sickbeard/providers/__init__.py b/sickbeard/providers/__init__.py
index 6f98f0112..162c53cb6 100644
--- a/sickbeard/providers/__init__.py
+++ b/sickbeard/providers/__init__.py
@@ -47,6 +47,7 @@ __all__ = ['womble',
            'tntvillage',
            'binsearch',
            'bluetigers',
+           'cpasbien',
            'fnt',
            'scenetime',
            'btdigg',
diff --git a/sickbeard/providers/cpasbien.py b/sickbeard/providers/cpasbien.py
new file mode 100644
index 000000000..272dfd440
--- /dev/null
+++ b/sickbeard/providers/cpasbien.py
@@ -0,0 +1,217 @@
+# -*- coding: latin-1 -*-
+# Author: Guillaume Serre <guillaume.serre@gmail.com>
+# URL: http://code.google.com/p/sickbeard/
+#
+# This file is part of Sick Beard.
+#
+# Sick Beard is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# Sick Beard is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+#  GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with Sick Beard.  If not, see <http://www.gnu.org/licenses/>.
+
+import traceback
+import re
+import datetime
+import sickbeard
+import generic
+
+from lib import requests
+from lib.requests import exceptions
+
+from sickbeard.common import USER_AGENT, Quality, cpu_presets
+from sickbeard import logger
+from sickbeard import tvcache
+from sickbeard import show_name_helpers
+from sickbeard.bs4_parser import BS4Parser
+from sickbeard import db
+from sickbeard import helpers
+from sickbeard import classes
+from sickbeard.helpers import sanitizeSceneName, arithmeticEval
+from sickbeard.exceptions import ex
+
+import cookielib
+
+
+class CpasbienProvider(generic.TorrentProvider):
+
+    def __init__(self):
+        
+        generic.TorrentProvider.__init__(self, "Cpasbien")
+
+        self.supportsBacklog = True
+        self.ratio = None
+        
+        self.url = "http://www.cpasbien.pw"
+        
+        
+    def isEnabled(self):
+        
+        return self.enabled
+    
+    def imageName(self):
+        return 'cpasbien.png'
+    
+    def getQuality(self, item, anime=False):
+        quality = Quality.sceneQuality(item[0], anime)
+        return quality
+
+    def _get_season_search_strings(self, ep_obj):
+
+        search_string = {'Season': []}
+        for show_name in set(show_name_helpers.allPossibleShowNames(self.show)):
+            if ep_obj.show.air_by_date or ep_obj.show.sports:
+                ep_string = show_name + '.' + str(ep_obj.airdate).split('-')[0]
+            elif ep_obj.show.anime:
+                ep_string = show_name + '.' + "%d" % ep_obj.scene_absolute_number
+            else:
+                ep_string = show_name + '.S%02d' % int(ep_obj.scene_season)  # 1) showName.SXX
+
+            search_string['Season'].append(ep_string)
+
+        return [search_string]
+
+    def _get_episode_search_strings(self, ep_obj, add_string=''):
+
+        search_string = {'Episode': []}
+
+        if not ep_obj:
+            return []
+
+        if self.show.air_by_date:
+            for show_name in set(show_name_helpers.allPossibleShowNames(self.show)):
+                ep_string = sanitizeSceneName(show_name) + '.' + \
+                            str(ep_obj.airdate).replace('-', '|')
+                search_string['Episode'].append(ep_string)
+        elif self.show.sports:
+            for show_name in set(show_name_helpers.allPossibleShowNames(self.show)):
+                ep_string = sanitizeSceneName(show_name) + '.' + \
+                            str(ep_obj.airdate).replace('-', '|') + '|' + \
+                            ep_obj.airdate.strftime('%b')
+                search_string['Episode'].append(ep_string)
+        elif self.show.anime:
+            for show_name in set(show_name_helpers.allPossibleShowNames(self.show)):
+                ep_string = sanitizeSceneName(show_name) + '.' + \
+                            "%i" % int(ep_obj.scene_absolute_number)
+                search_string['Episode'].append(ep_string)
+        else:
+            for show_name in set(show_name_helpers.allPossibleShowNames(self.show)):
+                ep_string = show_name_helpers.sanitizeSceneName(show_name) + '.' + \
+                            sickbeard.config.naming_ep_type[2] % {'seasonnumber': ep_obj.scene_season,
+                                                                  'episodenumber': ep_obj.scene_episode} + ' %s' % add_string
+
+                search_string['Episode'].append(re.sub('\s+', '.', ep_string))
+
+        return [search_string]
+        
+    def _doSearch(self, search_params, search_mode='eponly', epcount=0, age=0, epObj=None):
+        
+        results = []
+        items = {'Season': [], 'Episode': [], 'RSS': []}
+        
+        for mode in search_params.keys():
+
+            for search_string in search_params[mode]:
+        
+                searchURL = self.url + '/recherche/'+search_string.replace('.','-')+'.html'
+                data = self.getURL(searchURL)        
+                try:
+                    with BS4Parser(data, features=["html5lib", "permissive"]) as html:
+                        
+                        lin=0
+                        erlin=0
+                        resultdiv=[]
+                        while erlin==0:
+                            try:
+                                classlin='ligne'+str(lin)
+                                resultlin=html.findAll(attrs = {'class' : [classlin]})
+                                if resultlin:
+                                    for ele in resultlin:
+                                        resultdiv.append(ele)
+                                    lin+=1
+                                else:
+                                    erlin=1
+                            except:
+                                erlin=1
+                        
+                        for row in resultdiv:
+                            try:
+                                link = row.find("a", title=True)
+                                torrent_name = str(link.text).lower().strip()  
+                                pageURL = link['href']
+
+                                #downloadTorrentLink = torrentSoup.find("a", title.startswith('Cliquer'))
+                                tmp = pageURL.split('/')[-1].replace('.html','.torrent')
+
+                                downloadTorrentLink = ('http://www.cpasbien.pw/telechargement/%s' % tmp)
+
+                                if downloadTorrentLink:
+                
+                                    torrent_download_url = downloadTorrentLink
+                            except (AttributeError, TypeError):
+                                    continue
+                            
+                            if not torrent_name or not torrent_download_url:
+                                continue
+
+                            item = torrent_name, torrent_download_url
+                            logger.log(u"Found result: " + torrent_name + " (" + torrent_download_url + ")",logger.DEBUG)
+                            items[mode].append(item)
+
+                except Exception, e:
+                    logger.log(u"Failed parsing " + self.name + " Traceback: " + traceback.format_exc(),logger.ERROR)
+            results += items[mode]
+        return results
+    
+    def _get_title_and_url(self, item):
+
+        title, url = item
+
+        if title:
+            title = u'' + title
+            title = title.replace(' ', '.')
+
+        if url:
+            url = str(url).replace('&amp;', '&')
+
+        return title, url
+    
+    def findPropers(self, search_date=datetime.datetime.today()):
+
+        results = []
+
+        myDB = db.DBConnection()
+        sqlResults = myDB.select(
+            'SELECT s.show_name, e.showid, e.season, e.episode, e.status, e.airdate FROM tv_episodes AS e' +
+            ' INNER JOIN tv_shows AS s ON (e.showid = s.indexer_id)' +
+            ' WHERE e.airdate >= ' + str(search_date.toordinal()) +
+            ' AND (e.status IN (' + ','.join([str(x) for x in Quality.DOWNLOADED]) + ')' +
+            ' OR (e.status IN (' + ','.join([str(x) for x in Quality.SNATCHED]) + ')))'
+        )
+
+        if not sqlResults:
+            return []
+
+        for sqlshow in sqlResults:
+            self.show = helpers.findCertainShow(sickbeard.showList, int(sqlshow["showid"]))
+            if self.show:
+                curEp = self.show.getEpisode(int(sqlshow["season"]), int(sqlshow["episode"]))
+                searchString = self._get_episode_search_strings(curEp, add_string='PROPER|REPACK')
+
+                for item in self._doSearch(searchString[0]):
+                    title, url = self._get_title_and_url(item)
+                    results.append(classes.Proper(title, url, datetime.datetime.today(), self.show))
+
+        return results
+    
+    def seedRatio(self):
+        return self.ratio
+
+provider = CpasbienProvider()
-- 
GitLab