Michael Murtaugh
9 years ago
4 changed files with 132 additions and 38 deletions
@ -0,0 +1,17 @@ |
|||||
|
NOTES |
||||
|
====== |
||||
|
|
||||
|
23 July |
||||
|
* Add HTML diffing to dump |
||||
|
* Add indexing |
||||
|
* Make Constant DUMP public ! |
||||
|
_ _ _ |
||||
|
_____ _____ ___| | | ___ _ __ | |_ |
||||
|
/ _ \ \/ / __/ _ \ | |/ _ \ '_ \| __| |
||||
|
| __/> < (_| __/ | | __/ | | | |_ |
||||
|
\___/_/\_\___\___|_|_|\___|_| |_|\__| |
||||
|
|
||||
|
* drag and drop directory listing |
||||
|
* history via git |
||||
|
* editing in etherpad |
||||
|
* makefile based publishing scripts (pandoc for html to page / epub ?!) |
@ -1,38 +0,0 @@ |
|||||
#!/usr/bin/env python |
|
||||
from __future__ import print_function |
|
||||
from argparse import ArgumentParser |
|
||||
import json, sys |
|
||||
from urllib import urlencode |
|
||||
from urllib2 import urlopen, HTTPError, URLError |
|
||||
|
|
||||
p = ArgumentParser("") |
|
||||
p.add_argument("padid", help="the padid") |
|
||||
p.add_argument("--startrev", type=int, default=2, help="starting revision") |
|
||||
p.add_argument("--endrev", type=int, default=None, help="ending revision, default: last") |
|
||||
p.add_argument("--padinfo", default="padinfo.json", help="padinfo, default: padinfo.json") |
|
||||
p.add_argument("--dir", default="out") |
|
||||
args = p.parse_args() |
|
||||
|
|
||||
with open(args.padinfo) as f: |
|
||||
info = json.load(f) |
|
||||
apiurl = "{0[protocol]}://{0[hostname]}:{0[port]}{0[apiurl]}{0[apiversion]}/".format(info) |
|
||||
data = {} |
|
||||
data['apikey'] = info['apikey'] |
|
||||
data['padID'] = args.padid.encode("utf-8") |
|
||||
|
|
||||
|
|
||||
total_revisions = apiurl+'getRevisionsCount?'+urlencode(data) |
|
||||
total_revisions = json.load(urlopen(total_revisions))['data']['revisions'] |
|
||||
rev = args.startrev |
|
||||
print ("Dumping {0} revisions...".format(total_revisions), file=sys.stderr) |
|
||||
|
|
||||
data['startRev'] = "1" |
|
||||
while rev <= total_revisions: |
|
||||
data['endRev'] = "{0}".format(rev) |
|
||||
requesturl = apiurl+'createDiffHTML?'+urlencode(data) |
|
||||
html = json.load(urlopen(requesturl))['data']['html'] |
|
||||
out = "{0}/{1}_{2:06d}.html".format(args.dir, args.padid, rev) |
|
||||
print ("writing {0}".format(out), file=sys.stderr) |
|
||||
with open(out, "w") as f: |
|
||||
f.write(html.encode("utf-8")) |
|
||||
rev += 1 |
|
@ -0,0 +1,32 @@ |
|||||
|
#!/usr/bin/env python |
||||
|
|
||||
|
from argparse import ArgumentParser |
||||
|
import json |
||||
|
from urllib import urlencode |
||||
|
from urllib2 import urlopen, HTTPError, URLError |
||||
|
|
||||
|
p = ArgumentParser("") |
||||
|
p.add_argument("padid", help="the padid") |
||||
|
p.add_argument("--padinfo", default="padinfo.json", help="padinfo, default: padinfo.json") |
||||
|
p.add_argument("--showurl", default=False, action="store_true") |
||||
|
p.add_argument("--text", default=False, action="store_true", help="text output (not json)") |
||||
|
args = p.parse_args() |
||||
|
|
||||
|
with open(args.padinfo) as f: |
||||
|
info = json.load(f) |
||||
|
apiurl = "{0[protocol]}://{0[hostname]}:{0[port]}{0[apiurl]}{0[apiversion]}/".format(info) |
||||
|
data = {} |
||||
|
data['apikey'] = info['apikey'] |
||||
|
data['padID'] = args.padid.encode("utf-8") |
||||
|
requesturl = apiurl+'getText?'+urlencode(data) |
||||
|
if args.showurl: |
||||
|
print requesturl |
||||
|
else: |
||||
|
results = json.load(urlopen(requesturl))['data'] |
||||
|
if args.text: |
||||
|
print results['data'].encode("utf-8") |
||||
|
else: |
||||
|
print json.dump(results) |
||||
|
|
||||
|
# To save to file run: |
||||
|
# python gettext.py > copy.txt |
@ -0,0 +1,83 @@ |
|||||
|
import json |
||||
|
from urllib2 import urlopen, HTTPError, URLError |
||||
|
from urllib import urlencode |
||||
|
|
||||
|
class PadServer (object): |
||||
|
def __init__ (self, hostname, port=9001, apipath="/api/", apiversion="1.2.9", apikey=None, secure=False): |
||||
|
self.hostname = hostname |
||||
|
if secure: |
||||
|
self.protocol = "https" |
||||
|
else: |
||||
|
self.protocol = "http" |
||||
|
|
||||
|
self.apiurl = self.protocol+"://"+hostname |
||||
|
if port: |
||||
|
self.apiurl += ":{0}".format(port) |
||||
|
self.apiurl += "{0}{1}/".format(apipath, apiversion) |
||||
|
self.apikey = apikey |
||||
|
|
||||
|
def listAllPads (self): |
||||
|
data = {'apikey': self.apikey} |
||||
|
url = self.apiurl+'listAllPads?'+urlencode(data) |
||||
|
return json.load(urlopen(url))['data']['padIDs'] |
||||
|
|
||||
|
def listAllGroups (self): |
||||
|
data = {'apikey': self.apikey} |
||||
|
url = self.apiurl+'listAllGroups?'+urlencode(data) |
||||
|
return json.load(urlopen(url))['data']['groupIDs'] |
||||
|
|
||||
|
def getPadText (self, padID): |
||||
|
data = {'apikey': self.apikey, 'padID': padID.encode("utf-8")} |
||||
|
return json.load(urlopen(self.apiurl+'getText?'+urlencode(data)))['data']['text'] |
||||
|
|
||||
|
def getPadHTML (self, padID): |
||||
|
data = {'apikey': self.apikey, 'padID': padID.encode("utf-8")} |
||||
|
return json.load(urlopen(self.apiurl+'getHTML?'+urlencode(data)))['data']['html'] |
||||
|
|
||||
|
def getPadLastEdited (self, padID): |
||||
|
data = {'apikey': self.apikey, 'padID': padID.encode("utf-8")} |
||||
|
raw = json.load(urlopen(self.apiurl+'getLastEdited?'+urlencode(data)))['data']['lastEdited'] |
||||
|
try: |
||||
|
return datetime.fromtimestamp(int(raw)/1000) |
||||
|
except TypeError as e: |
||||
|
return None |
||||
|
|
||||
|
def getPadURL (self, padID, groupinfo=None): |
||||
|
group, name = pad_split_group(padID) |
||||
|
if group: |
||||
|
gid = group |
||||
|
if gid.startswith("g."): |
||||
|
gid = gid[2:] |
||||
|
if groupinfo: |
||||
|
ginfo = groupinfo.get(gid) |
||||
|
if ginfo: |
||||
|
groupID = ginfo.get("id", 0) |
||||
|
else: |
||||
|
groupID = 0 |
||||
|
else: |
||||
|
groupID = 0 |
||||
|
return self.protocol+"://"+self.hostname+"/group.html/"+str(groupID)+"/pad.html/"+padID |
||||
|
else: |
||||
|
return self.protocol+"://"+self.hostname+"/public_pad/"+padID |
||||
|
|
||||
|
def getRevisionsCount (self, padID): |
||||
|
data = {'apikey': self.apikey, 'padID': padID.encode("utf-8")} |
||||
|
raw = json.load(urlopen(self.apiurl+'getRevisionsCount?'+urlencode(data)))['data']['revisions'] |
||||
|
return int(raw) |
||||
|
|
||||
|
def listAuthorsOfPad (self, padID): |
||||
|
data = {'apikey': self.apikey, 'padID': padID.encode("utf-8")} |
||||
|
raw = json.load(urlopen(self.apiurl+'listAuthorsOfPad?'+urlencode(data)))['data']['authorIDs'] |
||||
|
return raw |
||||
|
|
||||
|
def getRevisionChangeset (self, padID, rev=None): |
||||
|
data = {'apikey': self.apikey, 'padID': padID.encode("utf-8"), 'rev': "{0}".format(rev)} |
||||
|
raw = json.load(urlopen(self.apiurl+'getRevisionChangeset?'+urlencode(data))) |
||||
|
return raw |
||||
|
|
||||
|
def createDiffHTML (self, padID, startRev=0, endRev=None): |
||||
|
if endRev == None: |
||||
|
endRev = getRevisionsCount(self, padID) |
||||
|
data = {'apikey': self.apikey, 'padID': padID.encode("utf-8"), 'startRev': "{0}".format(startRev), 'endRev': "{0}".format(endRev)} |
||||
|
raw = json.load(urlopen(self.apiurl+'createDiffHTML?'+urlencode(data)))['data'] |
||||
|
return raw |
Loading…
Reference in new issue