2014-07-17 12:19:04 +00:00
|
|
|
|
Slixmpp
|
2012-01-05 16:31:54 +00:00
|
|
|
|
#########
|
|
|
|
|
|
|
|
|
|
.. sidebar:: Get the Code
|
|
|
|
|
|
2015-02-24 17:58:40 +00:00
|
|
|
|
The latest source code for Slixmpp may be found on the `Git repo
|
2019-02-12 10:34:57 +00:00
|
|
|
|
<https://lab.louiz.org/poezio/slixmpp>`_. ::
|
2012-01-05 16:31:54 +00:00
|
|
|
|
|
2019-02-12 10:34:57 +00:00
|
|
|
|
git clone https://lab.louiz.org/poezio/slixmpp
|
2012-01-05 16:31:54 +00:00
|
|
|
|
|
2015-02-24 17:58:40 +00:00
|
|
|
|
An XMPP chat room is available for discussing and getting help with slixmpp.
|
2012-01-05 16:31:54 +00:00
|
|
|
|
|
|
|
|
|
**Chat**
|
2015-02-24 17:58:40 +00:00
|
|
|
|
`slixmpp@muc.poez.io <xmpp:slixmpp@muc.poez.io?join>`_
|
|
|
|
|
|
|
|
|
|
**Reporting bugs**
|
2019-02-12 10:26:04 +00:00
|
|
|
|
You can report bugs at http://lab.louiz.org/poezio/slixmpp/issues.
|
2012-01-05 16:31:54 +00:00
|
|
|
|
|
2015-02-24 17:58:40 +00:00
|
|
|
|
.. note::
|
|
|
|
|
slixmpp is a friendly fork of `SleekXMPP <https://github.com/fritzy/SleekXMPP>`_
|
|
|
|
|
which goal is to use asyncio instead of threads to handle networking. See
|
|
|
|
|
:ref:`differences`.
|
2012-01-05 16:31:54 +00:00
|
|
|
|
|
2020-05-01 13:13:19 +00:00
|
|
|
|
Slixmpp is an :ref:`MIT licensed <license>` XMPP library for Python 3.7+,
|
2012-01-05 16:31:54 +00:00
|
|
|
|
|
2014-07-17 12:19:04 +00:00
|
|
|
|
Slixmpp's design goals and philosphy are:
|
2012-01-05 16:31:54 +00:00
|
|
|
|
|
|
|
|
|
**Low number of dependencies**
|
2014-07-17 12:19:04 +00:00
|
|
|
|
Installing and using Slixmpp should be as simple as possible, without
|
2012-01-05 16:31:54 +00:00
|
|
|
|
having to deal with long dependency chains.
|
|
|
|
|
|
|
|
|
|
As part of reducing the number of dependencies, some third party
|
2014-07-17 12:19:04 +00:00
|
|
|
|
modules are included with Slixmpp in the ``thirdparty`` directory.
|
2012-01-05 16:31:54 +00:00
|
|
|
|
Imports from this module first try to import an existing installed
|
|
|
|
|
version before loading the packaged version, when possible.
|
|
|
|
|
|
|
|
|
|
**Every XEP as a plugin**
|
|
|
|
|
Following Python's "batteries included" approach, the goal is to
|
|
|
|
|
provide support for all currently active XEPs (final and draft). Since
|
|
|
|
|
adding XEP support is done through easy to create plugins, the hope is
|
|
|
|
|
to also provide a solid base for implementing and creating experimental
|
|
|
|
|
XEPs.
|
|
|
|
|
|
|
|
|
|
**Rewarding to work with**
|
2014-07-17 12:19:04 +00:00
|
|
|
|
As much as possible, Slixmpp should allow things to "just work" using
|
2012-01-05 16:31:54 +00:00
|
|
|
|
sensible defaults and appropriate abstractions. XML can be ugly to work
|
|
|
|
|
with, but it doesn't have to be that way.
|
|
|
|
|
|
2015-02-24 17:58:40 +00:00
|
|
|
|
|
2014-07-17 12:19:04 +00:00
|
|
|
|
Here's your first Slixmpp Bot:
|
2012-01-18 23:31:45 +00:00
|
|
|
|
--------------------------------
|
|
|
|
|
|
|
|
|
|
.. code-block:: python
|
|
|
|
|
|
2015-02-24 17:58:40 +00:00
|
|
|
|
import asyncio
|
2012-01-18 23:31:45 +00:00
|
|
|
|
import logging
|
|
|
|
|
|
2014-07-17 12:19:04 +00:00
|
|
|
|
from slixmpp import ClientXMPP
|
2012-01-18 23:31:45 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class EchoBot(ClientXMPP):
|
|
|
|
|
|
|
|
|
|
def __init__(self, jid, password):
|
|
|
|
|
ClientXMPP.__init__(self, jid, password)
|
|
|
|
|
|
|
|
|
|
self.add_event_handler("session_start", self.session_start)
|
|
|
|
|
self.add_event_handler("message", self.message)
|
|
|
|
|
|
|
|
|
|
# If you wanted more functionality, here's how to register plugins:
|
|
|
|
|
# self.register_plugin('xep_0030') # Service Discovery
|
|
|
|
|
# self.register_plugin('xep_0199') # XMPP Ping
|
|
|
|
|
|
|
|
|
|
# Here's how to access plugins once you've registered them:
|
|
|
|
|
# self['xep_0030'].add_feature('echo_demo')
|
|
|
|
|
|
|
|
|
|
def session_start(self, event):
|
|
|
|
|
self.send_presence()
|
|
|
|
|
self.get_roster()
|
|
|
|
|
|
|
|
|
|
# Most get_*/set_* methods from plugins use Iq stanzas, which
|
2015-02-24 17:58:40 +00:00
|
|
|
|
# are sent asynchronously. You can almost always provide a
|
|
|
|
|
# callback that will be executed when the reply is received.
|
2012-01-18 23:31:45 +00:00
|
|
|
|
|
|
|
|
|
def message(self, msg):
|
|
|
|
|
if msg['type'] in ('chat', 'normal'):
|
|
|
|
|
msg.reply("Thanks for sending\n%(body)s" % msg).send()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
2014-08-17 19:53:34 +00:00
|
|
|
|
# Ideally use optparse or argparse to get JID,
|
2012-01-18 23:31:45 +00:00
|
|
|
|
# password, and log level.
|
|
|
|
|
|
|
|
|
|
logging.basicConfig(level=logging.DEBUG,
|
|
|
|
|
format='%(levelname)-8s %(message)s')
|
|
|
|
|
|
|
|
|
|
xmpp = EchoBot('somejid@example.com', 'use_getpass')
|
|
|
|
|
xmpp.connect()
|
2015-02-24 17:58:40 +00:00
|
|
|
|
xmpp.process()
|
2012-01-18 23:31:45 +00:00
|
|
|
|
|
|
|
|
|
|
2015-02-24 17:58:40 +00:00
|
|
|
|
To read if you come from SleekXMPP
|
|
|
|
|
----------------------------------
|
|
|
|
|
|
|
|
|
|
.. toctree::
|
|
|
|
|
:maxdepth: 1
|
|
|
|
|
|
|
|
|
|
differences
|
|
|
|
|
using_asyncio
|
|
|
|
|
|
2012-01-18 23:31:45 +00:00
|
|
|
|
|
2012-01-05 16:31:54 +00:00
|
|
|
|
Getting Started (with Examples)
|
|
|
|
|
-------------------------------
|
|
|
|
|
.. toctree::
|
|
|
|
|
:maxdepth: 1
|
2014-08-17 19:53:34 +00:00
|
|
|
|
|
2012-01-05 16:31:54 +00:00
|
|
|
|
getting_started/echobot
|
|
|
|
|
getting_started/sendlogout
|
|
|
|
|
getting_started/component
|
|
|
|
|
getting_started/presence
|
|
|
|
|
getting_started/muc
|
|
|
|
|
getting_started/proxy
|
|
|
|
|
getting_started/scheduler
|
|
|
|
|
getting_started/iq
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Tutorials, FAQs, and How To Guides
|
|
|
|
|
----------------------------------
|
|
|
|
|
.. toctree::
|
|
|
|
|
:maxdepth: 1
|
2014-08-17 19:53:34 +00:00
|
|
|
|
|
2012-01-05 16:31:54 +00:00
|
|
|
|
xeps
|
|
|
|
|
xmpp_tdg
|
|
|
|
|
howto/stanzas
|
|
|
|
|
create_plugin
|
|
|
|
|
features
|
|
|
|
|
sasl
|
|
|
|
|
handlersmatchers
|
|
|
|
|
|
|
|
|
|
Plugin Guides
|
|
|
|
|
~~~~~~~~~~~~~
|
2014-08-17 19:53:34 +00:00
|
|
|
|
.. toctree::
|
2012-01-05 16:31:54 +00:00
|
|
|
|
:maxdepth: 1
|
|
|
|
|
|
|
|
|
|
guide_xep_0030
|
|
|
|
|
|
2014-07-17 12:19:04 +00:00
|
|
|
|
Slixmpp Architecture and Design
|
2012-01-05 16:31:54 +00:00
|
|
|
|
---------------------------------
|
|
|
|
|
.. toctree::
|
|
|
|
|
:maxdepth: 3
|
|
|
|
|
|
|
|
|
|
architecture
|
|
|
|
|
plugin_arch
|
|
|
|
|
|
|
|
|
|
API Reference
|
|
|
|
|
-------------
|
|
|
|
|
.. toctree::
|
|
|
|
|
:maxdepth: 2
|
2014-08-17 19:53:34 +00:00
|
|
|
|
|
2012-01-05 16:31:54 +00:00
|
|
|
|
event_index
|
|
|
|
|
api/clientxmpp
|
|
|
|
|
api/componentxmpp
|
|
|
|
|
api/basexmpp
|
|
|
|
|
api/exceptions
|
|
|
|
|
api/xmlstream/jid
|
|
|
|
|
api/xmlstream/stanzabase
|
|
|
|
|
api/xmlstream/handler
|
|
|
|
|
api/xmlstream/matcher
|
|
|
|
|
api/xmlstream/xmlstream
|
|
|
|
|
api/xmlstream/tostring
|
2020-12-10 19:45:26 +00:00
|
|
|
|
|
|
|
|
|
Plugins
|
|
|
|
|
~~~~~~~
|
|
|
|
|
|
|
|
|
|
.. toctree::
|
|
|
|
|
:maxdepth: 1
|
|
|
|
|
|
2020-12-09 17:09:19 +00:00
|
|
|
|
api/plugins/index
|
2012-01-05 16:31:54 +00:00
|
|
|
|
|
|
|
|
|
Core Stanzas
|
|
|
|
|
~~~~~~~~~~~~
|
|
|
|
|
.. toctree::
|
|
|
|
|
:maxdepth: 2
|
|
|
|
|
|
|
|
|
|
api/stanza/rootstanza
|
|
|
|
|
api/stanza/message
|
|
|
|
|
api/stanza/presence
|
|
|
|
|
api/stanza/iq
|
|
|
|
|
|
|
|
|
|
Additional Info
|
|
|
|
|
---------------
|
|
|
|
|
.. toctree::
|
|
|
|
|
:hidden:
|
|
|
|
|
|
|
|
|
|
glossary
|
|
|
|
|
license
|
|
|
|
|
|
|
|
|
|
* :ref:`license`
|
|
|
|
|
* :ref:`glossary`
|
|
|
|
|
* :ref:`genindex`
|
|
|
|
|
* :ref:`modindex`
|
|
|
|
|
* :ref:`search`
|
|
|
|
|
|
2015-02-24 17:58:40 +00:00
|
|
|
|
SleekXMPP Credits
|
|
|
|
|
-----------------
|
|
|
|
|
|
|
|
|
|
.. note::
|
|
|
|
|
Those people made SleekXMPP, so you should not bother them if
|
|
|
|
|
you have an issue with slixmpp. But it’s still fair to credit
|
|
|
|
|
them for their work.
|
|
|
|
|
|
2012-01-18 23:31:45 +00:00
|
|
|
|
|
2012-01-05 17:28:30 +00:00
|
|
|
|
**Main Author:** `Nathan Fritz <http://andyet.net/team/fritzy>`_
|
2012-01-18 23:31:45 +00:00
|
|
|
|
`fritzy@netflint.net <xmpp:fritzy@netflint.net?message>`_,
|
|
|
|
|
`@fritzy <http://twitter.com/fritzy>`_
|
2012-01-05 16:31:54 +00:00
|
|
|
|
|
2012-01-18 23:31:45 +00:00
|
|
|
|
Nathan is also the author of XMPPHP and `Seesmic-AS3-XMPP
|
|
|
|
|
<http://code.google.com/p/seesmic-as3-xmpp/>`_, and a former member of the XMPP
|
|
|
|
|
Council.
|
2012-01-05 16:31:54 +00:00
|
|
|
|
|
2012-01-05 17:28:30 +00:00
|
|
|
|
**Co-Author:** `Lance Stout <http://andyet.net/team/lance>`_
|
2012-01-18 23:31:45 +00:00
|
|
|
|
`lancestout@gmail.com <xmpp:lancestout@gmail.com?message>`_,
|
|
|
|
|
`@lancestout <http://twitter.com/lancestout>`_
|
2012-01-05 16:31:54 +00:00
|
|
|
|
|
2012-01-05 17:28:30 +00:00
|
|
|
|
Both Fritzy and Lance work for `&yet <http://andyet.net>`_, which specializes in
|
2012-01-18 23:31:45 +00:00
|
|
|
|
realtime web and XMPP applications.
|
2012-01-05 17:28:30 +00:00
|
|
|
|
|
2012-01-18 23:31:45 +00:00
|
|
|
|
- `contact@andyet.net <mailto:contact@andyet.net>`_
|
|
|
|
|
- `XMPP Consulting <http://xmppconsulting.com>`_
|
|
|
|
|
|
2012-01-05 16:31:54 +00:00
|
|
|
|
**Contributors:**
|
|
|
|
|
- Brian Beggs (`macdiesel <http://github.com/macdiesel>`_)
|
|
|
|
|
- Dann Martens (`dannmartens <http://github.com/dannmartens>`_)
|
|
|
|
|
- Florent Le Coz (`louiz <http://github.com/louiz>`_)
|
|
|
|
|
- Kevin Smith (`Kev <http://github.com/Kev>`_, http://kismith.co.uk)
|
|
|
|
|
- Remko Tronçon (`remko <http://github.com/remko>`_, http://el-tramo.be)
|
|
|
|
|
- Te-jé Rogers (`te-je <http://github.com/te-je>`_)
|
|
|
|
|
- Thom Nichols (`tomstrummer <http://github.com/tomstrummer>`_)
|
|
|
|
|
|