Willkommen zur Vorstellung von

 

 

Extensible Messaging and Presence Protocol

(früher Jabber von „(daher-)plappern“)

Erweiterbares Nachrichten- und Anwesenheitsprotokoll

OFFENER STANDARD

DEZENTRAL

ERWEITERBAR

FLEXIBEL

SICHERHEIT

VERSCHLÜSSELUNG

Was Bietet XMPP?

OFFENER STANDARD

DEZENTRAL

XMPP Netzwerk Aufbau

Clients bei verschiedenen XMPP Servern

Server - Server Kommunikation

Clients in Multi-User-Chat (MUC)

Server - Server Kommunikation

Ähnlichkeiten mit E-Mail

ERWEITERBAR

FLEXIBEL

Erweiterungen (XEPs)

Erweiterbar - mithilfe der Leistung von XML kann jeder benutzerdefinierte Funktionen auf den Kernprotokollen aufbauen.

Flexibel - XMPP-Anwendungen, die über IM hinausgehen, umfassen Netzwerkmanagement, Content-Syndizierung, Tools für die Zusammenarbeit, Dateifreigabe, Spiele, Remote-Systemüberwachung, Webdienste, leichtgewichtige Middleware, Cloud Computing und vieles mehr.

ERWEITERBAR

# Ein Empfänger
echo 'Hallo Welt!' | sendxmpp -t -r echobot -u echobot -j fr32k.de:63034 -p 123 picard@fr32k.de
# MUC
echo 'Hallo Welt!' | sendxmpp -t -r echobot -c linux-whv@chat.ffnw.de -u echobot -j fr32k.de:63034 -p 123 picard@fr32k.de

Beispiel: Terminal

ERWEITERBAR

import pyxmpp
from pyxmpp.jabber.client import JabberClient

class EchoBot(JabberClient):
	def __init__(self, jid, passwd):
	tls = pyxmpp.streamtls.TLSSettings(require=True, verify_peer=False)
	JabberClient. __init__(self, pyxmpp.jid .JID(jid), passwd, tls_settings=tls,
        auth_methods=["sasl : PLAIN"])
	
	def message(self, stanza):
		if stanza.get_type() == "chat" and stanza.get_body() != None :
			m = pyxmpp.message.Message(stanza, to_jid=stanza.get_from(),
                        from_jid=stanza.get_to())
			self.stream.send(m)
			
	def session_started( self ):
		JabberClient.session_started(self)
		self.stream.set_message_handler("normal", self.message)
		
bot = EchoBot("echobot@fr32k.de/test", "123" )
bot.connect()
try:
	while 1: bot.loop(1)
	except KeyboardInterrupt: bot.disconnect()

Beispiel: Python

SICHERHEIT

VERSCHLÜSSELUNG

SASL und TLS sind Kern bestandteil der XMPP Spezifikationen

Ende-zu-Ende-Verschlüsselung
OpenPGP, Off-the-Record Messaging (OTR) & Omemo.

 

Durch Perfect Forward Secrecy(PFS) wird außerdem erreicht, dass bei Verlust von privaten Schlüsseln vorherige Traffic Mitschnitte nicht entschlüsselt werden können.

Client-zu-Server- & Server-zu-Server-Verschlüsselung

Client A

Server A

Server B

Client B

XMPP Installation

PC:  Gajim

==> https://gajim.org

Android:  Conversations

==> https://conversations.im

IOS:  ChatSecure

==> https://chatsecure.org

Link Sammlung

https://xmpp.org/
https://de.wikipedia.org/wiki/OMEMO
https://de.wikipedia.org/wiki/Off-the-Record_Messaging
https://de.wikipedia.org/wiki/Perfect_Forward_Secrecy
https://github.com/xsf
https://de.wikipedia.org/wiki/OpenPGP
https://gajim.org
https://conversations.im
https://chatsecure.org

Multi-User-Chat (MUC)

linux-whv@chat.ffnw.de

Linux Wilhelmshaven und Umland

Danke

Ende

Willkommen zur Vorstellung von XMPP

By picardtux

Willkommen zur Vorstellung von XMPP

Erweiterbares Nachrichten- und Anwesenheitsprotokoll

  • 1,950