X-Git-Url: https://projects.mako.cc/source/python-simplemediawiki.debian/blobdiff_plain/c2c978f25fc626681c7d8ba477bea9082ae8ce93..04a25c76a33802f39e2afe4989d822c010a7e863:/simplemediawiki.py diff --git a/simplemediawiki.py b/simplemediawiki.py index 940fb2b..ab0f3f7 100644 --- a/simplemediawiki.py +++ b/simplemediawiki.py @@ -49,6 +49,7 @@ class MediaWiki(): _high_limits = None _namespaces = None _psuedo_namespaces = None + _mediawiki_version = None def __init__(self, api_url, cookie_file=None, user_agent=DEFAULT_UA): self._api_url = api_url @@ -61,7 +62,9 @@ class MediaWiki(): self._cj.load() else: self._cj = cookielib.CookieJar() - self._opener = urllib2.build_opener(urllib2.HTTPCookieProcessor(self._cj)) + self._opener = urllib2.build_opener( + urllib2.HTTPCookieProcessor(self._cj) + ) self._opener.addheaders = [('User-agent', user_agent)] def _fetch_http(self, url, params): @@ -138,12 +141,22 @@ class MediaWiki(): data['lgtoken'] = token result = self.call(data) if result['login']['result'] == 'Success': + self._high_limits = None return True elif result['login']['result'] == 'NeedToken' and not token: return self.login(user, passwd, result['login']['token']) else: return False + def logout(self): + """ + Conveinence function for logging out of the wiki. + """ + data = {'action': 'logout'} + self.call(data) + self._high_limits = None + return True + def limits(self, low, high): """ Convenience function for determining appropriate limits in the API. If @@ -196,7 +209,7 @@ class MediaWiki(): __author__ = 'Ian Weller ' -__version__ = '1.0.1' +__version__ = '1.0.2' DEFAULT_UA = 'python-simplemediawiki/%s ' + \ '+https://github.com/ianweller/python-simplemediawiki' \ % __version__