etherpump/README.md

147 lines
4.7 KiB
Markdown
Raw Normal View History

etherpump
2015-02-26 13:54:26 +01:00
=========
2019-09-11 19:46:05 +02:00
*pumping text from etherpads into publications*
2015-02-26 17:15:41 +01:00
A command-line utility that extends the multi writing and publishing functionalities of the [etherpad](http://etherpad.org/) by exporting the pads in multiple formats.
Many pads, many networks
------------------------
2019-09-11 19:47:19 +02:00
*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.
2019-09-11 19:56:06 +02:00
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.
Added features are:
* opt-in publishing with the `__PUBLISH__` magic word
* the `publication` command, that listens to custom magic words such as `__RELEARN__`
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.
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.
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**.
Change log / notes
==================
**September 2019**
Forking *etherdump* into *etherpump*. (Work in progress!)
<https://git.vvvvvvaria.org/varia/etherpump>
-----
**May - September 2019**
Etherdump 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__`.
-----
**June 2019**
Multiple conversations around etherdump emerged during Relearn Curved in Varia, Rotterdam.
Including the idea of executable pads (*etherhooks*), custom magic words, a federated snippet protocol (*etherstekje*) and more.
<https://varia.zone/relearn-2019.html>
-----
**April 2019**
Installation of etherdump on the Varia server.
<https://etherdump.vvvvvvaria.org/>
-----
**March 2019**
The `__PUBLISH__ vs. __NOPUBLISH__` was added to the etherdump repository by *decentral1se*.
<https://gitlab.constantvzw.org/aa/etherdump/issues/3>
-----
Originally designed for use at: [Constant](http://etherdump.constantvzw.org/).
More notes can be found in the [git repository of etherdump](https://gitlab.constantvzw.org/aa/etherdump).
Install etherpump
=================
2015-02-26 17:15:41 +01:00
Requirements
-------------
* python3
* html5lib
* requests (settext)
* python-dateutil, jinja2 (used by the index subcommand)
2015-02-26 17:15:41 +01:00
2015-03-05 16:24:23 +01:00
Installation
-------------
2019-09-11 20:11:24 +02:00
`$ pip install python-dateutil jinja2 html5lib`
`$ python setup.py install`
2015-03-05 16:24:23 +01:00
2016-10-17 13:06:56 +02:00
Example
---------------
2019-09-11 20:11:24 +02:00
```
$ mkdir mydump
$ cd myddump
$ etherdump init
2016-10-17 13:06:56 +02:00
2019-09-11 20:11:24 +02:00
```
2015-06-18 14:56:48 +02:00
The program then interactively asks some questions:
2015-06-18 14:56:48 +02:00
```
Please type the URL of the etherpad:
https://pad.vvvvvvaria.org/
The APIKEY is the contents of the file APIKEY.txt in the etherpad folder
Please paste the APIKEY:
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
2015-06-18 14:56:48 +02:00
```
2015-06-18 14:56:48 +02:00
The settings are placed in a file called .etherdump/settings.json and are used (by default) by future commands.
2015-06-18 14:56:48 +02:00
Subcommands
2015-06-18 14:56:48 +02:00
----------
2016-10-17 13:06:56 +02:00
* init
* pull
2015-09-17 18:47:25 +02:00
* list
* listauthors
2015-11-19 12:52:35 +01:00
* gettext
2016-10-17 15:40:31 +02:00
* settext
2015-11-19 12:52:35 +01:00
* gethtml
* creatediffhtml
2015-09-17 18:47:25 +02:00
* revisionscount
2016-10-17 15:40:16 +02:00
* index
2016-10-17 15:40:31 +02:00
* deletepad
* publication (*etherpump*)
2015-06-18 14:56:48 +02:00
2015-09-17 18:47:25 +02:00
To get help on a subcommand:
2015-06-18 14:56:48 +02:00
etherdump revisionscount --help
2016-10-17 15:40:16 +02:00
License
=======
2018-01-12 14:42:55 +01:00
GNU AFFERO GENERAL PUBLIC LICENSE, Version 3
2018-01-12 14:42:55 +01:00
See License.txt
2018-01-12 14:45:36 +01:00