changes, requests for settext with long texts
This commit is contained in:
parent
d50aaa791e
commit
0f07ee8647
@ -8,6 +8,7 @@ Requirements
|
|||||||
-------------
|
-------------
|
||||||
|
|
||||||
* html5lib
|
* html5lib
|
||||||
|
* requests (settext)
|
||||||
* python-datutil, jinja2 (index subcommand)
|
* python-datutil, jinja2 (index subcommand)
|
||||||
|
|
||||||
|
|
||||||
|
@ -140,7 +140,7 @@ def main (args):
|
|||||||
else:
|
else:
|
||||||
fin = sys.stdin
|
fin = sys.stdin
|
||||||
|
|
||||||
doc = parse(fin, namespaceHTMLElements=False)
|
doc = parse(fin, treebuilder="etree", namespaceHTMLElements=False)
|
||||||
if fin != sys.stdin:
|
if fin != sys.stdin:
|
||||||
fin.close()
|
fin.close()
|
||||||
html5tidy(doc, scripts=args.script, links=links, title=args.title, indent=args.indent)
|
html5tidy(doc, scripts=args.script, links=links, title=args.title, indent=args.indent)
|
||||||
|
@ -189,7 +189,7 @@ def main (args):
|
|||||||
html = html['data']['html']
|
html = html['data']['html']
|
||||||
ver["path"] = p+".diff.html"
|
ver["path"] = p+".diff.html"
|
||||||
ver["url"] = quote(ver["path"])
|
ver["url"] = quote(ver["path"])
|
||||||
doc = html5lib.parse(html.encode("utf-8"), encoding="utf-8", namespaceHTMLElements=False)
|
doc = html5lib.parse(html.encode("utf-8"), treebuilder="etree", encoding="utf-8", namespaceHTMLElements=False)
|
||||||
html5tidy(doc, indent=True, title=padid, scripts=args.script, links=links)
|
html5tidy(doc, indent=True, title=padid, scripts=args.script, links=links)
|
||||||
with open(ver["path"], "w") as f:
|
with open(ver["path"], "w") as f:
|
||||||
# f.write(html.encode("utf-8"))
|
# f.write(html.encode("utf-8"))
|
||||||
@ -205,7 +205,7 @@ def main (args):
|
|||||||
html = html['data']['html']
|
html = html['data']['html']
|
||||||
ver["path"] = p+".raw.html"
|
ver["path"] = p+".raw.html"
|
||||||
ver["url"] = quote(ver["path"])
|
ver["url"] = quote(ver["path"])
|
||||||
doc = html5lib.parse(html, namespaceHTMLElements=False)
|
doc = html5lib.parse(html, treebuilder="etree", namespaceHTMLElements=False)
|
||||||
html5tidy(doc, indent=True, title=padid, scripts=args.script, links=links)
|
html5tidy(doc, indent=True, title=padid, scripts=args.script, links=links)
|
||||||
with open(ver["path"], "w") as f:
|
with open(ver["path"], "w") as f:
|
||||||
# f.write(html.encode("utf-8"))
|
# f.write(html.encode("utf-8"))
|
||||||
|
@ -4,16 +4,20 @@ from argparse import ArgumentParser
|
|||||||
import json, sys
|
import json, sys
|
||||||
from urllib import urlencode
|
from urllib import urlencode
|
||||||
from urllib2 import urlopen, HTTPError, URLError
|
from urllib2 import urlopen, HTTPError, URLError
|
||||||
|
import requests
|
||||||
|
|
||||||
|
|
||||||
|
LIMIT_BYTES = 100*1000
|
||||||
|
|
||||||
def main(args):
|
def main(args):
|
||||||
p = ArgumentParser("calls the getText API function for the given padid")
|
p = ArgumentParser("calls the getText API function for the given padid")
|
||||||
p.add_argument("padid", help="the padid")
|
p.add_argument("padid", help="the padid")
|
||||||
p.add_argument("--text", default=None, help="text, default: read from stdin")
|
p.add_argument("--text", default=None, help="text, default: read from stdin")
|
||||||
p.add_argument("--padinfo", default=".etherdump/settings.json", help="settings, default: .etherdump/settings.json")
|
p.add_argument("--padinfo", default=".etherdump/settings.json", help="settings, default: .etherdump/settings.json")
|
||||||
p.add_argument("--showurl", default=False, action="store_true")
|
p.add_argument("--showurl", default=False, action="store_true")
|
||||||
p.add_argument("--format", default="text", help="output format, can be: text, json; default: text")
|
# p.add_argument("--format", default="text", help="output format, can be: text, json; default: text")
|
||||||
p.add_argument("--create", default=False, action="store_true", help="flag to create pad if necessary")
|
p.add_argument("--create", default=False, action="store_true", help="flag to create pad if necessary")
|
||||||
|
p.add_argument("--limit", default=False, action="store_true", help="limit text to 100k (etherpad limit)")
|
||||||
args = p.parse_args(args)
|
args = p.parse_args(args)
|
||||||
|
|
||||||
with open(args.padinfo) as f:
|
with open(args.padinfo) as f:
|
||||||
@ -31,19 +35,26 @@ def main(args):
|
|||||||
# print json.dumps(results, indent=2)
|
# print json.dumps(results, indent=2)
|
||||||
if results['code'] != 0:
|
if results['code'] != 0:
|
||||||
createPad = True
|
createPad = True
|
||||||
|
|
||||||
if args.text:
|
if args.text:
|
||||||
text = args.text
|
text = args.text
|
||||||
else:
|
else:
|
||||||
text = sys.stdin.read()
|
text = sys.stdin.read()
|
||||||
|
|
||||||
|
if len(text) > LIMIT_BYTES and args.limit:
|
||||||
|
print "limiting", len(text), LIMIT_BYTES
|
||||||
|
text = text[:LIMIT_BYTES]
|
||||||
|
|
||||||
data['text'] = text
|
data['text'] = text
|
||||||
|
|
||||||
if createPad:
|
if createPad:
|
||||||
requesturl = apiurl+'createPad?'+urlencode(data)
|
requesturl = apiurl+'createPad'
|
||||||
else:
|
else:
|
||||||
requesturl = apiurl+'setText?'+urlencode(data)
|
requesturl = apiurl+'setText'
|
||||||
|
|
||||||
if args.showurl:
|
if args.showurl:
|
||||||
print requesturl
|
print requesturl
|
||||||
else:
|
else:
|
||||||
results = json.load(urlopen(requesturl))
|
results = requests.post(requesturl, data=data) # json.load(urlopen(requesturl))
|
||||||
|
results = json.loads(results.text)
|
||||||
print json.dumps(results, indent=2)
|
print json.dumps(results, indent=2)
|
||||||
|
Loading…
Reference in New Issue
Block a user