2013-04-13 20:33:06 +00:00
|
|
|
|
"""
|
|
|
|
|
Opens links in a browser.
|
2011-10-29 05:18:19 +00:00
|
|
|
|
|
2013-04-13 20:33:06 +00:00
|
|
|
|
Installation
|
|
|
|
|
------------
|
|
|
|
|
|
|
|
|
|
First use case: local use
|
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
If you use poezio on your workstation, this is for you.
|
|
|
|
|
You only have to load the plugin: ::
|
|
|
|
|
|
|
|
|
|
/load link
|
|
|
|
|
|
|
|
|
|
Second use case: remote use
|
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
If you use poezio through SSH, this is for you.
|
|
|
|
|
|
|
|
|
|
.. note:: Small explanation: Poezio will create a `Unix FIFO`_ and send the commands in,
|
|
|
|
|
and you will have to run a dæmon locally with ssh, to get those commands.
|
|
|
|
|
|
|
|
|
|
First, set the :term:`exec_remote` option in the config file to ``true``. Then select
|
|
|
|
|
the directory you want to put the fifo in (default is the current
|
|
|
|
|
directory, :file:`./`), the :file:`poezio.fifo` file will be created there.
|
|
|
|
|
|
|
|
|
|
After that, load the plugin: ::
|
|
|
|
|
|
|
|
|
|
/load link
|
|
|
|
|
|
|
|
|
|
And open a link with :term:`/link` (as described below), this will create the FIFO.
|
|
|
|
|
|
|
|
|
|
You need to grab poezio’s sources on your client computer, or at least the `daemon.py`_
|
|
|
|
|
file.
|
|
|
|
|
|
|
|
|
|
Finally, on your client computer, run the ssh command:
|
|
|
|
|
|
|
|
|
|
.. code-block:: bash
|
|
|
|
|
|
|
|
|
|
ssh toto@example.org "cat ~/poezio/poezio.fifo" | python3 daemon.py
|
|
|
|
|
|
|
|
|
|
Usage
|
|
|
|
|
-----
|
|
|
|
|
|
|
|
|
|
.. glossary::
|
|
|
|
|
|
|
|
|
|
/link
|
|
|
|
|
**Usage:** ``/link [num]``
|
|
|
|
|
|
|
|
|
|
This plugin adds a :term:`/link` command that will open the links in ``firefox``. If
|
|
|
|
|
you want to use another browser, you can use the :term:`/set` command to change the
|
|
|
|
|
:term:`browser` option.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
:term:`/link` without argument will open the last received link, if any is found.
|
|
|
|
|
If an integer argument is given, /link will go back gradually in the buffer
|
|
|
|
|
to open the previous link, and so on.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
If you are scrolling in the buffer, poezio will open the links starting from
|
|
|
|
|
the first you can see. (although there are some problems with multiline
|
|
|
|
|
messages).
|
|
|
|
|
|
|
|
|
|
Options
|
|
|
|
|
-------
|
|
|
|
|
|
|
|
|
|
:term:`exec_remote`
|
|
|
|
|
|
|
|
|
|
To execute the command on your client
|
|
|
|
|
|
|
|
|
|
.. glossary::
|
|
|
|
|
|
|
|
|
|
browser
|
|
|
|
|
Set the default browser started by the plugin
|
|
|
|
|
|
|
|
|
|
.. _Unix FIFO: https://en.wikipedia.org/wiki/Named_pipe
|
|
|
|
|
.. _daemon.py: http://gitweb.louiz.org/?p=poezio;a=blob_plain;f=src/daemon.py;hb=HEAD
|
|
|
|
|
|
|
|
|
|
"""
|
2011-10-29 05:18:19 +00:00
|
|
|
|
import re
|
|
|
|
|
|
2012-05-13 16:45:40 +00:00
|
|
|
|
from plugin import BasePlugin
|
2011-10-29 05:18:19 +00:00
|
|
|
|
from xhtml import clean_text
|
|
|
|
|
import common
|
2012-05-13 16:45:40 +00:00
|
|
|
|
import tabs
|
2011-10-29 05:18:19 +00:00
|
|
|
|
|
|
|
|
|
url_pattern = re.compile(r'\b(http[s]?://(?:\S+))\b', re.I|re.U)
|
|
|
|
|
|
|
|
|
|
class Plugin(BasePlugin):
|
|
|
|
|
def init(self):
|
2013-03-01 18:25:31 +00:00
|
|
|
|
for _class in (tabs.MucTab, tabs.PrivateTab, tabs.ConversationTab):
|
2013-03-08 21:53:35 +00:00
|
|
|
|
self.api.add_tab_command(_class, 'link', self.command_link,
|
2013-03-01 18:25:31 +00:00
|
|
|
|
usage='[num]',
|
|
|
|
|
help='Opens the last link from the conversation into a browser.\nIf [num] is given, then it will open the num-th link displayed.',
|
|
|
|
|
short='Open links into a browser')
|
2011-10-29 05:18:19 +00:00
|
|
|
|
|
|
|
|
|
def find_link(self, nb):
|
2013-03-08 21:53:35 +00:00
|
|
|
|
messages = self.api.get_conversation_messages()
|
2011-10-29 05:18:19 +00:00
|
|
|
|
if not messages:
|
|
|
|
|
return None
|
|
|
|
|
for message in messages[::-1]:
|
2011-10-29 15:20:18 +00:00
|
|
|
|
matches = url_pattern.findall(clean_text(message.txt))
|
|
|
|
|
if matches:
|
|
|
|
|
for url in matches[::-1]:
|
2011-10-29 05:18:19 +00:00
|
|
|
|
if nb == 1:
|
|
|
|
|
return url
|
|
|
|
|
else:
|
|
|
|
|
nb -= 1
|
|
|
|
|
return None
|
|
|
|
|
|
|
|
|
|
def command_link(self, args):
|
|
|
|
|
args = common.shell_split(args)
|
|
|
|
|
if len(args) == 1:
|
|
|
|
|
try:
|
|
|
|
|
nb = int(args[0])
|
|
|
|
|
except:
|
2013-03-08 21:53:35 +00:00
|
|
|
|
return self.api.run_command('/help link')
|
2011-10-29 05:18:19 +00:00
|
|
|
|
else:
|
|
|
|
|
nb = 1
|
|
|
|
|
link = self.find_link(nb)
|
|
|
|
|
if link:
|
2012-10-22 15:14:21 +00:00
|
|
|
|
self.core.exec_command([self.config.get('browser', 'firefox'), link])
|
2011-10-29 05:18:19 +00:00
|
|
|
|
else:
|
2013-03-08 21:53:35 +00:00
|
|
|
|
self.api.information('No URL found.', 'Warning')
|
2011-10-29 05:18:19 +00:00
|
|
|
|
|
|
|
|
|
def cleanup(self):
|
|
|
|
|
del self.config
|