X-Git-Url: https://projects.mako.cc/source/mw/blobdiff_plain/a58c94092d906cad0611dda3b0fc2b18501b0299..1d1aafa5f78d4db3df784026af179409e914e3d0:/src/mw/api.py diff --git a/src/mw/api.py b/src/mw/api.py index bd12bb0..6aec91c 100644 --- a/src/mw/api.py +++ b/src/mw/api.py @@ -1,6 +1,6 @@ ### # mw - VCS-like nonsense for MediaWiki websites -# Copyright (C) 2009 Ian Weller +# Copyright (C) 2010 Ian Weller # # 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 @@ -19,30 +19,48 @@ import cookielib import gzip import json +import mw +import mw.metadir +import os from StringIO import StringIO import urllib import urllib2 + class API(object): - def __init__(self, api_url): + + def __init__(self, api_url, metadir): self.api_url = api_url - self.cookiejar = cookielib.CookieJar() + self.metadir = metadir + self.cookiejar = cookielib.MozillaCookieJar(os.path.join( + self.metadir.location, 'cookies')) + try: + self.cookiejar.load() + except IOError: + self.cookiejar.save() + self.cookiejar.load() self.opener = urllib2.build_opener( urllib2.HTTPCookieProcessor(self.cookiejar)) self._high_limits = None def call(self, data): data['format'] = 'json' - request = urllib2.Request(self.api_url, urllib.urlencode(data)) + user_agent = 'mw/%s +http://github.com/ianweller/mw' % mw.version + request = urllib2.Request(self.api_url, urllib.urlencode(data), + {'User-Agent': user_agent}) request.add_header('Accept-encoding', 'gzip') response = self.opener.open(request) + self.cookiejar.save() if response.headers.get('Content-Encoding') == 'gzip': compressed = StringIO(response.read()) gzipper = gzip.GzipFile(fileobj=compressed) data = gzipper.read() else: data = response.read() - return json.loads(data) + the_data = json.loads(data) + if 'error' in the_data.keys(): + raise APIError(the_data['error']['info']) + return the_data def limits(self, low, high): if self._high_limits == None: @@ -55,3 +73,24 @@ class API(object): return high else: return low + + +class APIError(Exception): + + def __init__(self, info): + self.info = info + + def __str__(self): + return self.info + + +def pagename_to_filename(name): + name = name.replace(' ', '_') + name = name.replace('/', '!') + return name + + +def filename_to_pagename(name): + name = name.replace('!', '/') + name = name.replace('_', ' ') + return name