README.rst 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459
  1. .. contents::
  2. 1 gnusrss
  3. ---------
  4. 1.1 English
  5. ~~~~~~~~~~~
  6. 1.1.1 About
  7. ^^^^^^^^^^^
  8. gnusrss parse feeds and post them to GNU Social. The idea of ​​this program came from `spigot <https://github.com/nathans/spigot>`_, a program that posts feeds to the social network `pump.io <https://pump.io>`_ as does gnusrss but better, because it controls the possible flood. gnusrss does not have this option and it will be managed with the crontab (for now).
  9. 1.1.2 Features
  10. ^^^^^^^^^^^^^^
  11. - Multiple feed and GNU Social accounts support
  12. - sqlite3 is used to store the feeds
  13. - Can fetch RSS files or url indistinctly
  14. - Twitter image upload support when used with `twitter2rss <http://daemons.cf/cgit/twitter2rss>`_
  15. 1.1.3 Requirements
  16. ^^^^^^^^^^^^^^^^^^
  17. Need a version equal to or greater than python 3 and some libraries:
  18. - `feedparser <//pypi.python.org/pypi/feedparser>`_ >= 5.0
  19. - `requests <https://pypi.python.org/pypi/requests/2.11.1>`_ >= 2.11.1
  20. 1.1.4 Git repository
  21. ^^^^^^^^^^^^^^^^^^^^
  22. It's in two places:
  23. - `http://daemons.cf/cgit/gnusrss <http://daemons.cf/cgit/gnusrss>`_: the original repository
  24. - `https://notabug.org/drymer/gnusrss/ <https://notabug.org/drymer/gnusrss/>`_: A mirror in which it can be put issues and feature requests
  25. 1.1.5 Install
  26. ^^^^^^^^^^^^^
  27. As with any program that uses python, it should be used a virtual environment (virtualenv), but that is user selectable. It's possible to use one of the next installation methods:
  28. Install via pip:
  29. .. code-block:: sh
  30. :number-lines: 0
  31. $ su -c "pip3 install gnusrss"
  32. Clone the repository:
  33. .. code-block:: sh
  34. :number-lines: 0
  35. $ git clone git://daemons.cf/gnusrss
  36. # OR ...
  37. $ git clone https://notabug.org/drymer/gnusrss/
  38. $ cd gnusrss
  39. $ su -c "pip3 install -r requirements.txt"
  40. $ su -c "python3 setup.py install"
  41. If on parabola:
  42. .. code-block:: sh
  43. :number-lines: 0
  44. $ su -c "pacman -S gnusrss"
  45. 1.1.6 Configuration
  46. ^^^^^^^^^^^^^^^^^^^
  47. The program is (or should be) quite intuitive. Running the following, should show the basics:
  48. .. code-block:: sh
  49. :number-lines: 0
  50. $ gnusrss.py
  51. usage: gnusrss [-h] [-c file_name] [-C] [-p config_file] [-P] [-k file_name]
  52. Post feeds to GNU Social
  53. optional arguments:
  54. -h, --help show this help message and exit
  55. -c file_name, --create-config file_name
  56. creates a config file
  57. -C, --create-db creates the database
  58. -p config_file, --post config_file
  59. posts feeds
  60. -P, --post-all posts all feeds
  61. -k file_name, --populate-database file_name
  62. fetch the RSS and save it in the database
  63. In any case, if not clear, read the following.
  64. For the first use, it must be created the database and the first configuration file. This can done using the same command, like this:
  65. .. code-block:: sh
  66. :number-lines: 0
  67. $ gnusrss.py --create-db --create-config daemons
  68. Then it will ask several questions to create the first configuration file. It should look like this:
  69. .. code-block:: text
  70. :number-lines: 0
  71. Database created!
  72. Hi! Now we'll create config file!
  73. Please enter the feed's URL: https://daemons.cf/rss.xml
  74. Please enter your username (user@server.com): drymer@quitter.se
  75. Please enter your password: falsePassword
  76. Do you need to shorten the URLs that you 'post? Please take in account
  77. That You should only use it if your node only have 140 characters.
  78. Answer with "yes" or just press enter if you do not want to use it:
  79. Please enter your feed's fallbackurl. If you do not want or have one,
  80. just press enter:
  81. Now we're gona fetch the feed. Please wait ...
  82. Done! The tags are:
  83. tags
  84. title_detail
  85. link
  86. authors
  87. links
  88. author_detail
  89. published_parsed
  90. title
  91. summary
  92. id
  93. author
  94. published
  95. guidislink
  96. summary_detail
  97. The XML has-been parsed. Choose wich format you want:
  98. Please put the tags inside the square brackets
  99. Ex: {title} - {link} by @{author}: {title} - {link} by @{author}
  100. Do you want to allow insecure connection to your GNU social server?
  101. Answer with "yes" or just press enter if you don't want to use it:
  102. Do you want to populate the database? (y) Or you prefer to post old items? (n)
  103. The file is saved under the name 'daemons.ini'. It should look like this:
  104. .. code-block:: text
  105. :number-lines: 0
  106. [Feeds]
  107. feed = https://daemons.cf/rss.xml
  108. user = drymer@quitter.se
  109. password = falsePassword
  110. shorten =
  111. fallback_feed =
  112. format = {title} - {link} by @ {author}
  113. It can create all the configuration files you want.
  114. When creating the above file, it put into the database all the feeds that had so far. Thus, when running **gnusrss** for the first time, it will not post nothing to GNU Social until the feed has new information.
  115. To post feeds from a concrete config file or all execute, respectively, the following:
  116. .. code-block:: sh
  117. :number-lines: 0
  118. $ gnusrss.py -p daemons.ini
  119. $ gnusrss.py -P
  120. If the config file is created manually and the user don't want to post all the feed's content, just use the --populate-database option to save them to the database:
  121. .. code-block:: sh
  122. :number-lines: 0
  123. $ gnusrss.py -k otherFile.ini
  124. 1.1.7 Crontab
  125. ^^^^^^^^^^^^^
  126. The recommended way to execute **gnurss** is using the crontab. Each time it's run, a single item of the feed will be posted to prevent flood. Depending on the number of feeds that are published, you should choose a different runtime. For a blog that publishs once a day, it could be used the following:
  127. .. code-block:: sh
  128. :number-lines: 0
  129. $ crontab -e
  130. # A file is open and gets the following
  131. * 12 * * * cd $rutaDEgnusrss && gnusrss.py -p daemons.ini
  132. So it runs once, every day at midday. If, however, it's used with `twitter2rss <http://daemons.cf/cgit/twitter2rss/>`_, it could be recommended putting it to run every five minutes. It has to be remembered that is important to run in the directory where the database was created, because is where it will search it..
  133. 1.1.8 Use with twitter2rss and/or GNU Social
  134. ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  135. It works like any feed, except for the field that is published. In both you have to choose ``{summary}``. An example configuration file is as follows:
  136. .. code-block:: text
  137. :number-lines: 0
  138. [feeds]
  139. feed = https://quitter.se/api/statuses/user_timeline/127168.atom
  140. user = drymer@quitter.se
  141. password = falsePassword
  142. shorten =
  143. fallback_feed =
  144. format = {summary}
  145. The feed can be achieved by looking at the source code of the page of the account you want. For `twitter2rss <http://daemons.cf/cgit/twitter2rss>`_, you can host it or can use this `web <http://daemons.cf/twitter2rss>`_.
  146. 1.1.9 License
  147. ^^^^^^^^^^^^^
  148. .. code-block:: text
  149. :number-lines: 0
  150. This program is free software: you can redistribute it and / or modify
  151. it under the terms of the GNU General Public License as published by
  152. the Free Software Foundation, Either version 3 of the License, or
  153. (At your option) any later version.
  154. This program is distributed in the hope That it will be useful,
  155. but WITHOUT ANY WARRANTY; without even the implied warranty of
  156. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  157. GNU General Public License for more details.
  158. You should have received a copy of the GNU General Public License
  159. Along With This Program. If not, see <http://www.gnu.org/licenses/>.
  160. 1.2 Castellano
  161. ~~~~~~~~~~~~~~
  162. 1.2.1 Acerca de
  163. ^^^^^^^^^^^^^^^
  164. gnusrss parsea feeds y los postea en GNU Social. La idea de hacer este programa surgió de `spigot <https://github.com/nathans/spigot>`_, un programa que postea feeds en la red social `pump.io <https://pump.io>`_ igual que hace gnusrss pero mejor, ya que controla el posible flood. gnusrss no tiene esta opción y se controlará con el propio crontab (de momento).
  165. 1.2.2 Features
  166. ^^^^^^^^^^^^^^
  167. - Soporta múltiples feeds y cuentas de GNU Social
  168. - sqlite3 es usado para guardar los feeds
  169. - Se puede usar tanto archivos RSS cómo url indistintamente
  170. - Soporta la súbida de imágenes de Twitter cuando es usado en conjunto con `twitter2rss <http://daemons.cf/cgit/twitter2rss>`_
  171. 1.2.3 Requisitos
  172. ^^^^^^^^^^^^^^^^
  173. Necesita una versión de python igual o superior a la 3 y algunas librerias:
  174. - `feedparser <https://pypi.python.org/pypi/feedparser>`_ >= 5.0
  175. - `requests <https://pypi.python.org/pypi/requests/2.11.1>`_ >= 2.11.1
  176. 1.2.4 Repositorio git
  177. ^^^^^^^^^^^^^^^^^^^^^
  178. Está en dos sitios:
  179. - `http://daemons.cf/cgit/gnusrss <http://daemons.cf/cgit/gnusrss>`_: el repositorio original
  180. - `https://notabug.org/drymer/gnusrss/ <https://notabug.org/drymer/gnusrss/>`_: un mirror, en el que se pueden poner los problemas y sugerencias de mejoras
  181. 1.2.5 Instalación
  182. ^^^^^^^^^^^^^^^^^
  183. Cómo con cualquier programa con python, es recomendable usar un entorno virtual (virtualenv), pero eso queda a elección del usuario. Se puede escoger entre los siguientes metodos:
  184. Instalar usando pip:
  185. .. code-block:: sh
  186. :number-lines: 0
  187. $ su -c "pip3 install gnusrss"
  188. Clonar el repositorio:
  189. .. code-block:: sh
  190. :number-lines: 0
  191. $ git clone git://daemons.cf/gnusrss
  192. # O ...
  193. $ git clone https://notabug.org/drymer/gnusrss/
  194. $ cd gnusrss
  195. $ su -c "pip3 install -r requirements.txt"
  196. $ su -c "python3 setup.py install"
  197. Si se usa parabola:
  198. .. code-block:: sh
  199. :number-lines: 0
  200. $ su -c "pacman -S gnusrss"
  201. 1.2.6 Configuración
  202. ^^^^^^^^^^^^^^^^^^^
  203. El programa es (o debería ser) bastante intuitivo. Ejecutando lo siguiente, deberia verse lo básico:
  204. .. code-block:: sh
  205. :number-lines: 0
  206. $ gnusrss.py
  207. usage: gnusrss [-h] [-c file_name] [-C] [-p config_file] [-P] [-k file_name]
  208. Post feeds to GNU Social
  209. optional arguments:
  210. -h, --help show this help message and exit
  211. -c file_name, --create-config file_name
  212. creates a config file
  213. -C, --create-db creates the database
  214. -p config_file, --post config_file
  215. posts feeds
  216. -P, --post-all posts all feeds
  217. -k file_name, --populate-database file_name
  218. fetch the RSS and save it in the database
  219. En cualquier caso, si no queda claro, leer lo siguiente.
  220. Para el primer uso, la base de datos y el primer archivo de configuración deben ser creados. Podemos hacerlo usando la misma orden, tal que así:
  221. .. code-block:: sh
  222. :number-lines: 0
  223. $ gnusrss.py --create-db --create-config daemons
  224. A continuación hará varias preguntas para configurar el primer archivo de configuración. Debería verse así:
  225. .. code-block:: text
  226. :number-lines: 0
  227. Database created!
  228. Hi! Now we'll create de config file!
  229. Please introduce the feed's url: https://daemons.cf/rss.xml
  230. Please introduce your username (user@server.com): drymer@quitter.se
  231. Please introduce your password: contraseñaFalsa
  232. {1}Do you need to shorten the urls that you post? Please take in account
  233. that you should only use it if your node only has 140 characters.
  234. Answer with "yes" or just press enter if you don't want to use it:
  235. {2}Please introduce your feed's fallbackurl. If you don't want or have one,
  236. just press enter:
  237. Now we're gona fetch the feed. Please wait...
  238. Done! The tags are:
  239. tags
  240. title_detail
  241. link
  242. authors
  243. links
  244. author_detail
  245. published_parsed
  246. title
  247. summary
  248. id
  249. author
  250. published
  251. guidislink
  252. summary_detail
  253. The XML has been parsed. Choose wich format you want:
  254. {3}Please put the tags inside the square brackets
  255. Ex: {title} - {link} by @{author}: {title} - {link} by @{author}
  256. {4}Do you want to allow insecure connection to your GNU social server?
  257. Answer with "yes" or just press enter if you don't want to use it:
  258. {5}Do you want to populate the database? (y) Or you prefer to post old items? (n)
  259. A continuación traduciré las lineas con los números entre corchetes.
  260. {1} Necesitas acortar las url que quieres postear? Por favor ten en cuenta que sólo deberia usarse si el servidor sólo tiene 140 carácteres.
  261. {2} Por favor introduce tu feed de emergencia. Si no tienes uno, solamente aprieta enter.
  262. {3} Por favor pon las etiquetas dentro de los corchetes.
  263. {4} Quieres permitir conexiones inseguras a tu servidor GNU social? Responde con "si" o simplemente apreta enter si no necesitas usarlo.
  264. {5} Quieres llenar la base de datos? (y) O prefieres publicar los artículos antiguos? (n)
  265. Respecto al 3, hay que examinar el código fuente del RSS para saber cuales interesan. En general, el que hay de ejemplo será lo que se busque. En el caso 4, sólo es útil si el servidor usa un certificado auto-firmado.
  266. El archivo se guardará con el nombre 'daemons.ini'. Después de todas estas preguntas, debería verse similar a esto:
  267. .. code-block:: text
  268. :number-lines: 0
  269. [feeds]
  270. feed = https://daemons.cf/rss.xml
  271. user = drymer@quitter.se
  272. password = contraseñaFalsa
  273. shorten =
  274. fallback_feed =
  275. format = {title} - {link} by @{author}
  276. insecure =
  277. Se pueden crear todos los archivos de configuración que se quieran.
  278. Al haber creado el archivo anterior, se han metido en la base de datos todos los feeds que habian hasta el momento. Por lo tanto, cuando se ejecuta **gnusrss** por primera vez, no posteará nada en GNU Social, a menos que el feed tenga nueva información.
  279. Para postear los feeds de un archivo o todos, ejecutar, respectivamente, lo siguiente:
  280. .. code-block:: sh
  281. :number-lines: 0
  282. $ gnusrss.py -p daemons.ini
  283. $ gnusrss.py -P
  284. Si el archivo de configuración ha sido creado manualmente y no se quiere postear el contenido del feed, sólo hay que ejecutar la opción --populate-database para guardar estos en la base de datos:
  285. .. code-block:: sh
  286. :number-lines: 0
  287. $ gnusrss.py -k otherFile.ini
  288. 1.2.7 Crontab
  289. ^^^^^^^^^^^^^
  290. El modo recomendado de ejecución de gnusrss es usando el crontab. Cada vez que se ejecute posteará un sólo elemento del feed para evitar el flood. Según la cantidad de feeds que se publiquen, se deberia escoger un tiempo de ejecución distinto. Para un blog que publique una vez al día, con poner lo siguiente, deberia valer:
  291. .. code-block:: sh
  292. :number-lines: 0
  293. $ crontab -e
  294. # Se abrirá un archivo y se mete lo siguiente
  295. * 12 * * * cd $rutaDEgnusrss && gnusrss.py -p daemons.cf
  296. Así se ejecuta una vez al día, a las doce de la mañana. Si, en cambio, lo usasemos con `twitter2rss <http://daemons.cf/cgit/twitter2rss/>`_, se recomienda poner que se ejecute cada cinco minutos. Hay que recordar que es importante que se ejecute en el directorio en el que se ha creado la base de datos, ya que es ahí dónde la buscará.
  297. 1.2.8 Uso con twitter2rss y/o GNU Social
  298. ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  299. Funciona igual que con cualquier feed, exceptuando el campo que se publica. En ambos hay que escoger ``{summary}``. Un ejemplo de archivo de configuración sería el siguiente:
  300. .. code-block:: text
  301. :number-lines: 0
  302. [feeds]
  303. feed = https://quitter.se/api/statuses/user_timeline/127168.atom
  304. user = drymer@quitter.se
  305. password = contraseñaFalsa
  306. shorten =
  307. fallback_feed =
  308. format = {summary}
  309. El feed se puede conseguir mirando el código fuente de la página de la cuenta que se quiere. En el caso de `twitter2rss <http://daemons.cf/cgit/twitter2rss>`_, se puede hostear o se puede usar esta `web <http://daemons.cf/twitter2rss>`_. No es recomendable usarlo con ningún nodo que use 140 carácteres, ya que en los retweets se añade un símbolo, "♻", lo cual hará que un tweet de 140 carácteres no sea posteado.
  310. 1.2.9 Bugs
  311. ^^^^^^^^^^
  312. 1.2.10 Licencia
  313. ^^^^^^^^^^^^^^^
  314. .. code-block:: text
  315. :number-lines: 0
  316. This program is free software: you can redistribute it and/or modify
  317. it under the terms of the GNU General Public License as published by
  318. the Free Software Foundation, either version 3 of the License, or
  319. (at your option) any later version.
  320. This program is distributed in the hope that it will be useful,
  321. but WITHOUT ANY WARRANTY; without even the implied warranty of
  322. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  323. GNU General Public License for more details.
  324. You should have received a copy of the GNU General Public License
  325. along with this program. If not, see <http://www.gnu.org/licenses/>.