Weboob class
This commit is contained in:
parent
34f42b9af1
commit
9a9862e935
3 changed files with 49 additions and 12 deletions
|
|
@ -0,0 +1,36 @@
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
|
||||||
|
"""
|
||||||
|
Copyright(C) 2010 Romain Bignon
|
||||||
|
|
||||||
|
This program 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, version 3 of the License.
|
||||||
|
|
||||||
|
This program 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 this program; if not, write to the Free Software
|
||||||
|
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
|
||||||
|
"""
|
||||||
|
|
||||||
|
import os
|
||||||
|
|
||||||
|
from weboob.modules import ModulesLoader
|
||||||
|
from weboob.config import Config
|
||||||
|
|
||||||
|
class Weboob:
|
||||||
|
CONFIG_FILE = '%s/.weboobrc' % os.path.expanduser("~")
|
||||||
|
|
||||||
|
def __init__(self, app_name, config_file=CONFIG_FILE):
|
||||||
|
self.app_name = app_name
|
||||||
|
self.backends = {}
|
||||||
|
self.config = Config(self.CONFIG_FILE)
|
||||||
|
self.config.load()
|
||||||
|
self.modules_loader = ModulesLoader()
|
||||||
|
self.modules_loader.load()
|
||||||
|
|
||||||
|
|
@ -18,8 +18,7 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
import mechanize.Browser
|
import mechanize
|
||||||
from mechanize import response_seek_wrapper, BrowserStateError
|
|
||||||
import urllib2
|
import urllib2
|
||||||
import html5lib
|
import html5lib
|
||||||
from html5lib import treebuilders
|
from html5lib import treebuilders
|
||||||
|
|
@ -130,21 +129,21 @@ class Browser(mechanize.Browser):
|
||||||
def openurl(self, *args, **kwargs):
|
def openurl(self, *args, **kwargs):
|
||||||
try:
|
try:
|
||||||
return mechanize.Browser.open(self, *args, **kwargs)
|
return mechanize.Browser.open(self, *args, **kwargs)
|
||||||
except (response_seek_wrapper, urllib2.HTTPError, urllib2.URLError), e:
|
except (mechanize.response_seek_wrapper, urllib2.HTTPError, urllib2.URLError), e:
|
||||||
error(e)
|
error(e)
|
||||||
raise BrowserUnavailable()
|
raise BrowserUnavailable()
|
||||||
except BrowserStateError:
|
except mechanize.BrowserStateError:
|
||||||
self.home()
|
self.home()
|
||||||
return mechanize.Browser.open(self, *args, **kwargs)
|
return mechanize.Browser.open(self, *args, **kwargs)
|
||||||
|
|
||||||
def submit(self, *args, **kwargs):
|
def submit(self, *args, **kwargs):
|
||||||
try:
|
try:
|
||||||
self.__changeLocation(mechanize.Browser.submit(self, *args, **kwargs))
|
self.__changeLocation(mechanize.Browser.submit(self, *args, **kwargs))
|
||||||
except (response_seek_wrapper, urllib2.HTTPError, urllib2.URLError), e:
|
except (mechanize.response_seek_wrapper, urllib2.HTTPError, urllib2.URLError), e:
|
||||||
error(e)
|
error(e)
|
||||||
self.page = None
|
self.page = None
|
||||||
raise BrowserUnavailable()
|
raise BrowserUnavailable()
|
||||||
except (BrowserStateError,BrowserRetry):
|
except (mechanize.BrowserStateError,BrowserRetry):
|
||||||
self.home()
|
self.home()
|
||||||
raise BrowserUnavailable()
|
raise BrowserUnavailable()
|
||||||
|
|
||||||
|
|
@ -154,11 +153,11 @@ class Browser(mechanize.Browser):
|
||||||
def follow_link(self, *args, **kwargs):
|
def follow_link(self, *args, **kwargs):
|
||||||
try:
|
try:
|
||||||
self.__changeLocation(mechanize.Browser.follow_link(self, *args, **kwargs))
|
self.__changeLocation(mechanize.Browser.follow_link(self, *args, **kwargs))
|
||||||
except (response_seek_wrapper, urllib2.HTTPError, urllib2.URLError), e:
|
except (mechanize.response_seek_wrapper, urllib2.HTTPError, urllib2.URLError), e:
|
||||||
error(e)
|
error(e)
|
||||||
self.page = None
|
self.page = None
|
||||||
raise BrowserUnavailable()
|
raise BrowserUnavailable()
|
||||||
except (BrowserStateError,BrowserRetry):
|
except (mechanize.BrowserStateError,BrowserRetry):
|
||||||
self.home()
|
self.home()
|
||||||
raise BrowserUnavailable()
|
raise BrowserUnavailable()
|
||||||
|
|
||||||
|
|
@ -172,11 +171,11 @@ class Browser(mechanize.Browser):
|
||||||
except BrowserRetry:
|
except BrowserRetry:
|
||||||
if not self.page or not args or self.page.url != args[0]:
|
if not self.page or not args or self.page.url != args[0]:
|
||||||
self.location(keep_args, keep_kwargs)
|
self.location(keep_args, keep_kwargs)
|
||||||
except (response_seek_wrapper, urllib2.HTTPError, urllib2.URLError), e:
|
except (mechanize.response_seek_wrapper, urllib2.HTTPError, urllib2.URLError), e:
|
||||||
error(e)
|
error(e)
|
||||||
self.page = None
|
self.page = None
|
||||||
raise BrowserUnavailable()
|
raise BrowserUnavailable()
|
||||||
except BrowserStateError:
|
except mechanize.BrowserStateError:
|
||||||
self.home()
|
self.home()
|
||||||
self.location(*keep_args, **keep_kwargs)
|
self.location(*keep_args, **keep_kwargs)
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -21,7 +21,7 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
import sys
|
import sys
|
||||||
from dlfp import DLFP
|
from weboob import Weboob
|
||||||
|
|
||||||
class User:
|
class User:
|
||||||
def __init__(self, username, password, email):
|
def __init__(self, username, password, email):
|
||||||
|
|
@ -30,8 +30,10 @@ class User:
|
||||||
self.email = email
|
self.email = email
|
||||||
|
|
||||||
class Application:
|
class Application:
|
||||||
|
APPNAME = 'weboob2mail'
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
pass
|
self.weboob = Weboob(self.APPNAME)
|
||||||
|
|
||||||
def main(self, argv):
|
def main(self, argv):
|
||||||
pass
|
pass
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue