s/BaseBackend/BaseModule

This commit is contained in:
Florent 2014-09-22 17:25:38 +02:00
commit 8559af3d6a
165 changed files with 354 additions and 354 deletions

View file

@ -63,8 +63,8 @@ For example, use this command::
In a module directory, there are commonly these files:
* **__init__.py** - needed in every python modules, it exports your :class:`BaseBackend <weboob.tools.backend.BaseBackend>` class.
* **backend.py** - defines the main class of your module, which derives :class:`BaseBackend <weboob.tools.backend.BaseBackend>`.
* **__init__.py** - needed in every python modules, it exports your :class:`BaseModule <weboob.tools.backend.BaseModule>` class.
* **backend.py** - defines the main class of your module, which derives :class:`BaseModule <weboob.tools.backend.BaseModule>`.
* **browser.py** - your browser, derived from :class:`BaseBrowser <weboob.tools.browser2.browser.BaseBrowser>`, is called by your module to interact with the supported website.
* **pages.py** - all website's pages handled by the browser are defined here
* **test.py** - functional tests
@ -97,9 +97,9 @@ If the last command does not work, check your :doc:`repositories setup </guides/
Backend class
*************
Edit ``backend.py``. It contains the main class of the module derived from :class:`BaseBackend <weboob.tools.backend.BaseBackend>` class::
Edit ``backend.py``. It contains the main class of the module derived from :class:`BaseModule <weboob.tools.backend.BaseModule>` class::
class ExampleBackend(BaseBackend, CapBank):
class ExampleBackend(BaseModule, CapBank):
NAME = 'example' # The name of module
DESCRIPTION = u'Example bank website' # Description of your module
MAINTAINER = u'John Smith' # Name of maintainer of this module
@ -138,7 +138,7 @@ For example::
from weboob.tools.backend import BackendConfig
# ...
class ExampleBackend(BaseBackend, CapBank):
class ExampleBackend(BaseModule, CapBank):
# ...
CONFIG = BackendConfig(Value('username', label='Username', regexp='.+'),
ValueBackendPassword('password', label='Password'),
@ -155,7 +155,7 @@ Implement capabilities
You need to implement each method of all of the capabilities your module implements. For example, in our case::
# ...
class ExampleBackend(BaseBackend, CapBank):
class ExampleBackend(BaseModule, CapBank):
# ...
def iter_accounts(self):
@ -271,7 +271,7 @@ Now you have a functional browser, you can use it in your class ``ExampleBackend
from .browser import ExampleBrowser
# ...
class ExampleBackend(BaseBackend, CapBank):
class ExampleBackend(BaseModule, CapBank):
# ...
BROWSER = ExampleBrowser
@ -288,9 +288,9 @@ Login management
----------------
When the website requires to be authenticated, you have to give credentials to the constructor of the browser. You can redefine
the method :func:`create_default_browser <weboob.tools.backend.BaseBackend.create_default_browser>`::
the method :func:`create_default_browser <weboob.tools.backend.BaseModule.create_default_browser>`::
class ExampleBackend(BaseBackend, CapBank):
class ExampleBackend(BaseModule, CapBank):
# ...
def create_default_browser(self):
return self.create_browser(self.config['username'].get(), self.config['password'].get())
@ -430,8 +430,8 @@ Filling objects
An object returned by a method of a capability can be not fully completed.
The class :class:`BaseBackend <weboob.tools.backend.BaseBackend>` provides a method named
:func:`fillobj <weboob.tools.backend.BaseBackend.fillobj>`, which can be called by an application to
The class :class:`BaseModule <weboob.tools.backend.BaseModule>` provides a method named
:func:`fillobj <weboob.tools.backend.BaseModule.fillobj>`, which can be called by an application to
fill some unloaded fields of a specific object, for example with::
backend.fillobj(video, ['url', 'author'])
@ -443,7 +443,7 @@ uncompleted fields, and call the method associated to the type of the object.
To define what objects are supported to be filled, and what method to call, define the ``OBJECTS``
class attribute in your ``ExampleBackend``::
class ExampleBackend(BaseBackend, CapVideo):
class ExampleBackend(BaseModule, CapVideo):
# ...
OBJECTS = {Video: fill_video}
@ -454,7 +454,7 @@ The prototype of the function might be::
Then, the function might, for each requested fields, fetch the right data and fill the object. For example::
class ExampleBackend(BaseBackend, CapVideo):
class ExampleBackend(BaseModule, CapVideo):
# ...
def fill_video(self, video, fields):
@ -477,7 +477,7 @@ The application can provide a storage to let your backend store data. So, you ca
STORAGE = {'seen': {}}
To store and read data in your storage space, use the ``storage`` attribute of your :class:`BaseBackend <weboob.tools.backend.BaseBackend>`
To store and read data in your storage space, use the ``storage`` attribute of your :class:`BaseModule <weboob.tools.backend.BaseModule>`
object.
It implements the methods of :class:`BackendStorage <weboob.tools.backend.BackendStorage>`.

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.capabilities.recipe import CapRecipe, Recipe
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from .browser import SevenFiftyGramsBrowser
@ -30,7 +30,7 @@ def strip_accents(s):
__all__ = ['SevenFiftyGramsBackend']
class SevenFiftyGramsBackend(BaseBackend, CapRecipe):
class SevenFiftyGramsBackend(BaseModule, CapRecipe):
NAME = '750g'
MAINTAINER = u'Julien Veyssier'
EMAIL = 'julien.veyssier@aiur.fr'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.ordereddict import OrderedDict
from weboob.tools.value import Value
from weboob.capabilities.job import CapJob
@ -28,7 +28,7 @@ from .job import AdeccoJobAdvert
__all__ = ['AdeccoBackend']
class AdeccoBackend(BaseBackend, CapJob):
class AdeccoBackend(BaseModule, CapJob):
NAME = 'adecco'
DESCRIPTION = u'adecco website'
MAINTAINER = u'Bezleputh'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.capabilities.calendar import CapCalendarEvent, CATEGORIES
from weboob.tools.ordereddict import OrderedDict
from weboob.tools.value import Value
@ -29,7 +29,7 @@ from .browser import AgendadulibreBrowser
__all__ = ['AgendadulibreBackend']
class AgendadulibreBackend(BaseBackend, CapCalendarEvent):
class AgendadulibreBackend(BaseModule, CapCalendarEvent):
NAME = 'agendadulibre'
DESCRIPTION = u'agendadulibre website'
MAINTAINER = u'Bezleputh'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.capabilities.cinema import CapCinema, Person, Movie
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from .browser import AllocineBrowser
@ -27,7 +27,7 @@ from urllib import quote_plus
__all__ = ['AllocineBackend']
class AllocineBackend(BaseBackend, CapCinema):
class AllocineBackend(BaseModule, CapCinema):
NAME = 'allocine'
MAINTAINER = u'Julien Veyssier'
EMAIL = 'julien.veyssier@aiur.fr'

View file

@ -20,7 +20,7 @@
from weboob.capabilities.bank import CapBank, AccountNotFound
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword
from .browser import AlloRestoBrowser
@ -29,7 +29,7 @@ from .browser import AlloRestoBrowser
__all__ = ['AlloRestoBackend']
class AlloRestoBackend(BaseBackend, CapBank):
class AlloRestoBackend(BaseModule, CapBank):
NAME = 'alloresto'
MAINTAINER = u'Romain Bignon'
EMAIL = 'romain@weboob.org'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.capabilities.recipe import CapRecipe, Recipe
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from .browser import AllrecipesBrowser
@ -27,7 +27,7 @@ from urllib import quote_plus
__all__ = ['AllrecipesBackend']
class AllrecipesBackend(BaseBackend, CapRecipe):
class AllrecipesBackend(BaseModule, CapRecipe):
NAME = 'allrecipes'
MAINTAINER = u'Julien Veyssier'
EMAIL = 'julien.veyssier@aiur.fr'

View file

@ -19,14 +19,14 @@
import urllib
from weboob.capabilities.bill import CapBill, SubscriptionNotFound, BillNotFound, Subscription, Bill
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword
from .browser import AmeliBrowser
__all__ = ['AmeliBackend']
class AmeliBackend(BaseBackend, CapBill):
class AmeliBackend(BaseModule, CapBill):
NAME = 'ameli'
DESCRIPTION = u'Ameli website: French Health Insurance'
MAINTAINER = u'Christophe Lampin'

View file

@ -19,14 +19,14 @@
import urllib
from weboob.capabilities.bill import CapBill, SubscriptionNotFound, BillNotFound, Subscription, Bill
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword
from .browser import AmeliProBrowser
__all__ = ['AmeliProBackend']
class AmeliProBackend(BaseBackend, CapBill):
class AmeliProBackend(BaseModule, CapBill):
NAME = 'amelipro'
DESCRIPTION = u'Ameli website: French Health Insurance for Professionals'
MAINTAINER = u'Christophe Lampin'

View file

@ -20,7 +20,7 @@
from weboob.capabilities.bank import CapBank, AccountNotFound
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword
from .browser import AmericanExpressBrowser
@ -29,7 +29,7 @@ from .browser import AmericanExpressBrowser
__all__ = ['AmericanExpressBackend']
class AmericanExpressBackend(BaseBackend, CapBank):
class AmericanExpressBackend(BaseModule, CapBank):
NAME = 'americanexpress'
MAINTAINER = u'Romain Bignon'
EMAIL = 'romain@weboob.org'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.capabilities.job import CapJob
from weboob.tools.ordereddict import OrderedDict
from weboob.tools.value import Value
@ -28,7 +28,7 @@ from .job import ApecJobAdvert
__all__ = ['ApecBackend']
class ApecBackend(BaseBackend, CapJob):
class ApecBackend(BaseModule, CapJob):
NAME = 'apec'
DESCRIPTION = u'apec website'
MAINTAINER = u'Bezleputh'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.capabilities.bank import CapBank
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword
from .browser import ApivieBrowser
@ -27,7 +27,7 @@ from .browser import ApivieBrowser
__all__ = ['ApivieBackend']
class ApivieBackend(BaseBackend, CapBank):
class ApivieBackend(BaseModule, CapBank):
NAME = 'apivie'
DESCRIPTION = u'Apivie'
MAINTAINER = u'Romain Bignon'

View file

@ -20,7 +20,7 @@
from weboob.capabilities.video import CapVideo, BaseVideo
from weboob.capabilities.collection import CapCollection, CollectionNotFound
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword
from .browser import ArretSurImagesBrowser
@ -29,7 +29,7 @@ from .video import ArretSurImagesVideo
__all__ = ['ArretSurImagesBackend']
class ArretSurImagesBackend(BaseBackend, CapVideo, CapCollection):
class ArretSurImagesBackend(BaseModule, CapVideo, CapCollection):
NAME = 'arretsurimages'
DESCRIPTION = u'arretsurimages website'
MAINTAINER = u'franek'

View file

@ -22,7 +22,7 @@ import re
from weboob.capabilities.video import CapVideo, BaseVideo
from weboob.capabilities.collection import CapCollection, CollectionNotFound, Collection
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import Value
from .browser import ArteBrowser
@ -32,7 +32,7 @@ from .video import ArteVideo, ArteLiveVideo
__all__ = ['ArteBackend']
class ArteBackend(BaseBackend, CapVideo, CapCollection):
class ArteBackend(BaseModule, CapVideo, CapCollection):
NAME = 'arte'
MAINTAINER = u'Bezleputh'
EMAIL = 'carton_ben@yahoo.fr'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.capabilities.subtitle import CapSubtitle, LanguageNotSupported
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from .browser import AttilasubBrowser
@ -27,7 +27,7 @@ from urllib import quote_plus
__all__ = ['AttilasubBackend']
class AttilasubBackend(BaseBackend, CapSubtitle):
class AttilasubBackend(BaseModule, CapSubtitle):
NAME = 'attilasub'
MAINTAINER = u'Julien Veyssier'
EMAIL = 'julien.veyssier@aiur.fr'

View file

@ -22,7 +22,7 @@ from weboob.capabilities.radio import CapRadio, Radio
from weboob.capabilities.audiostream import BaseAudioStream
from weboob.tools.capabilities.streaminfo import StreamInfo
from weboob.capabilities.collection import CapCollection, Collection
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import Value
from weboob.tools.browser import StandardBrowser
import time
@ -38,7 +38,7 @@ __all__ = ['AudioAddictBackend']
# option to another player in the ~/.config/weboob/radioob config file:
# [ROOT]
# media_player = your_non_mplayer_player
class AudioAddictBackend(BaseBackend, CapRadio, CapCollection):
class AudioAddictBackend(BaseModule, CapRadio, CapCollection):
NAME = 'audioaddict'
MAINTAINER = u'Pierre Mazière'
EMAIL = 'pierre.maziere@gmx.com'

View file

@ -33,7 +33,7 @@ from weboob.capabilities.messages import CapMessages, CapMessagesPost, Message,
from weboob.capabilities.dating import CapDating, OptimizationNotFound, Event
from weboob.capabilities.contact import CapContact, ContactPhoto, Query, QueryError
from weboob.capabilities.account import CapAccount, StatusField
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.browser import BrowserUnavailable, BrowserHTTPNotFound
from weboob.tools.value import Value, ValuesDict, ValueBool, ValueBackendPassword
from weboob.tools.log import getLogger
@ -57,7 +57,7 @@ def parse_dt(s):
return local2utc(d)
class AuMBackend(BaseBackend, CapMessages, CapMessagesPost, CapDating, CapChat, CapContact, CapAccount):
class AuMBackend(BaseModule, CapMessages, CapMessagesPost, CapDating, CapChat, CapContact, CapAccount):
NAME = 'aum'
MAINTAINER = u'Romain Bignon'
EMAIL = 'romain@weboob.org'
@ -79,7 +79,7 @@ class AuMBackend(BaseBackend, CapMessages, CapMessagesPost, CapDating, CapChat,
MAGIC_ID_BASKET = 1
def __init__(self, *args, **kwargs):
BaseBackend.__init__(self, *args, **kwargs)
BaseModule.__init__(self, *args, **kwargs)
if self.config['antispam'].get():
self.antispam = AntiSpam()
else:

View file

@ -19,7 +19,7 @@
from weboob.capabilities.bank import CapBank, AccountNotFound
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword
from .browser import AXABanque
@ -28,7 +28,7 @@ from .browser import AXABanque
__all__ = ['AXABanqueBackend']
class AXABanqueBackend(BaseBackend, CapBank):
class AXABanqueBackend(BaseModule, CapBank):
NAME = 'axabanque'
MAINTAINER = u'Romain Bignon'
EMAIL = 'romain@weboob.org'

View file

@ -20,7 +20,7 @@
from weboob.capabilities.base import find_object
from weboob.capabilities.bank import CapBank, AccountNotFound
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword
from .browser import BanqueAccordBrowser
@ -29,7 +29,7 @@ from .browser import BanqueAccordBrowser
__all__ = ['BanqueAccordBackend']
class BanqueAccordBackend(BaseBackend, CapBank):
class BanqueAccordBackend(BaseModule, CapBank):
NAME = 'banqueaccord'
DESCRIPTION = u'Banque Accord'
MAINTAINER = u'Romain Bignon'

View file

@ -19,7 +19,7 @@
from weboob.capabilities.bank import CapBank, AccountNotFound
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.ordereddict import OrderedDict
from weboob.tools.value import ValueBackendPassword, Value
@ -29,7 +29,7 @@ from .browser import BanquePopulaire
__all__ = ['BanquePopulaireBackend']
class BanquePopulaireBackend(BaseBackend, CapBank):
class BanquePopulaireBackend(BaseModule, CapBank):
NAME = 'banquepopulaire'
MAINTAINER = u'Romain Bignon'
EMAIL = 'romain@weboob.org'

View file

@ -19,7 +19,7 @@
from weboob.capabilities.bank import CapBank, AccountNotFound
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword
from .browser import Barclays
@ -28,7 +28,7 @@ from .browser import Barclays
__all__ = ['BarclaysBackend']
class BarclaysBackend(BaseBackend, CapBank):
class BarclaysBackend(BaseModule, CapBank):
NAME = 'barclays'
MAINTAINER = u'Romain Bignon'
EMAIL = 'romain@weboob.org'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from weboob.capabilities.calendar import CapCalendarEvent, CATEGORIES
import itertools
@ -28,7 +28,7 @@ from.calendar import BiplanCalendarEvent
__all__ = ['BiplanBackend']
class BiplanBackend(BaseBackend, CapCalendarEvent):
class BiplanBackend(BaseModule, CapCalendarEvent):
NAME = 'biplan'
DESCRIPTION = u'lebiplan.org website'
MAINTAINER = u'Bezleputh'

View file

@ -23,7 +23,7 @@ from datetime import datetime, timedelta
from weboob.capabilities.bank import CapBank, AccountNotFound, Account, Recipient
from weboob.capabilities.messages import CapMessages, Thread
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword, Value
from .browser import BNPorc
@ -33,7 +33,7 @@ from .enterprise.browser import BNPEnterprise
__all__ = ['BNPorcBackend']
class BNPorcBackend(BaseBackend, CapBank, CapMessages):
class BNPorcBackend(BaseModule, CapBank, CapMessages):
NAME = 'bnporc'
MAINTAINER = u'Romain Bignon'
EMAIL = 'romain@weboob.org'
@ -54,7 +54,7 @@ class BNPorcBackend(BaseBackend, CapBank, CapMessages):
CACHE_THREADS = timedelta(seconds=3 * 60 * 60)
def __init__(self, *args, **kwargs):
BaseBackend.__init__(self, *args, **kwargs)
BaseModule.__init__(self, *args, **kwargs)
self._threads = None
self._threads_age = datetime.utcnow()

View file

@ -21,7 +21,7 @@
from weboob.capabilities.bank import CapBank, AccountNotFound
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword, ValueBool, Value
from .browser import Boursorama
@ -30,7 +30,7 @@ from .browser import Boursorama
__all__ = ['BoursoramaBackend']
class BoursoramaBackend(BaseBackend, CapBank):
class BoursoramaBackend(BaseModule, CapBank):
NAME = 'boursorama'
MAINTAINER = u'Gabriel Kerneis'
EMAIL = 'gabriel@kerneis.info'

View file

@ -21,7 +21,7 @@
from weboob.capabilities.messages import CantSendMessage, CapMessages, CapMessagesPost
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword, Value
from .browser import BouyguesBrowser
@ -30,7 +30,7 @@ from .browser import BouyguesBrowser
__all__ = ['BouyguesBackend']
class BouyguesBackend(BaseBackend, CapMessages, CapMessagesPost):
class BouyguesBackend(BaseModule, CapMessages, CapMessagesPost):
NAME = 'bouygues'
MAINTAINER = u'Christophe Benz'
EMAIL = 'christophe.benz@gmail.com'

View file

@ -19,7 +19,7 @@
from weboob.capabilities.bank import CapBank, Account
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword
from .browser import BPBrowser
@ -28,7 +28,7 @@ from .browser import BPBrowser
__all__ = ['BPBackend']
class BPBackend(BaseBackend, CapBank):
class BPBackend(BaseModule, CapBank):
NAME = 'bp'
MAINTAINER = u'Nicolas Duhamel'
EMAIL = 'nicolas@jombi.fr'

View file

@ -20,7 +20,7 @@
from weboob.capabilities.bank import CapBank, AccountNotFound
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword, Value
from .browser import BredBrowser
@ -29,7 +29,7 @@ from .browser import BredBrowser
__all__ = ['BredBackend']
class BredBackend(BaseBackend, CapBank):
class BredBackend(BaseModule, CapBank):
NAME = 'bred'
MAINTAINER = u'Romain Bignon'
EMAIL = 'romain@weboob.org'

View file

@ -1,14 +1,14 @@
# -*- coding: utf-8 -*-
from weboob.capabilities.torrent import CapTorrent
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from .browser import BTDiggBrowser
__all__ = ['BTDiggBackend']
class BTDiggBackend(BaseBackend, CapTorrent):
class BTDiggBackend(BaseModule, CapTorrent):
NAME = 'btdigg'
MAINTAINER = u'Matthieu Rakotojaona'
EMAIL = 'matthieu.rakotojaona@gmail.com'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.capabilities.torrent import CapTorrent, Torrent
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from .browser import BtmonBrowser
@ -27,7 +27,7 @@ from urllib import quote_plus
__all__ = ['BtmonBackend']
class BtmonBackend(BaseBackend, CapTorrent):
class BtmonBackend(BaseModule, CapTorrent):
NAME = 'btmon'
MAINTAINER = u'Julien Veyssier'
EMAIL = 'julien.veyssier@aiur.fr'

View file

@ -19,7 +19,7 @@
from weboob.capabilities.bank import CapBank, AccountNotFound
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import Value, ValueBackendPassword
from .browser import CaisseEpargne
@ -28,7 +28,7 @@ from .browser import CaisseEpargne
__all__ = ['CaisseEpargneBackend']
class CaisseEpargneBackend(BaseBackend, CapBank):
class CaisseEpargneBackend(BaseModule, CapBank):
NAME = 'caissedepargne'
MAINTAINER = u'Romain Bignon'
EMAIL = 'romain@weboob.org'

View file

@ -20,7 +20,7 @@
import re
from weboob.capabilities.video import CapVideo, BaseVideo
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import Value
from .browser import CanalplusBrowser
@ -32,7 +32,7 @@ from weboob.capabilities.collection import CapCollection
__all__ = ['CanalplusBackend']
class CanalplusBackend(BaseBackend, CapVideo, CapCollection):
class CanalplusBackend(BaseModule, CapVideo, CapCollection):
NAME = 'canalplus'
MAINTAINER = u'Nicolas Duhamel'
EMAIL = 'nicolas@jombi.fr'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.capabilities.travel import CapTravel, Station, Departure
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from .browser import CanalTP
@ -26,7 +26,7 @@ from .browser import CanalTP
__all__ = ['CanalTPBackend']
class CanalTPBackend(BaseBackend, CapTravel):
class CanalTPBackend(BaseModule, CapTravel):
NAME = 'canaltp'
MAINTAINER = u'Romain Bignon'
EMAIL = 'romain@weboob.org'

View file

@ -12,14 +12,14 @@
from weboob.capabilities.video import CapVideo, BaseVideo
from weboob.capabilities.collection import CapCollection, CollectionNotFound
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from .browser import CappedBrowser, CappedVideo
__all__ = ['CappedBackend']
class CappedBackend(BaseBackend, CapVideo, CapCollection):
class CappedBackend(BaseModule, CapVideo, CapCollection):
NAME = 'cappedtv'
MAINTAINER = u'Lord'
EMAIL = 'lord@lordtoniok.com'

View file

@ -20,7 +20,7 @@
from weboob.capabilities.base import find_object
from weboob.capabilities.bank import CapBank, AccountNotFound
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword
from .browser import CarrefourBanque
@ -29,7 +29,7 @@ from .browser import CarrefourBanque
__all__ = ['CarrefourBanqueBackend']
class CarrefourBanqueBackend(BaseBackend, CapBank):
class CarrefourBanqueBackend(BaseModule, CapBank):
NAME = 'carrefourbanque'
MAINTAINER = u'Romain Bignon'
EMAIL = 'romain@weboob.org'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.capabilities.job import CapJob, BaseJobAdvert
from weboob.tools.value import Value
@ -28,7 +28,7 @@ from .browser import CciBrowser
__all__ = ['CciBackend']
class CciBackend(BaseBackend, CapJob):
class CciBackend(BaseModule, CapJob):
NAME = 'cci'
DESCRIPTION = u'cci website'
MAINTAINER = u'Bezleputh'

View file

@ -19,7 +19,7 @@
from weboob.capabilities.library import CapBook
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword, Value
from .browser import ChampslibresBrowser
@ -28,7 +28,7 @@ from .browser import ChampslibresBrowser
__all__ = ['ChampslibresBackend']
class ChampslibresBackend(BaseBackend, CapBook):
class ChampslibresBackend(BaseModule, CapBook):
NAME = 'champslibres'
MAINTAINER = u'Florent Fourcot'
EMAIL = 'weboob@flo.fourcot.fr'

View file

@ -19,7 +19,7 @@
from weboob.capabilities.parcel import CapParcel
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from .browser import ChronopostBrowser
@ -27,7 +27,7 @@ from .browser import ChronopostBrowser
__all__ = ['ChronopostBackend']
class ChronopostBackend(BaseBackend, CapParcel):
class ChronopostBackend(BaseModule, CapParcel):
NAME = 'chronopost'
DESCRIPTION = u'Chronopost website'
MAINTAINER = u'Romain Bignon'

View file

@ -23,7 +23,7 @@ from decimal import Decimal
import string
from weboob.capabilities.bank import CapBank, AccountNotFound, Recipient, Account
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword
from .browser import CICBrowser
@ -32,7 +32,7 @@ from .browser import CICBrowser
__all__ = ['CICBackend']
class CICBackend(BaseBackend, CapBank):
class CICBackend(BaseModule, CapBank):
NAME = 'cic'
MAINTAINER = u'Romain Bignon'
EMAIL = 'romain@weboob.org'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword
from weboob.capabilities.bank import CapBank, AccountNotFound
@ -28,7 +28,7 @@ from .browser import CitelisBrowser
__all__ = ['CitelisBackend']
class CitelisBackend(BaseBackend, CapBank):
class CitelisBackend(BaseModule, CapBank):
NAME = 'citelis'
DESCRIPTION = u'Citélis'
MAINTAINER = u'Laurent Bachelier'

View file

@ -19,7 +19,7 @@
from weboob.capabilities.bank import CapBank, AccountNotFound
from weboob.capabilities.bank import Account, Transaction
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword
from weboob.capabilities.base import NotAvailable
from weboob.tools.exceptions import BrowserIncorrectPassword, ParseError
@ -36,7 +36,7 @@ from StringIO import StringIO
__all__ = ['CmbBackend']
class CmbBackend(BaseBackend, CapBank):
class CmbBackend(BaseModule, CapBank):
NAME = 'cmb'
MAINTAINER = u'Johann Broudin'
EMAIL = 'Johann.Broudin@6-8.fr'

View file

@ -19,7 +19,7 @@
from weboob.capabilities.bank import CapBank, AccountNotFound
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword
from .browser import Cmso
@ -28,7 +28,7 @@ from .browser import Cmso
__all__ = ['CmsoBackend']
class CmsoBackend(BaseBackend, CapBank):
class CmsoBackend(BaseModule, CapBank):
NAME = 'cmso'
MAINTAINER = u'Romain Bignon'
EMAIL = 'romain@weboob.org'

View file

@ -18,14 +18,14 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.capabilities.parcel import CapParcel
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from .browser import ColispriveBrowser
__all__ = ['ColispriveBackend']
class ColispriveBackend(BaseBackend, CapParcel):
class ColispriveBackend(BaseModule, CapParcel):
NAME = 'colisprive'
DESCRIPTION = u'Colisprive parcel tracking website'
MAINTAINER = u'Florent Fourcot'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.capabilities.parcel import CapParcel, Parcel, Event, ParcelNotFound
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from .browser import ColissimoBrowser
from datetime import date
@ -26,7 +26,7 @@ from datetime import date
__all__ = ['ColissimoBackend']
class ColissimoBackend(BaseBackend, CapParcel):
class ColissimoBackend(BaseModule, CapParcel):
NAME = 'colissimo'
DESCRIPTION = u'Colissimo parcel tracking website'
MAINTAINER = u'Florent Fourcot'

View file

@ -19,7 +19,7 @@
from weboob.capabilities.bank import CapBank, AccountNotFound
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.ordereddict import OrderedDict
from weboob.tools.value import ValueBackendPassword, Value
@ -30,7 +30,7 @@ from .mobile.browser import CragrMobile
__all__ = ['CragrBackend']
class CragrBackend(BaseBackend, CapBank):
class CragrBackend(BaseModule, CapBank):
NAME = 'cragr'
MAINTAINER = u'Romain Bignon'
EMAIL = 'romain@weboob.org'

View file

@ -19,7 +19,7 @@
from weboob.capabilities.bank import CapBank, AccountNotFound
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword, Value
from .perso.browser import CreditCooperatif as CreditCooperatifPerso
@ -29,7 +29,7 @@ from .pro.browser import CreditCooperatif as CreditCooperatifPro
__all__ = ['CreditCooperatifBackend']
class CreditCooperatifBackend(BaseBackend, CapBank):
class CreditCooperatifBackend(BaseModule, CapBank):
NAME = 'creditcooperatif'
MAINTAINER = u'Kevin Pouget'
EMAIL = 'weboob@kevin.pouget.me'

View file

@ -20,7 +20,7 @@
from weboob.capabilities.bank import CapBank, AccountNotFound
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.ordereddict import OrderedDict
from weboob.tools.value import ValueBackendPassword, Value
@ -30,7 +30,7 @@ from .browser import CreditDuNordBrowser
__all__ = ['CreditDuNordBackend']
class CreditDuNordBackend(BaseBackend, CapBank):
class CreditDuNordBackend(BaseModule, CapBank):
NAME = 'creditdunord'
MAINTAINER = u'Romain Bignon'
EMAIL = 'romain@weboob.org'

View file

@ -24,7 +24,7 @@ from decimal import Decimal
import string
from weboob.capabilities.bank import CapBank, AccountNotFound, Recipient, Account
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword
from .browser import CreditMutuelBrowser
@ -33,7 +33,7 @@ from .browser import CreditMutuelBrowser
__all__ = ['CreditMutuelBackend']
class CreditMutuelBackend(BaseBackend, CapBank):
class CreditMutuelBackend(BaseModule, CapBank):
NAME = 'creditmutuel'
MAINTAINER = u'Julien Veyssier'
EMAIL = 'julien.veyssier@aiur.fr'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.capabilities.recipe import CapRecipe, Recipe
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from .browser import CuisineazBrowser
@ -30,7 +30,7 @@ def strip_accents(s):
return ''.join(c for c in unicodedata.normalize('NFD', s) if unicodedata.category(c) != 'Mn')
class CuisineazBackend(BaseBackend, CapRecipe):
class CuisineazBackend(BaseModule, CapRecipe):
NAME = 'cuisineaz'
MAINTAINER = u'Julien Veyssier'
EMAIL = 'julien.veyssier@aiur.fr'

View file

@ -19,7 +19,7 @@
from weboob.capabilities.video import CapVideo, BaseVideo
from weboob.capabilities.collection import CapCollection, CollectionNotFound
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from .browser import DailymotionBrowser
from .video import DailymotionVideo
@ -28,7 +28,7 @@ from .video import DailymotionVideo
__all__ = ['DailymotionBackend']
class DailymotionBackend(BaseBackend, CapVideo, CapCollection):
class DailymotionBackend(BaseModule, CapVideo, CapCollection):
NAME = 'dailymotion'
MAINTAINER = u'Romain Bignon'
EMAIL = 'romain@weboob.org'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.capabilities.bank import CapBank
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword
from .browser import DelubacBrowser
@ -27,7 +27,7 @@ from .browser import DelubacBrowser
__all__ = ['DelubacBackend']
class DelubacBackend(BaseBackend, CapBank):
class DelubacBackend(BaseModule, CapBank):
NAME = 'delubac'
DESCRIPTION = u'Banque Delubac & Cie'
MAINTAINER = u'Noe Rubinstein'

View file

@ -23,7 +23,7 @@
from datetime import datetime, timedelta
import time
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.browser import BrowserForbidden
from weboob.tools.newsfeed import Newsfeed
from weboob.tools.value import Value, ValueBool, ValueBackendPassword
@ -37,7 +37,7 @@ from .tools import rssid, id2url
__all__ = ['DLFPBackend']
class DLFPBackend(BaseBackend, CapMessages, CapMessagesPost, CapContent):
class DLFPBackend(BaseModule, CapMessages, CapMessagesPost, CapContent):
NAME = 'dlfp'
MAINTAINER = u'Romain Bignon'
EMAIL = 'romain@weboob.org'

View file

@ -22,13 +22,13 @@ from .browser import DresdenWetterBrowser
from weboob.capabilities.gauge import CapGauge, GaugeSensor, Gauge,\
SensorNotFound
from weboob.capabilities.base import find_object
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
__all__ = ['DresdenWetterBackend']
class DresdenWetterBackend(BaseBackend, CapGauge):
class DresdenWetterBackend(BaseModule, CapGauge):
NAME = 'dresdenwetter'
MAINTAINER = u'Florent Fourcot'
EMAIL = 'weboob@flo.fourcot.fr'

View file

@ -21,14 +21,14 @@
import urllib
from weboob.capabilities.translate import CapTranslate, Translation, TranslationFail, LanguageNotSupported
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from weboob.tools.browser import StandardBrowser
__all__ = ['EbonicsBackend']
class EbonicsBackend(BaseBackend, CapTranslate):
class EbonicsBackend(BaseModule, CapTranslate):
NAME = 'ebonics'
MAINTAINER = u'Romain Bignon'
EMAIL = 'romain@weboob.org'

View file

@ -18,14 +18,14 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.capabilities.bill import CapBill, SubscriptionNotFound, BillNotFound, Subscription, Bill
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword
from .browser import EdfBrowser
__all__ = ['EdfBackend']
class EdfBackend(BaseBackend, CapBill):
class EdfBackend(BaseModule, CapBill):
NAME = 'edf'
DESCRIPTION = u'Edf website: French power provider'
MAINTAINER = u'Christophe Gouiran'

View file

@ -22,7 +22,7 @@
import re
from weboob.capabilities.gallery import CapGallery, BaseGallery
from weboob.capabilities.collection import CapCollection, CollectionNotFound
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.misc import ratelimit
from weboob.tools.value import Value, ValueBackendPassword
@ -33,7 +33,7 @@ from .gallery import EHentaiGallery, EHentaiImage
__all__ = ['EHentaiBackend']
class EHentaiBackend(BaseBackend, CapGallery, CapCollection):
class EHentaiBackend(BaseModule, CapGallery, CapCollection):
NAME = 'ehentai'
MAINTAINER = u'Roger Philibert'
EMAIL = 'roger.philibert@gmail.com'

View file

@ -22,7 +22,7 @@
from weboob.capabilities.video import CapVideo, BaseVideo
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from weboob.capabilities.collection import CapCollection, CollectionNotFound
from .browser import EuroparlBrowser
@ -32,7 +32,7 @@ from .video import EuroparlVideo
__all__ = ['EuroparlBackend']
class EuroparlBackend(BaseBackend, CapVideo, CapCollection):
class EuroparlBackend(BaseModule, CapVideo, CapCollection):
NAME = 'europarl'
MAINTAINER = u'François Revol'
EMAIL = 'revol@free.fr'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.capabilities.collection import CapCollection
from weboob.capabilities.messages import CapMessages, Message, Thread
from weboob.tools.value import Value, ValueBackendPassword
@ -29,7 +29,7 @@ from .google import GoogleBrowser
__all__ = ['FeedlyBackend']
class FeedlyBackend(BaseBackend, CapMessages, CapCollection):
class FeedlyBackend(BaseModule, CapMessages, CapCollection):
NAME = 'feedly'
DESCRIPTION = u'handle the popular RSS reading service Feedly'
MAINTAINER = u'Bezleputh'

View file

@ -19,7 +19,7 @@
from weboob.capabilities.bank import CapBank, AccountNotFound
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword
from .browser import Fortuneo
@ -28,7 +28,7 @@ from .browser import Fortuneo
__all__ = ['FortuneoBackend']
class FortuneoBackend(BaseBackend, CapBank):
class FortuneoBackend(BaseModule, CapBank):
NAME = 'fortuneo'
MAINTAINER = u'Gilles-Alexandre Quenot'
EMAIL = 'gilles.quenot@gmail.com'

View file

@ -21,7 +21,7 @@
from weboob.capabilities.messages import CapMessages, Message, Thread
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import Value
from .browser import FourChan
@ -30,7 +30,7 @@ from .browser import FourChan
__all__ = ['FourChanBackend']
class FourChanBackend(BaseBackend, CapMessages):
class FourChanBackend(BaseModule, CapMessages):
NAME = 'fourchan'
MAINTAINER = u'Romain Bignon'
EMAIL = 'romain@weboob.org'

View file

@ -20,7 +20,7 @@
from weboob.capabilities.video import CapVideo, BaseVideo
from weboob.capabilities.collection import CapCollection, CollectionNotFound
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from .browser import PluzzBrowser
@ -28,7 +28,7 @@ from .browser import PluzzBrowser
__all__ = ['PluzzBackend']
class PluzzBackend(BaseBackend, CapVideo, CapCollection):
class PluzzBackend(BaseModule, CapVideo, CapCollection):
NAME = 'francetelevisions'
MAINTAINER = u'Romain Bignon'
EMAIL = 'romain@weboob.org'

View file

@ -19,7 +19,7 @@
from weboob.capabilities.bill import CapBill, Subscription, Bill, SubscriptionNotFound, BillNotFound
from weboob.capabilities.base import find_object
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword
from .browser import Freemobile
@ -28,7 +28,7 @@ from .browser import Freemobile
__all__ = ['FreeMobileBackend']
class FreeMobileBackend(BaseBackend, CapBill):
class FreeMobileBackend(BaseModule, CapBill):
NAME = 'freemobile'
MAINTAINER = u'Florent Fourcot'
EMAIL = 'weboob@flo.fourcot.fr'

View file

@ -19,7 +19,7 @@
from weboob.capabilities.bank import CapBank, AccountNotFound
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.ordereddict import OrderedDict
from weboob.tools.value import ValueBackendPassword, Value
@ -29,7 +29,7 @@ from .browser import GanAssurances
__all__ = ['GanAssurancesBackend']
class GanAssurancesBackend(BaseBackend, CapBank):
class GanAssurancesBackend(BaseModule, CapBank):
NAME = 'ganassurances'
MAINTAINER = u'Romain Bignon'
EMAIL = 'romain@weboob.org'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.capabilities.torrent import CapTorrent
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword, Value
from .browser import GazelleBrowser
@ -27,7 +27,7 @@ from .browser import GazelleBrowser
__all__ = ['GazelleBackend']
class GazelleBackend(BaseBackend, CapTorrent):
class GazelleBackend(BaseModule, CapTorrent):
NAME = 'gazelle'
MAINTAINER = u'Romain Bignon'
EMAIL = 'romain@weboob.org'

View file

@ -22,7 +22,7 @@
from weboob.capabilities.video import CapVideo, BaseVideo
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.capabilities.collection import CapCollection, CollectionNotFound
from weboob.tools.value import Value, ValueBackendPassword
@ -33,7 +33,7 @@ from .video import GDCVaultVideo
__all__ = ['GDCVaultBackend']
class GDCVaultBackend(BaseBackend, CapVideo, CapCollection):
class GDCVaultBackend(BaseModule, CapVideo, CapCollection):
NAME = 'gdcvault'
MAINTAINER = u'François Revol'
EMAIL = 'revol@free.fr'

View file

@ -19,14 +19,14 @@
from weboob.capabilities.bill import CapBill, SubscriptionNotFound,\
BillNotFound, Subscription, Bill
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword
from .browser import GdfSuez
__all__ = ['GdfSuezBackend']
class GdfSuezBackend(BaseBackend, CapBill):
class GdfSuezBackend(BaseModule, CapBill):
NAME = 'gdfsuez'
MAINTAINER = u'Mathieu Jourdan'
EMAIL = 'mathieu.jourdan@gresille.org'

View file

@ -20,14 +20,14 @@
from weboob.capabilities.geolocip import CapGeolocIp, IpLocation
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from weboob.tools.browser import BaseBrowser, BrowserUnavailable
__all__ = ['GeolocIpBackend']
class GeolocIpBackend(BaseBackend, CapGeolocIp):
class GeolocIpBackend(BaseModule, CapGeolocIp):
NAME = 'geolocip'
MAINTAINER = u'Julien Veyssier'
EMAIL = 'julien.veyssier@aiur.fr'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import Value, ValueBackendPassword
from weboob.capabilities.bugtracker import CapBugTracker, Issue, Project, User, Version, Status, Update, Attachment
@ -32,7 +32,7 @@ STATUSES = {'open': Status('open', u'Open', Status.VALUE_NEW),
'closed': Status('closed', u'closed', Status.VALUE_RESOLVED)}
# TODO tentatively parse github "labels"?
class GithubBackend(BaseBackend, CapBugTracker):
class GithubBackend(BaseModule, CapBugTracker):
NAME = 'github'
DESCRIPTION = u'GitHub issues tracking'
MAINTAINER = u'Vincent A'

View file

@ -20,7 +20,7 @@
from weboob.capabilities.translate import CapTranslate, Translation, TranslationFail, LanguageNotSupported
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from .browser import GoogleTranslateBrowser
@ -28,7 +28,7 @@ from .browser import GoogleTranslateBrowser
__all__ = ['GoogleTranslateBackend']
class GoogleTranslateBackend(BaseBackend, CapTranslate):
class GoogleTranslateBackend(BaseModule, CapTranslate):
MAINTAINER = u'Lucien Loiseau'
EMAIL = 'loiseau.lucien@gmail.com'
VERSION = '1.0'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.capabilities.audio import CapAudio, BaseAudio, Album, Playlist, decode_id
from weboob.capabilities.collection import CapCollection, CollectionNotFound
from .browser import GroovesharkBrowser
@ -35,7 +35,7 @@ def cmp_id(p1, p2):
return -1
class GroovesharkBackend(BaseBackend, CapAudio, CapCollection):
class GroovesharkBackend(BaseModule, CapAudio, CapCollection):
NAME = 'grooveshark'
DESCRIPTION = u'Grooveshark music streaming website'
MAINTAINER = u'Bezleputh'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.capabilities.bank import CapBank, AccountNotFound
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword
from weboob.capabilities.base import find_object
@ -28,7 +28,7 @@ from .browser import GroupamaesBrowser
__all__ = ['GroupamaesBackend']
class GroupamaesBackend(BaseBackend, CapBank):
class GroupamaesBackend(BaseModule, CapBank):
NAME = 'groupamaes'
DESCRIPTION = u"Groupama Épargne Salariale"
MAINTAINER = u'Bezleputh'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.capabilities.messages import CapMessages, CapMessagesPost, Thread, Message
from weboob.tools.value import Value
@ -28,7 +28,7 @@ from .browser import GuerrillamailBrowser
__all__ = ['GuerrillamailBackend']
class GuerrillamailBackend(BaseBackend, CapMessages, CapMessagesPost):
class GuerrillamailBackend(BaseModule, CapMessages, CapMessagesPost):
NAME = 'guerrillamail'
DESCRIPTION = u'GuerrillaMail temp mailbox'
MAINTAINER = u'Vincent A'

View file

@ -20,7 +20,7 @@
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from weboob.capabilities.messages import CapMessages, Message, Thread
from .browser import HDSBrowser
@ -29,7 +29,7 @@ from .browser import HDSBrowser
__all__ = ['HDSBackend']
class HDSBackend(BaseBackend, CapMessages):
class HDSBackend(BaseModule, CapMessages):
NAME = 'hds'
MAINTAINER = u'Romain Bignon'
EMAIL = 'romain@weboob.org'

View file

@ -24,7 +24,7 @@ from datetime import datetime, timedelta
from weboob.capabilities.bank import CapBank, AccountNotFound, Account, Recipient
from weboob.capabilities.messages import CapMessages, Thread
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword
from .browser import HelloBank
@ -33,7 +33,7 @@ from .browser import HelloBank
__all__ = ['HelloBankBackend']
class HelloBankBackend(BaseBackend, CapBank, CapMessages):
class HelloBankBackend(BaseModule, CapBank, CapMessages):
NAME = 'hellobank'
MAINTAINER = u'Christophe Lampin'
EMAIL = 'weboob@lampin.net'
@ -49,7 +49,7 @@ class HelloBankBackend(BaseBackend, CapBank, CapMessages):
CACHE_THREADS = timedelta(seconds=3 * 60 * 60)
def __init__(self, *args, **kwargs):
BaseBackend.__init__(self, *args, **kwargs)
BaseModule.__init__(self, *args, **kwargs)
self._threads = None
self._threads_age = datetime.utcnow()

View file

@ -21,7 +21,7 @@
from weboob.capabilities.bank import CapBank, AccountNotFound
from weboob.capabilities.base import find_object
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword, Value
from .browser import HSBC
@ -30,7 +30,7 @@ from .browser import HSBC
__all__ = ['HSBCBackend']
class HSBCBackend(BaseBackend, CapBank):
class HSBCBackend(BaseModule, CapBank):
NAME = 'hsbc'
MAINTAINER = u'Romain Bignon'
EMAIL = 'romain@weboob.org'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from weboob.capabilities.calendar import CapCalendarEvent, CATEGORIES
from .browser import HybrideBrowser
@ -27,7 +27,7 @@ from .calendar import HybrideCalendarEvent
__all__ = ['HybrideBackend']
class HybrideBackend(BaseBackend, CapCalendarEvent):
class HybrideBackend(BaseModule, CapCalendarEvent):
NAME = 'hybride'
DESCRIPTION = u'hybride website'
MAINTAINER = u'Bezleputh'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.capabilities.cinema import CapCinema, Person, Movie
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from .browser import ImdbBrowser
@ -27,7 +27,7 @@ from urllib import quote_plus
__all__ = ['ImdbBackend']
class ImdbBackend(BaseBackend, CapCinema):
class ImdbBackend(BaseModule, CapCinema):
NAME = 'imdb'
MAINTAINER = u'Julien Veyssier'
EMAIL = 'julien.veyssier@aiur.fr'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from weboob.capabilities.paste import CapPaste, BasePaste
from weboob.tools.capabilities.paste import image_mime
from weboob.capabilities.base import StringField
@ -43,7 +43,7 @@ class ImgPaste(BasePaste):
return 'http://i.imgur.com/%s.png' % self.id
class ImgurBackend(BaseBackend, CapPaste):
class ImgurBackend(BaseModule, CapPaste):
NAME = 'imgur'
DESCRIPTION = u'imgur image upload service'
MAINTAINER = u'Vincent A'

View file

@ -19,7 +19,7 @@
from weboob.capabilities.video import CapVideo
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from .browser import InaBrowser
from .video import InaVideo
@ -28,7 +28,7 @@ from .video import InaVideo
__all__ = ['InaBackend']
class InaBackend(BaseBackend, CapVideo):
class InaBackend(BaseModule, CapVideo):
NAME = 'ina'
MAINTAINER = u'Christophe Benz'
EMAIL = 'christophe.benz@gmail.com'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.ordereddict import OrderedDict
from weboob.capabilities.job import CapJob, BaseJobAdvert
from weboob.tools.value import Value
@ -27,7 +27,7 @@ from .browser import IndeedBrowser
__all__ = ['IndeedBackend']
class IndeedBackend(BaseBackend, CapJob):
class IndeedBackend(BaseModule, CapJob):
NAME = 'indeed'
DESCRIPTION = u'indeed website'
MAINTAINER = u'Bezleputh'

View file

@ -23,7 +23,7 @@ from weboob.capabilities.bank import CapBank, AccountNotFound,\
from weboob.capabilities.bill import CapBill, Bill, Subscription,\
SubscriptionNotFound, BillNotFound
from weboob.capabilities.base import UserError, find_object
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword
from .browser import IngBrowser
@ -31,7 +31,7 @@ from .browser import IngBrowser
__all__ = ['INGBackend']
class INGBackend(BaseBackend, CapBank, CapBill):
class INGBackend(BaseModule, CapBank, CapBill):
NAME = 'ing'
MAINTAINER = u'Florent Fourcot'
EMAIL = 'weboob@flo.fourcot.fr'

View file

@ -20,14 +20,14 @@
from weboob.capabilities.geolocip import CapGeolocIp, IpLocation
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from weboob.tools.browser import StandardBrowser
__all__ = ['IpinfodbBackend']
class IpinfodbBackend(BaseBackend, CapGeolocIp):
class IpinfodbBackend(BaseModule, CapGeolocIp):
NAME = 'ipinfodb'
MAINTAINER = u'Julien Veyssier'
EMAIL = 'julien.veyssier@aiur.fr'

View file

@ -23,7 +23,7 @@ import re
from weboob.capabilities.gallery import CapGallery, BaseGallery, BaseImage
from weboob.tools.json import json
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from weboob.tools.browser import BaseBrowser, BasePage
__all__ = ['IzneoBackend']
@ -61,7 +61,7 @@ class IzneoBrowser(BaseBrowser):
image.url, None, {'Referer': image.gallery.url}))
class IzneoBackend(BaseBackend, CapGallery):
class IzneoBackend(BaseModule, CapGallery):
NAME = 'izneo'
MAINTAINER = u'Roger Philibert'
EMAIL = 'roger.philibert@gmail.com'

View file

@ -19,7 +19,7 @@
from weboob.capabilities.video import CapVideo, BaseVideo
from weboob.capabilities.collection import CapCollection, CollectionNotFound
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from .browser import JacquieEtMichelBrowser
from .video import JacquieEtMichelVideo
@ -28,7 +28,7 @@ from .video import JacquieEtMichelVideo
__all__ = ['JacquieEtMichelBackend']
class JacquieEtMichelBackend(BaseBackend, CapVideo, CapCollection):
class JacquieEtMichelBackend(BaseModule, CapVideo, CapCollection):
NAME = 'jacquieetmichel'
MAINTAINER = u'Roger Philibert'
EMAIL = 'roger.philibert@gmail.com'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.capabilities.base import StringField
from weboob.capabilities.gauge import CapGauge, GaugeSensor, Gauge, GaugeMeasure, SensorNotFound
from weboob.tools.value import Value
@ -51,7 +51,7 @@ class BikeSensor(GaugeSensor):
latitude = StringField('Latitude of the sensor')
class jcvelauxBackend(BaseBackend, CapGauge):
class jcvelauxBackend(BaseModule, CapGauge):
NAME = 'jcvelaux'
DESCRIPTION = (u'City bike renting availability information.\nCities: %s' %
u', '.join(CITIES))

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.capabilities.travel import CapTravel, RoadStep
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from .browser import JVMalin
@ -26,7 +26,7 @@ from .browser import JVMalin
__all__ = ['JVMalinBackend']
class JVMalinBackend(BaseBackend, CapTravel):
class JVMalinBackend(BaseModule, CapTravel):
NAME = 'jvmalin'
MAINTAINER = u'Alexandre Lissy'
EMAIL = 'github@lissy.me'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.capabilities.torrent import CapTorrent, Torrent
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from .browser import KickassBrowser
@ -29,7 +29,7 @@ from gzip import GzipFile
__all__ = ['KickassBackend']
class KickassBackend(BaseBackend, CapTorrent):
class KickassBackend(BaseModule, CapTorrent):
NAME = 'kickass'
MAINTAINER = u'Julien Veyssier'
EMAIL = 'julien.veyssier@aiur.fr'

View file

@ -19,7 +19,7 @@
import re
from weboob.capabilities.pricecomparison import CapPriceComparison, Price
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
#from weboob.tools.value import Value
from .browser import LaCentraleBrowser
@ -29,7 +29,7 @@ __all__ = ['LaCentraleBackend']
# I implement capability
class LaCentraleBackend(BaseBackend, CapPriceComparison):
class LaCentraleBackend(BaseModule, CapPriceComparison):
NAME = 'lacentrale'
MAINTAINER = u'Vicnet'
EMAIL = 'vo.publique@gmail.com'

View file

@ -21,7 +21,7 @@
from weboob.capabilities.bank import CapBank, AccountNotFound
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword, Value
from .browser import LCLBrowser, LCLProBrowser
@ -31,7 +31,7 @@ from .enterprise.browser import LCLEnterpriseBrowser, LCLEspaceProBrowser
__all__ = ['LCLBackend']
class LCLBackend(BaseBackend, CapBank):
class LCLBackend(BaseModule, CapBank):
NAME = 'lcl'
MAINTAINER = u'Romain Bignon'
EMAIL = 'romain@weboob.org'

View file

@ -20,7 +20,7 @@
from weboob.capabilities.bill import CapBill, SubscriptionNotFound,\
BillNotFound, Subscription, Bill
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword
from .browser import Leclercmobile
@ -29,7 +29,7 @@ from .browser import Leclercmobile
__all__ = ['LeclercMobileBackend']
class LeclercMobileBackend(BaseBackend, CapBill):
class LeclercMobileBackend(BaseModule, CapBill):
NAME = 'leclercmobile'
MAINTAINER = u'Florent Fourcot'
EMAIL = 'weboob@flo.fourcot.fr'

View file

@ -17,7 +17,7 @@
# You should have received a copy of the GNU Affero General Public License
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.ordereddict import OrderedDict
from weboob.tools.value import Value
from weboob.capabilities.job import CapJob
@ -28,7 +28,7 @@ from .job import LolixJobAdvert
__all__ = ['LolixBackend']
class LolixBackend(BaseBackend, CapJob):
class LolixBackend(BaseModule, CapJob):
NAME = 'lolix'
DESCRIPTION = u'Lolix French free software employment website'
MAINTAINER = u'Bezleputh'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.capabilities.paste import CapPaste, BasePaste
from weboob.tools.capabilities.paste import image_mime
from weboob.tools.value import Value
@ -31,7 +31,7 @@ from .browser import LutimBrowser
__all__ = ['LutimBackend']
class LutimBackend(BaseBackend, CapPaste):
class LutimBackend(BaseModule, CapPaste):
NAME = 'lutim'
DESCRIPTION = u'LUTIm website'
MAINTAINER = u'Vincent A'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.capabilities.messages import CapMessages, Thread, Message
from weboob.tools.value import Value
@ -30,7 +30,7 @@ __all__ = ['MailinatorBackend']
# There is only one thread per inbox, and the thread id is the inbox name
# TODO but this can lead to bans if there are too many messages...
class MailinatorBackend(BaseBackend, CapMessages):
class MailinatorBackend(BaseModule, CapMessages):
NAME = 'mailinator'
DESCRIPTION = u'mailinator temp mailbox'
MAINTAINER = u'Vincent A'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from weboob.capabilities.base import find_object
from weboob.capabilities.gauge import CapGauge, Gauge, SensorNotFound
from .browser import MareeinfoBrowser
@ -27,7 +27,7 @@ from .browser import MareeinfoBrowser
__all__ = ['MareeinfoBackend']
class MareeinfoBackend(BaseBackend, CapGauge):
class MareeinfoBackend(BaseModule, CapGauge):
NAME = 'mareeinfo'
DESCRIPTION = u'Un module qui permet d\' aller a la pêche aux moules totalement informé'
MAINTAINER = u'Bezleputh'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.capabilities.recipe import CapRecipe, Recipe
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from .browser import MarmitonBrowser
@ -27,7 +27,7 @@ from urllib import quote_plus
__all__ = ['MarmitonBackend']
class MarmitonBackend(BaseBackend, CapRecipe):
class MarmitonBackend(BaseModule, CapRecipe):
NAME = 'marmiton'
MAINTAINER = u'Julien Veyssier'
EMAIL = 'julien.veyssier@aiur.fr'

View file

@ -19,7 +19,7 @@
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.capabilities.content import CapContent, Content
from weboob.tools.value import ValueBackendPassword, Value
@ -30,7 +30,7 @@ from .browser import MediawikiBrowser
__all__ = ['MediawikiBackend']
class MediawikiBackend(BaseBackend, CapContent):
class MediawikiBackend(BaseModule, CapContent):
NAME = 'mediawiki'
MAINTAINER = u'Clément Schreiner'
EMAIL = 'clemux@clemux.info'

View file

@ -19,7 +19,7 @@
from weboob.capabilities.weather import CapWeather
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from .browser import MeteofranceBrowser
@ -27,7 +27,7 @@ from .browser import MeteofranceBrowser
__all__ = ['MeteofranceBackend']
class MeteofranceBackend(BaseBackend, CapWeather):
class MeteofranceBackend(BaseModule, CapWeather):
NAME = 'meteofrance'
MAINTAINER = u'Cedric Defortis'
EMAIL = 'cedric@aiur.fr'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.capabilities.job import CapJob
from weboob.tools.value import Value
from weboob.tools.ordereddict import OrderedDict
@ -29,7 +29,7 @@ from .job import MonsterJobAdvert
__all__ = ['MonsterBackend']
class MonsterBackend(BaseBackend, CapJob):
class MonsterBackend(BaseModule, CapJob):
NAME = 'monster'
DESCRIPTION = u'monster website'
MAINTAINER = u'Bezleputh'

View file

@ -18,12 +18,12 @@
from weboob.capabilities.radio import CapRadio, Radio
from weboob.capabilities.collection import CapCollection
from weboob.tools.backend import BaseBackend
from weboob.tools.backend import BaseModule
from .browser import NectarineBrowser
__all__ = ['NectarineBackend']
class NectarineBackend(BaseBackend, CapRadio, CapCollection):
class NectarineBackend(BaseModule, CapRadio, CapCollection):
NAME = 'nectarine'
MAINTAINER = u'Thomas Lecavelier'
EMAIL = 'thomas-weboob@lecavelier.name'

View file

@ -20,7 +20,7 @@
from weboob.capabilities.bill import CapBill, Subscription, SubscriptionNotFound, Detail
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.tools.value import ValueBackendPassword
from .browser import Nettokom
@ -29,7 +29,7 @@ from .browser import Nettokom
__all__ = ['NettoKomBackend']
class NettoKomBackend(BaseBackend, CapBill):
class NettoKomBackend(BaseModule, CapBill):
NAME = 'nettokom'
MAINTAINER = u'Florent Fourcot'
EMAIL = 'weboob@flo.fourcot.fr'

View file

@ -18,7 +18,7 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.tools.backend import BaseBackend, BackendConfig
from weboob.tools.backend import BaseModule, BackendConfig
from weboob.capabilities.messages import CapMessages, Message, Thread
from weboob.tools.newsfeed import Newsfeed
from weboob.tools.value import Value
@ -27,7 +27,7 @@ from weboob.tools.value import Value
__all__ = ['NewsfeedBackend']
class NewsfeedBackend(BaseBackend, CapMessages):
class NewsfeedBackend(BaseModule, CapMessages):
NAME = 'newsfeed'
MAINTAINER = u'Clément Schreiner'
EMAIL = "clemux@clemux.info"

Some files were not shown because too many files have changed in this diff Show more