2 # mw - VCS-like nonsense for MediaWiki websites
3 # Copyright (C) 2009 Ian Weller <ian@ianweller.org>
5 # This program is free software; you can redistribute it and/or modify
6 # it under the terms of the GNU General Public License as published by
7 # the Free Software Foundation; either version 2 of the License, or
8 # (at your option) any later version.
10 # This program is distributed in the hope that it will be useful,
11 # but WITHOUT ANY WARRANTY; without even the implied warranty of
12 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 # GNU General Public License for more details.
15 # You should have received a copy of the GNU General Public License along
16 # with this program. If not, see <http://www.gnu.org/licenses/>.
25 class Metadir(object):
27 self.me = os.path.basename(sys.argv[0])
30 if '.mw' in os.listdir(root):
33 (head, tail) = os.path.split(root)
35 self.root = os.getcwd()
38 self.location = os.path.join(self.root, '.mw')
39 self.config_loc = os.path.join(self.location, 'config')
40 if os.path.isdir(self.location) and \
41 os.path.isfile(self.config_loc):
42 self.config = ConfigParser.RawConfigParser()
43 self.config.read(self.config_loc)
47 def create(self, api_url):
48 # create the directory
49 if os.path.isdir(self.location):
50 print '%s: you are already in a mw repo' % self.me
53 os.mkdir(self.location, 0755)
55 fd = file(os.path.join(self.location, 'version'), 'w')
59 self.config = ConfigParser.RawConfigParser()
60 self.config.add_section('remote')
61 self.config.set('remote', 'api_url', api_url)
62 with open(self.config_loc, 'wb') as config_file:
63 self.config.write(config_file)
65 os.mkdir(os.path.join(self.location, 'cache'))
66 # create cache/pagedict
67 fd = file(os.path.join(self.location, 'cache', 'pagedict'), 'w')
68 fd.write(json.dumps({}))
71 os.mkdir(os.path.join(self.location, 'cache', 'pages'), 0755)
73 def pagedict_add(self, pagename, pageid):
74 fd = file(os.path.join(self.location, 'cache', 'pagedict'), 'r+')
75 pagedict = json.loads(fd.read())
76 pagedict[pagename] = int(pageid)
78 fd.write(json.dumps(pagedict))
82 def get_pageid_from_pagename(self, pagename):
83 fd = file(os.path.join(self.location, 'cache', 'pagedict'), 'r')
84 pagedict = json.loads(fd.read())
85 if pagename in pagedict.keys():
86 return pagedict[pagename]
90 def pages_add_rv(self, pageid, rv):
91 pagefile = os.path.join(self.location, 'cache', 'pages', str(pageid))
92 fd = file(pagefile, 'w+')
93 pagedata_raw = fd.read()
94 if pagedata_raw == '':
97 pagedata = json.loads(pagedata_raw)
98 rvid = int(rv['revid'])
100 'user': rv['user'], 'timestamp': rv['timestamp'],
104 fd.write(json.dumps(pagedata))
108 def pages_get_rv_list(self, pageid):
109 pagefile = os.path.join(self.location, 'cache', 'pages', str(pageid))
110 fd = file(pagefile, 'r')
111 pagedata = json.loads(fd.read())
112 rvs = [int(x) for x in pagedata.keys()]
116 def pages_get_rv(self, pageid, rvid):
117 pagefile = os.path.join(self.location, 'cache', 'pages', str(pageid))
118 fd = file(pagefile, 'r')
119 pagedata = json.loads(fd.read())
120 return pagedata[str(rvid)]