Merge branch 'migrate-to-python3' of decentral1se/etherpump into master
This commit is contained in:
commit
64b16ba5a3
1
.gitignore
vendored
1
.gitignore
vendored
@ -5,3 +5,4 @@ venv/
|
|||||||
testing/
|
testing/
|
||||||
padinfo.json
|
padinfo.json
|
||||||
.etherpump
|
.etherpump
|
||||||
|
*egg-info*
|
||||||
|
91
README.md
91
README.md
@ -8,10 +8,9 @@ A command-line utility that extends the multi writing and publishing functionali
|
|||||||
Many pads, many networks
|
Many pads, many networks
|
||||||
------------------------
|
------------------------
|
||||||
|
|
||||||
*Etherpump* is a fork of [*etherdump*](https://gitlab.constantvzw.org/aa/etherdump), a command line tool written by [Michael Murtaugh](http://automatist.org/) that converts etherpad pages to files. This fork is made out of curiosities in the tool, a wish to study it and shared sparks of enthusiasm to use it in different situations within Varia.
|
*Etherpump* is a fork of [*etherpump*](https://gitlab.constantvzw.org/aa/etherpump), a command line tool written by [Michael Murtaugh](http://automatist.org/) that converts etherpad pages to files. This fork is made out of curiosities in the tool, a wish to study it and shared sparks of enthusiasm to use it in different situations within Varia.
|
||||||
|
|
||||||
Etherpump is a stretched version of etherdump. It is a playground in which we would like to add features to the initial tool that diffuse actions of *dumping* into *pumping*. So most of all, etherpump is a work-in-progress, exploring potential uses of etherpads to edit, structure and publish various types of content.
|
|
||||||
|
|
||||||
|
Etherpump is a stretched version of etherpump. It is a playground in which we would like to add features to the initial tool that diffuse actions of *dumping* into *pumping*. So most of all, etherpump is a work-in-progress, exploring potential uses of etherpads to edit, structure and publish various types of content.
|
||||||
Added features are:
|
Added features are:
|
||||||
|
|
||||||
* opt-in publishing with the `__PUBLISH__` magic word
|
* opt-in publishing with the `__PUBLISH__` magic word
|
||||||
@ -19,27 +18,28 @@ Added features are:
|
|||||||
|
|
||||||
See the [Change log / notes ](#change-log--notes) section for further changes.
|
See the [Change log / notes ](#change-log--notes) section for further changes.
|
||||||
|
|
||||||
Etherdump is a tool that is used from the command line. It dumps all pads of one etherpad installation to a folder, saving them as different text files, such as plain text and HTML. It also creates an index file, that allows one to easily navigate through the list of pads. Etherdump follows a document-driven idea of publishing, which means that it converts pads as database entries into pads as files. This seems to be a redundant act of copying, but is actually an important in-between step that allows for many different publishing projects and experiments.
|
etherpump is a tool that is used from the command line. It dumps all pads of one etherpad installation to a folder, saving them as different text files, such as plain text and HTML. It also creates an index file, that allows one to easily navigate through the list of pads. etherpump follows a document-driven idea of publishing, which means that it converts pads as database entries into pads as files. This seems to be a redundant act of copying, but is actually an important in-between step that allows for many different publishing projects and experiments.
|
||||||
|
|
||||||
We started to get to know etherdump through various editions of Relearn and/or the worksessions organized by Constant. Collaborative writing on an etherpad has been an important ingredient for these situations. The habit of using pads branched into the day-to-day practice of Varia, where we use etherpads for all sorts of things, ranging from organising remote-meetings with 10+ people, to writing and designing PDF documents collaboratively.
|
We started to get to know etherpump through various editions of Relearn and/or the worksessions organized by Constant. Collaborative writing on an etherpad has been an important ingredient for these situations. The habit of using pads branched into the day-to-day practice of Varia, where we use etherpads for all sorts of things, ranging from organising remote-meetings with 10+ people, to writing and designing PDF documents collaboratively.
|
||||||
|
|
||||||
After installing etherdump on the Varia server, we collectively decided to not want to publish pads by default. Discussions in the group around the use of etherpads, privacy and ideas of what publishing means, led to a need to have etherdump only start the indexing work after it recognizes a `__PUBLISH__` marker on a pad. We decided to work on a `__PUBLISH__ vs. __NOPUBLISH__` branch of etherdump, which we now fork into **etherpump**.
|
|
||||||
|
|
||||||
|
After installing etherpump on the Varia server, we collectively decided to not want to publish pads by default. Discussions in the group around the use of etherpads, privacy and ideas of what publishing means, led to a need to have etherpump only start the indexing work after it recognizes a `__PUBLISH__` marker on a pad. We decided to work on a `__PUBLISH__ vs. __NOPUBLISH__` branch of etherpump, which we now fork into **etherpump**.
|
||||||
|
|
||||||
Change log / notes
|
Change log / notes
|
||||||
==================
|
==================
|
||||||
|
|
||||||
**September 2019**
|
**September 2019**
|
||||||
|
|
||||||
Forking *etherdump* into *etherpump*. (Work in progress!)
|
Forking *etherpump* into *etherpump*. (Work in progress!)
|
||||||
|
|
||||||
<https://git.vvvvvvaria.org/varia/etherpump>
|
<https://git.vvvvvvaria.org/varia/etherpump>
|
||||||
|
|
||||||
|
Migrating the source code to Python 3.
|
||||||
|
|
||||||
-----
|
-----
|
||||||
|
|
||||||
**May - September 2019**
|
**May - September 2019**
|
||||||
|
|
||||||
Etherdump is used to produce the *Ruminating Relearn* section of the Network Of One's Own 2 (NOOO2) publication.
|
etherpump is used to produce the *Ruminating Relearn* section of the Network Of One's Own 2 (NOOO2) publication.
|
||||||
|
|
||||||
A new command is added to make a web publication, based on the custom magic word `__RELEARN__`.
|
A new command is added to make a web publication, based on the custom magic word `__RELEARN__`.
|
||||||
|
|
||||||
@ -47,7 +47,7 @@ A new command is added to make a web publication, based on the custom magic word
|
|||||||
|
|
||||||
**June 2019**
|
**June 2019**
|
||||||
|
|
||||||
Multiple conversations around etherdump emerged during Relearn Curved in Varia, Rotterdam.
|
Multiple conversations around etherpump emerged during Relearn Curved in Varia, Rotterdam.
|
||||||
|
|
||||||
Including the idea of executable pads (*etherhooks*), custom magic words, a federated snippet protocol (*etherstekje*) and more.
|
Including the idea of executable pads (*etherhooks*), custom magic words, a federated snippet protocol (*etherstekje*) and more.
|
||||||
|
|
||||||
@ -57,94 +57,67 @@ Including the idea of executable pads (*etherhooks*), custom magic words, a fede
|
|||||||
|
|
||||||
**April 2019**
|
**April 2019**
|
||||||
|
|
||||||
Installation of etherdump on the Varia server.
|
Installation of etherpump on the Varia server.
|
||||||
|
|
||||||
<https://etherdump.vvvvvvaria.org/>
|
<https://etherpump.vvvvvvaria.org/>
|
||||||
|
|
||||||
-----
|
-----
|
||||||
|
|
||||||
**March 2019**
|
**March 2019**
|
||||||
|
|
||||||
The `__PUBLISH__ vs. __NOPUBLISH__` was added to the etherdump repository by *decentral1se*.
|
The `__PUBLISH__ vs. __NOPUBLISH__` was added to the etherpump repository by *decentral1se*.
|
||||||
|
|
||||||
<https://gitlab.constantvzw.org/aa/etherdump/issues/3>
|
<https://gitlab.constantvzw.org/aa/etherpump/issues/3>
|
||||||
|
|
||||||
-----
|
-----
|
||||||
|
|
||||||
Originally designed for use at: [Constant](http://etherdump.constantvzw.org/).
|
Originally designed for use at: [Constant](http://etherpump.constantvzw.org/).
|
||||||
|
|
||||||
More notes can be found in the [git repository of etherdump](https://gitlab.constantvzw.org/aa/etherdump).
|
More notes can be found in the [git repository of etherpump](https://gitlab.constantvzw.org/aa/etherpump).
|
||||||
|
|
||||||
|
|
||||||
Install etherpump
|
Install etherpump
|
||||||
=================
|
=================
|
||||||
|
|
||||||
Requirements
|
`$ pip install etherpump`
|
||||||
-------------
|
|
||||||
|
|
||||||
* python3
|
Etherpump only supports Python 3.
|
||||||
* html5lib
|
|
||||||
* requests (settext)
|
|
||||||
* python-dateutil, jinja2 (used by the index subcommand)
|
|
||||||
|
|
||||||
Installation
|
|
||||||
-------------
|
|
||||||
|
|
||||||
`$ pip install python-dateutil jinja2 html5lib`
|
|
||||||
|
|
||||||
`$ python setup.py install`
|
|
||||||
|
|
||||||
Example
|
Example
|
||||||
---------------
|
-------
|
||||||
|
|
||||||
```
|
```
|
||||||
$ mkdir mydump
|
$ mkdir mydump
|
||||||
$ cd myddump
|
$ cd myddump
|
||||||
$ etherdump init
|
$ etherpump init
|
||||||
|
|
||||||
```
|
```
|
||||||
|
|
||||||
The program then interactively asks some questions:
|
The program then interactively asks some questions:
|
||||||
|
|
||||||
```
|
> Please type the URL of the etherpad:
|
||||||
Please type the URL of the etherpad:
|
> https://pad.vvvvvvaria.org/
|
||||||
|
|
||||||
https://pad.vvvvvvaria.org/
|
|
||||||
```
|
|
||||||
|
|
||||||
The APIKEY is the contents of the file APIKEY.txt in the etherpad folder.
|
The APIKEY is the contents of the file APIKEY.txt in the etherpad folder.
|
||||||
|
|
||||||
```
|
> Please paste the APIKEY:
|
||||||
Please paste the APIKEY:
|
> xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
|
||||||
|
|
||||||
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
|
The settings are placed in a file called `.etherpump/settings.json` and are used (by default) by future commands.
|
||||||
```
|
|
||||||
|
|
||||||
The settings are placed in a file called `.etherdump/settings.json` and are used (by default) by future commands.
|
|
||||||
|
|
||||||
Subcommands
|
Subcommands
|
||||||
----------
|
----------
|
||||||
|
|
||||||
* init
|
To see all available subcommands, run:
|
||||||
* pull
|
|
||||||
* list
|
|
||||||
* listauthors
|
|
||||||
* gettext
|
|
||||||
* settext
|
|
||||||
* gethtml
|
|
||||||
* creatediffhtml
|
|
||||||
* revisionscount
|
|
||||||
* index
|
|
||||||
* deletepad
|
|
||||||
* publication (*etherpump*)
|
|
||||||
|
|
||||||
To get help on a subcommand:
|
`$ etherpump --help`
|
||||||
|
|
||||||
`$ etherdump revisionscount --help`
|
For help on each individual subcommand, run:
|
||||||
|
|
||||||
|
`$ etherpump revisionscount --help`
|
||||||
|
|
||||||
License
|
License
|
||||||
=======
|
=======
|
||||||
|
|
||||||
GNU AFFERO GENERAL PUBLIC LICENSE, Version 3
|
GNU AFFERO GENERAL PUBLIC LICENSE, Version 3.
|
||||||
|
|
||||||
See `License.txt`
|
See [LICENSE.txt](./LICENSE.txt).
|
||||||
|
@ -1,10 +0,0 @@
|
|||||||
Metadata-Version: 1.0
|
|
||||||
Name: etherpump
|
|
||||||
Version: 0.0.1
|
|
||||||
Summary: Etherpump an etherpad publishing system
|
|
||||||
Home-page: https://git.vvvvvvaria.org/varia/etherpump
|
|
||||||
Author: Varia members
|
|
||||||
Author-email: info@varia.zone
|
|
||||||
License: LICENSE.txt
|
|
||||||
Description: UNKNOWN
|
|
||||||
Platform: UNKNOWN
|
|
@ -1,35 +0,0 @@
|
|||||||
README.md
|
|
||||||
setup.py
|
|
||||||
bin/etherpump
|
|
||||||
etherpump/__init__.py
|
|
||||||
etherpump.egg-info/PKG-INFO
|
|
||||||
etherpump.egg-info/SOURCES.txt
|
|
||||||
etherpump.egg-info/dependency_links.txt
|
|
||||||
etherpump.egg-info/requires.txt
|
|
||||||
etherpump.egg-info/top_level.txt
|
|
||||||
etherpump/commands/__init__.py
|
|
||||||
etherpump/commands/appendmeta.py
|
|
||||||
etherpump/commands/common.py
|
|
||||||
etherpump/commands/creatediffhtml.py
|
|
||||||
etherpump/commands/deletepad.py
|
|
||||||
etherpump/commands/dumpcsv.py
|
|
||||||
etherpump/commands/gethtml.py
|
|
||||||
etherpump/commands/gettext.py
|
|
||||||
etherpump/commands/html5tidy.py
|
|
||||||
etherpump/commands/index.py
|
|
||||||
etherpump/commands/init.py
|
|
||||||
etherpump/commands/join.py
|
|
||||||
etherpump/commands/list.py
|
|
||||||
etherpump/commands/listauthors.py
|
|
||||||
etherpump/commands/publication.py
|
|
||||||
etherpump/commands/pull.py
|
|
||||||
etherpump/commands/revisionscount.py
|
|
||||||
etherpump/commands/sethtml.py
|
|
||||||
etherpump/commands/settext.py
|
|
||||||
etherpump/commands/showmeta.py
|
|
||||||
etherpump/commands/status.py
|
|
||||||
etherpump/data/templates/index.html
|
|
||||||
etherpump/data/templates/pad.html
|
|
||||||
etherpump/data/templates/pad_colors.html
|
|
||||||
etherpump/data/templates/pad_index.html
|
|
||||||
etherpump/data/templates/rss.xml
|
|
@ -1 +0,0 @@
|
|||||||
|
|
@ -1,2 +0,0 @@
|
|||||||
html5lib
|
|
||||||
jinja2
|
|
@ -1 +0,0 @@
|
|||||||
etherpump
|
|
@ -1,6 +1,6 @@
|
|||||||
#!/usr/bin/env python
|
#!/usr/bin/env python
|
||||||
|
|
||||||
from __future__ import print_function
|
|
||||||
from argparse import ArgumentParser
|
from argparse import ArgumentParser
|
||||||
import json, os
|
import json, os
|
||||||
|
|
||||||
|
@ -1,15 +1,16 @@
|
|||||||
from __future__ import print_function
|
|
||||||
import re, os, json, sys
|
import re, os, json, sys
|
||||||
from math import ceil, floor
|
from math import ceil, floor
|
||||||
from time import sleep
|
from time import sleep
|
||||||
|
|
||||||
try:
|
try:
|
||||||
# python2
|
# python2
|
||||||
from urlparse import urlparse, urlunparse
|
from urllib.parse import urlparse, urlunparse
|
||||||
from urllib2 import urlopen, URLError, HTTPError
|
from urllib.request import urlopen
|
||||||
from urllib import urlencode
|
from urllib.error import URLError, HTTPError
|
||||||
from urllib import quote_plus, unquote_plus
|
from urllib.parse import urlencode
|
||||||
from htmlentitydefs import name2codepoint
|
from urllib.parse import quote_plus, unquote_plus
|
||||||
|
from html.entities import name2codepoint
|
||||||
|
|
||||||
input = raw_input
|
input = raw_input
|
||||||
except ImportError:
|
except ImportError:
|
||||||
@ -24,12 +25,12 @@ def splitpadname (padid):
|
|||||||
if m:
|
if m:
|
||||||
return(m.group(1), padid[m.end():])
|
return(m.group(1), padid[m.end():])
|
||||||
else:
|
else:
|
||||||
return (u"", padid)
|
return ("", padid)
|
||||||
|
|
||||||
def padurl (padid, ):
|
def padurl (padid, ):
|
||||||
return padid
|
return padid
|
||||||
|
|
||||||
def padpath (padid, pub_path=u"", group_path=u"", normalize=False):
|
def padpath (padid, pub_path="", group_path="", normalize=False):
|
||||||
g, p = splitpadname(padid)
|
g, p = splitpadname(padid)
|
||||||
# if type(g) == unicode:
|
# if type(g) == unicode:
|
||||||
# g = g.encode("utf-8")
|
# g = g.encode("utf-8")
|
||||||
@ -48,7 +49,7 @@ def padpath (padid, pub_path=u"", group_path=u"", normalize=False):
|
|||||||
return os.path.join(pub_path, p)
|
return os.path.join(pub_path, p)
|
||||||
|
|
||||||
def padpath2id (path):
|
def padpath2id (path):
|
||||||
if type(path) == unicode:
|
if type(path) == str:
|
||||||
path = path.encode("utf-8")
|
path = path.encode("utf-8")
|
||||||
dd, p = os.path.split(path)
|
dd, p = os.path.split(path)
|
||||||
gname = dd.split("/")[-1]
|
gname = dd.split("/")[-1]
|
||||||
@ -95,7 +96,7 @@ def progressbar (i, num, label="", file=sys.stderr):
|
|||||||
percentage = int(floor(p*100))
|
percentage = int(floor(p*100))
|
||||||
bars = int(ceil(p*20))
|
bars = int(ceil(p*20))
|
||||||
bar = ("*"*bars) + ("-"*(20-bars))
|
bar = ("*"*bars) + ("-"*(20-bars))
|
||||||
msg = u"\r{0} {1}/{2} {3}... ".format(bar, (i+1), num, label)
|
msg = "\r{0} {1}/{2} {3}... ".format(bar, (i+1), num, label)
|
||||||
sys.stderr.write(msg)
|
sys.stderr.write(msg)
|
||||||
sys.stderr.flush()
|
sys.stderr.flush()
|
||||||
|
|
||||||
@ -114,15 +115,15 @@ def unescape(text):
|
|||||||
# character reference
|
# character reference
|
||||||
try:
|
try:
|
||||||
if text[:3] == "&#x":
|
if text[:3] == "&#x":
|
||||||
return unichr(int(text[3:-1], 16))
|
return chr(int(text[3:-1], 16))
|
||||||
else:
|
else:
|
||||||
return unichr(int(text[2:-1]))
|
return chr(int(text[2:-1]))
|
||||||
except ValueError:
|
except ValueError:
|
||||||
pass
|
pass
|
||||||
else:
|
else:
|
||||||
# named entity
|
# named entity
|
||||||
try:
|
try:
|
||||||
text = unichr(name2codepoint[text[1:-1]])
|
text = chr(name2codepoint[text[1:-1]])
|
||||||
except KeyError:
|
except KeyError:
|
||||||
pass
|
pass
|
||||||
return text # leave as is
|
return text # leave as is
|
||||||
|
@ -1,8 +1,9 @@
|
|||||||
from __future__ import print_function
|
|
||||||
from argparse import ArgumentParser
|
from argparse import ArgumentParser
|
||||||
import json
|
import json
|
||||||
from urllib import urlencode
|
from urllib.parse import urlencode
|
||||||
from urllib2 import urlopen, HTTPError, URLError
|
from urllib.request import urlopen
|
||||||
|
from urllib.error import HTTPError, URLError
|
||||||
|
|
||||||
|
|
||||||
def main(args):
|
def main(args):
|
||||||
|
@ -1,8 +1,9 @@
|
|||||||
from __future__ import print_function
|
|
||||||
from argparse import ArgumentParser
|
from argparse import ArgumentParser
|
||||||
import json
|
import json
|
||||||
from urllib import urlencode
|
from urllib.parse import urlencode
|
||||||
from urllib2 import urlopen, HTTPError, URLError
|
from urllib.request import urlopen
|
||||||
|
from urllib.error import HTTPError, URLError
|
||||||
|
|
||||||
|
|
||||||
def main(args):
|
def main(args):
|
||||||
|
@ -1,9 +1,10 @@
|
|||||||
from __future__ import print_function
|
|
||||||
from argparse import ArgumentParser
|
from argparse import ArgumentParser
|
||||||
import sys, json, re
|
import sys, json, re
|
||||||
from datetime import datetime
|
from datetime import datetime
|
||||||
from urllib import urlencode
|
from urllib.parse import urlencode
|
||||||
from urllib2 import urlopen, HTTPError, URLError
|
from urllib.request import urlopen
|
||||||
|
from urllib.error import HTTPError, URLError
|
||||||
from csv import writer
|
from csv import writer
|
||||||
from math import ceil, floor
|
from math import ceil, floor
|
||||||
|
|
||||||
@ -52,7 +53,7 @@ def main (args):
|
|||||||
percentage = int(floor(p*100))
|
percentage = int(floor(p*100))
|
||||||
bars = int(ceil(p*20))
|
bars = int(ceil(p*20))
|
||||||
bar = ("*"*bars) + ("-"*(20-bars))
|
bar = ("*"*bars) + ("-"*(20-bars))
|
||||||
msg = u"\r{0} {1}/{2} {3}... ".format(bar, (i+1), numpads, padid)
|
msg = "\r{0} {1}/{2} {3}... ".format(bar, (i+1), numpads, padid)
|
||||||
if len(msg) > maxmsglen:
|
if len(msg) > maxmsglen:
|
||||||
maxmsglen = len(msg)
|
maxmsglen = len(msg)
|
||||||
sys.stderr.write("\r{0}".format(" "*maxmsglen))
|
sys.stderr.write("\r{0}".format(" "*maxmsglen))
|
||||||
@ -63,7 +64,7 @@ def main (args):
|
|||||||
groupname = m.group(1)
|
groupname = m.group(1)
|
||||||
padidnogroup = padid[m.end():]
|
padidnogroup = padid[m.end():]
|
||||||
else:
|
else:
|
||||||
groupname = u""
|
groupname = ""
|
||||||
padidnogroup = padid
|
padidnogroup = padid
|
||||||
|
|
||||||
data['padID'] = padid.encode("utf-8")
|
data['padID'] = padid.encode("utf-8")
|
||||||
@ -75,7 +76,7 @@ def main (args):
|
|||||||
lastedited_raw = jsonload(apiurl+'getLastEdited?'+urlencode(data))['data']['lastEdited']
|
lastedited_raw = jsonload(apiurl+'getLastEdited?'+urlencode(data))['data']['lastEdited']
|
||||||
lastedited_iso = datetime.fromtimestamp(int(lastedited_raw)/1000).isoformat()
|
lastedited_iso = datetime.fromtimestamp(int(lastedited_raw)/1000).isoformat()
|
||||||
author_ids = jsonload(apiurl+'listAuthorsOfPad?'+urlencode(data))['data']['authorIDs']
|
author_ids = jsonload(apiurl+'listAuthorsOfPad?'+urlencode(data))['data']['authorIDs']
|
||||||
author_ids = u" ".join(author_ids).encode("utf-8")
|
author_ids = " ".join(author_ids).encode("utf-8")
|
||||||
out.writerow((padidnogroup.encode("utf-8"), groupname.encode("utf-8"), revisions, lastedited_iso, author_ids))
|
out.writerow((padidnogroup.encode("utf-8"), groupname.encode("utf-8"), revisions, lastedited_iso, author_ids))
|
||||||
count += 1
|
count += 1
|
||||||
|
|
||||||
|
@ -1,8 +1,9 @@
|
|||||||
from __future__ import print_function
|
|
||||||
from argparse import ArgumentParser
|
from argparse import ArgumentParser
|
||||||
import json
|
import json
|
||||||
from urllib import urlencode
|
from urllib.parse import urlencode
|
||||||
from urllib2 import urlopen, HTTPError, URLError
|
from urllib.request import urlopen
|
||||||
|
from urllib.error import HTTPError, URLError
|
||||||
|
|
||||||
|
|
||||||
def main(args):
|
def main(args):
|
||||||
|
@ -1,10 +1,11 @@
|
|||||||
from __future__ import print_function
|
|
||||||
from argparse import ArgumentParser
|
from argparse import ArgumentParser
|
||||||
import json, sys
|
import json, sys
|
||||||
try:
|
try:
|
||||||
# python2
|
# python2
|
||||||
from urllib2 import urlopen, URLError, HTTPError
|
from urllib.request import urlopen
|
||||||
from urllib import urlencode
|
from urllib.error import URLError, HTTPError
|
||||||
|
from urllib.parse import urlencode
|
||||||
except ImportError:
|
except ImportError:
|
||||||
# python3
|
# python3
|
||||||
from urllib.parse import urlencode
|
from urllib.parse import urlencode
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
#!/usr/bin/env python3
|
#!/usr/bin/env python3
|
||||||
|
|
||||||
from __future__ import print_function
|
|
||||||
from html5lib import parse
|
from html5lib import parse
|
||||||
import os, sys
|
import os, sys
|
||||||
from argparse import ArgumentParser
|
from argparse import ArgumentParser
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
from __future__ import print_function
|
|
||||||
from argparse import ArgumentParser
|
from argparse import ArgumentParser
|
||||||
import sys, json, re, os, time
|
import sys, json, re, os, time
|
||||||
from datetime import datetime
|
from datetime import datetime
|
||||||
@ -6,9 +6,10 @@ import dateutil.parser
|
|||||||
|
|
||||||
try:
|
try:
|
||||||
# python2
|
# python2
|
||||||
from urllib2 import urlopen, URLError, HTTPError
|
from urllib.request import urlopen
|
||||||
from urllib import urlencode
|
from urllib.error import URLError, HTTPError
|
||||||
from urlparse import urlparse, urlunparse
|
from urllib.parse import urlencode
|
||||||
|
from urllib.parse import urlparse, urlunparse
|
||||||
except ImportError:
|
except ImportError:
|
||||||
# python3
|
# python3
|
||||||
from urllib.parse import urlparse, urlunparse, urlencode, quote
|
from urllib.parse import urlparse, urlunparse, urlencode, quote
|
||||||
@ -182,9 +183,9 @@ def main (args):
|
|||||||
padmeta["lastedited_822"] = d.strftime("%a, %d %b %Y %H:%M:%S +0000")
|
padmeta["lastedited_822"] = d.strftime("%a, %d %b %Y %H:%M:%S +0000")
|
||||||
return padmeta
|
return padmeta
|
||||||
|
|
||||||
pads = map(loadmeta, inputs)
|
pads = list(map(loadmeta, inputs))
|
||||||
pads = [x for x in pads if x != None]
|
pads = [x for x in pads if x != None]
|
||||||
pads = map(fixdates, pads)
|
pads = list(map(fixdates, pads))
|
||||||
args.pads = list(pads)
|
args.pads = list(pads)
|
||||||
|
|
||||||
def could_have_base (x, y):
|
def could_have_base (x, y):
|
||||||
|
@ -1,11 +1,12 @@
|
|||||||
from __future__ import print_function
|
|
||||||
from argparse import ArgumentParser
|
from argparse import ArgumentParser
|
||||||
|
|
||||||
try:
|
try:
|
||||||
# python2
|
# python2
|
||||||
from urlparse import urlparse, urlunparse
|
from urllib.parse import urlparse, urlunparse
|
||||||
from urllib2 import urlopen, URLError, HTTPError
|
from urllib.request import urlopen
|
||||||
from urllib import urlencode
|
from urllib.error import URLError, HTTPError
|
||||||
|
from urllib.parse import urlencode
|
||||||
input = raw_input
|
input = raw_input
|
||||||
except ImportError:
|
except ImportError:
|
||||||
# python3
|
# python3
|
||||||
|
@ -1,8 +1,9 @@
|
|||||||
from __future__ import print_function
|
|
||||||
from argparse import ArgumentParser
|
from argparse import ArgumentParser
|
||||||
import json, os, re
|
import json, os, re
|
||||||
from urllib import urlencode
|
from urllib.parse import urlencode
|
||||||
from urllib2 import urlopen, HTTPError, URLError
|
from urllib.request import urlopen
|
||||||
|
from urllib.error import HTTPError, URLError
|
||||||
|
|
||||||
def group (items, key=lambda x: x):
|
def group (items, key=lambda x: x):
|
||||||
ret = []
|
ret = []
|
||||||
|
@ -1,13 +1,14 @@
|
|||||||
from __future__ import print_function
|
|
||||||
from argparse import ArgumentParser
|
from argparse import ArgumentParser
|
||||||
import json
|
import json
|
||||||
import sys
|
import sys
|
||||||
from etherpump.commands.common import getjson
|
from etherpump.commands.common import getjson
|
||||||
try:
|
try:
|
||||||
# python2
|
# python2
|
||||||
from urlparse import urlparse, urlunparse
|
from urllib.parse import urlparse, urlunparse
|
||||||
from urllib2 import urlopen, URLError, HTTPError
|
from urllib.request import urlopen
|
||||||
from urllib import urlencode
|
from urllib.error import URLError, HTTPError
|
||||||
|
from urllib.parse import urlencode
|
||||||
input = raw_input
|
input = raw_input
|
||||||
except ImportError:
|
except ImportError:
|
||||||
# python3
|
# python3
|
||||||
|
@ -1,8 +1,9 @@
|
|||||||
from __future__ import print_function
|
|
||||||
from argparse import ArgumentParser
|
from argparse import ArgumentParser
|
||||||
import json
|
import json
|
||||||
from urllib import urlencode
|
from urllib.parse import urlencode
|
||||||
from urllib2 import urlopen, HTTPError, URLError
|
from urllib.request import urlopen
|
||||||
|
from urllib.error import HTTPError, URLError
|
||||||
|
|
||||||
|
|
||||||
def main(args):
|
def main(args):
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
from __future__ import print_function
|
|
||||||
from argparse import ArgumentParser
|
from argparse import ArgumentParser
|
||||||
import sys, json, re, os, time
|
import sys, json, re, os, time
|
||||||
from datetime import datetime
|
from datetime import datetime
|
||||||
@ -7,9 +7,10 @@ import pypandoc
|
|||||||
|
|
||||||
try:
|
try:
|
||||||
# python2
|
# python2
|
||||||
from urllib2 import urlopen, URLError, HTTPError
|
from urllib.request import urlopen
|
||||||
from urllib import urlencode
|
from urllib.error import URLError, HTTPError
|
||||||
from urlparse import urlparse, urlunparse
|
from urllib.parse import urlencode
|
||||||
|
from urllib.parse import urlparse, urlunparse
|
||||||
except ImportError:
|
except ImportError:
|
||||||
# python3
|
# python3
|
||||||
from urllib.parse import urlparse, urlunparse, urlencode, quote
|
from urllib.parse import urlparse, urlunparse, urlencode, quote
|
||||||
@ -183,9 +184,9 @@ def main (args):
|
|||||||
padmeta["lastedited_822"] = d.strftime("%a, %d %b %Y %H:%M:%S +0000")
|
padmeta["lastedited_822"] = d.strftime("%a, %d %b %Y %H:%M:%S +0000")
|
||||||
return padmeta
|
return padmeta
|
||||||
|
|
||||||
pads = map(loadmeta, inputs)
|
pads = list(map(loadmeta, inputs))
|
||||||
pads = [x for x in pads if x != None]
|
pads = [x for x in pads if x != None]
|
||||||
pads = map(fixdates, pads)
|
pads = list(map(fixdates, pads))
|
||||||
args.pads = list(pads)
|
args.pads = list(pads)
|
||||||
|
|
||||||
def could_have_base (x, y):
|
def could_have_base (x, y):
|
||||||
|
@ -1,12 +1,13 @@
|
|||||||
from __future__ import print_function
|
|
||||||
from argparse import ArgumentParser
|
from argparse import ArgumentParser
|
||||||
import sys, json, re, os
|
import sys, json, re, os
|
||||||
from datetime import datetime
|
from datetime import datetime
|
||||||
|
|
||||||
try:
|
try:
|
||||||
# python2
|
# python2
|
||||||
from urllib2 import urlopen, URLError, HTTPError
|
from urllib.request import urlopen
|
||||||
from urllib import urlencode
|
from urllib.error import URLError, HTTPError
|
||||||
|
from urllib.parse import urlencode
|
||||||
except ImportError:
|
except ImportError:
|
||||||
# python3
|
# python3
|
||||||
from urllib.parse import urlencode, quote
|
from urllib.parse import urlencode, quote
|
||||||
|
@ -1,8 +1,9 @@
|
|||||||
from __future__ import print_function
|
|
||||||
from argparse import ArgumentParser
|
from argparse import ArgumentParser
|
||||||
import json
|
import json
|
||||||
from urllib import urlencode
|
from urllib.parse import urlencode
|
||||||
from urllib2 import urlopen, HTTPError, URLError
|
from urllib.request import urlopen
|
||||||
|
from urllib.error import HTTPError, URLError
|
||||||
|
|
||||||
def main(args):
|
def main(args):
|
||||||
p = ArgumentParser("call getRevisionsCount for the given padid")
|
p = ArgumentParser("call getRevisionsCount for the given padid")
|
||||||
|
@ -1,8 +1,9 @@
|
|||||||
from __future__ import print_function
|
|
||||||
from argparse import ArgumentParser
|
from argparse import ArgumentParser
|
||||||
import json, sys
|
import json, sys
|
||||||
from urllib import urlencode
|
from urllib.parse import urlencode
|
||||||
from urllib2 import urlopen, HTTPError, URLError
|
from urllib.request import urlopen
|
||||||
|
from urllib.error import HTTPError, URLError
|
||||||
import requests
|
import requests
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,11 +1,12 @@
|
|||||||
from __future__ import print_function
|
|
||||||
from argparse import ArgumentParser
|
from argparse import ArgumentParser
|
||||||
import json, sys
|
import json, sys
|
||||||
|
|
||||||
try:
|
try:
|
||||||
# python2
|
# python2
|
||||||
from urllib2 import urlopen, URLError, HTTPError
|
from urllib.request import urlopen
|
||||||
from urllib import urlencode
|
from urllib.error import URLError, HTTPError
|
||||||
|
from urllib.parse import urlencode
|
||||||
except ImportError:
|
except ImportError:
|
||||||
# python3
|
# python3
|
||||||
from urllib.parse import urlencode, quote
|
from urllib.parse import urlencode, quote
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
from __future__ import print_function
|
|
||||||
from argparse import ArgumentParser
|
from argparse import ArgumentParser
|
||||||
import json, sys, re
|
import json, sys, re
|
||||||
from common import *
|
from .common import *
|
||||||
|
|
||||||
"""
|
"""
|
||||||
Extract and output selected fields of metadata
|
Extract and output selected fields of metadata
|
||||||
|
@ -1,11 +1,12 @@
|
|||||||
from __future__ import print_function
|
|
||||||
from argparse import ArgumentParser
|
from argparse import ArgumentParser
|
||||||
import sys, json, re, os
|
import sys, json, re, os
|
||||||
from datetime import datetime
|
from datetime import datetime
|
||||||
from urllib import urlencode
|
from urllib.parse import urlencode
|
||||||
from urllib2 import urlopen, HTTPError, URLError
|
from urllib.request import urlopen
|
||||||
|
from urllib.error import HTTPError, URLError
|
||||||
from math import ceil, floor
|
from math import ceil, floor
|
||||||
from common import *
|
from .common import *
|
||||||
|
|
||||||
"""
|
"""
|
||||||
status (meta):
|
status (meta):
|
||||||
@ -95,7 +96,7 @@ def main (args):
|
|||||||
pad = PadItem(path=p)
|
pad = PadItem(path=p)
|
||||||
padsbypath[pad.path] = pad
|
padsbypath[pad.path] = pad
|
||||||
|
|
||||||
pads = padsbypath.values()
|
pads = list(padsbypath.values())
|
||||||
pads.sort(key=lambda x: (x.status, x.padid))
|
pads.sort(key=lambda x: (x.status, x.padid))
|
||||||
|
|
||||||
curstat = None
|
curstat = None
|
||||||
|
Loading…
Reference in New Issue
Block a user