SILC

SILC (englisch: Secure Internet Live Conferencing, dt. etwa ‚Sichere Konferenz via Internet, in Echtzeit‘) ist ein Netzwerkprotokoll für sicheres Synchronous Conferencing und wird vor allem für MUC (Multi-User Chat, dt. Mehrbenutzer-Chat) verwendet.

Funktionen und Funktionsweise

Ein SILC-Netzwerk kann (ähnlich einem IRC-Netz) auf mehrere Server verteilt sein. Trotz der oberflächlichen Ähnlichkeit zu IRC ist der interne Aufbau aber grundverschieden.

Ein wesentlicher Unterschied zu vielen anderen Chatprotokollen besteht darin, dass SILC sichere Kommunikation über unsichere Netze ermöglicht, da es die Möglichkeit bietet, Nachrichten auf dem gesamten Übertragungsweg verschlüsselt zu lassen (Ende-zu-Ende-Verschlüsselung).

So wie viele andere Konferenz- und Chatprotokolle bietet auch SILC Kanäle (Gruppen), Nicknamen, private Nachrichten und andere gebräuchliche Funktionen. Allerdings sind SILC-Nicknamen im Gegensatz zu vielen anderen Protokollen (z. B. IRC) nicht eindeutig: Ein Benutzer kann jeden Nicknamen verwenden, selbst wenn dieser schon verwendet wird. Die eigentliche Identifikation wird im Protokoll durch eine eindeutige Client ID vollbracht. Das SILC-Protokoll bedient sich dessen, um der Nicknamekollision Herr zu werden – ein Problem, das in vielen anderen Protokollen auftritt. Sämtliche in einem SILC-Netzwerk gesendete Nachrichten sind binär codiert, sodass in ihnen jeglicher Datentyp enthalten sein darf, einschließlich Text-, Video-, Audio- und andere Multimediadaten.

Durch die Struktur der SILC-Netze werden Netsplits, welche bei IRC auftreten können, verhindert.

Bestandteile des Protokolls

Das SILC-Protokoll kann in drei Hauptbestandteile gegliedert werden:

  1. SILC-Schlüsselaustauschprotokoll (SILC Key Exchange (SKE) protocol)
  2. SILC-Authentifizierungsprotokoll
  3. SILC-Paketprotokoll.

Im SILC-Protokoll sind zusätzlich SILC-Befehle definiert welche verwendet werden um die SILC-Sitzung zu steuern.

Das SKE-Protokoll dient dazu einen Sitzungsschlüssel und andere Sicherheitsparameter, welche das SILC-Paket-Protokoll absichern, zu ermitteln. Das SKE selbst basiert auf dem Diffie-Hellman Schlüsselaustauschalgorithmus (eine Form der Asymmetrischen Kryptographie) und der Austausch wird mit digitalen Signaturen abgesichert. Das SILC-Authentifizierungsprotokoll wird nach einer erfolgreichen Ausführung des SKE-Protokolls angewandt um einen Client und/oder einen Server zu authentifizieren. Die Authentifizierung kann auf einer Passphrase oder auf digitalen Signaturen basieren und gestattet, wenn erfolgreich, Zugang zum entsprechenden SILC-Netzwerk. Das SILC-Paketprotokoll ist als sicheres Binärpaketprotokoll gedacht welches gewährleistet, dass der Inhalt eines jeden Pakets (bestehend aus einem Paket-Header und Paket-Nutzdaten) abgesichert und authentifiziert ist. Die Pakete werden mittels Algorithmen abgesichert die auf Symmetrischer Kryptographie beruhen und authentifiziert unter Verwendung des Message-Authentication-Code-Algorithmus, HMAC.

SILC-Kanäle (Gruppen) werden durch symmetrische Kanalschlüssel abgesichert. Optional ist es möglich alle Kanalnachrichten digital zu signieren. Auch ist es möglich Nachrichten mit einem privat generierten Kanalschlüssel, welcher im Voraus von den Kanalmitgliedern vereinbart wurde, abzusichern. Private Nachrichten zwischen Nutzern in einem SILC-Netzwerk werden mit Sitzungsschlüsseln abgesichert. Es ist allerdings möglich, das SKE-Protokoll zwischen zwei Nutzern anzuwenden und den generierten Schlüssel zu verwenden, um private Nachrichten abzusichern. Optional können private Nachrichten digital signiert werden. Wenn Nachrichten mit einem durch das SKE-Protokoll generierten Schlüsselmaterial oder einem im Voraus vereinbarten Schlüsselmaterial (zum Beispiel Passphrasen) abgesichert sind, dann bietet SILC sogar dann Sicherheit, wenn der SILC-Server kompromittiert worden sein könnte.

Geschichte

SILC wurde von Pekka Riikonen entworfen und erstmals im Sommer 2000 veröffentlicht.

Implementierungen

Clients

NamePlattform(en)LizenzInternetauftritt
PidginWindows/Linux & Unices (GIMP-Toolkit)GPLhttp://pidgin.im/
SilkyWindows/Linux & Unices (GIMP-Toolkit)GPLhttp://silky.sourceforge.net/
ColloquyMac OS X (Cocoa)GPLhttp://colloquy.info/
irssi mit SILC-Plug-inLinux & Unices (Kommandozeile)GPLhttp://penguin-breeder.org/silc/
SILC ClientWindows/Linux & Unices (Kommandozeile)GPLhttp://silcnet.org/
kopete_silcLinux & UnicesGPLhttp://www.brokenpipe.de/hp/wiki.cgi/KopeteSilc

Bots

Netzwerke

Diese Auflistung erhebt keinen Anspruch auf Vollständigkeit.

NetzwerkRound RobinEinzelserverServerlisten und InfosMotto, Beschreibung, BesonderheitAngemeldete Clients
1. Nov. 07 zwischen 22:45 und 23:00
SILCNetsilc.silcnet.orghttp://silcnet.org/»SILC Network (SILCNet) is the very first SILC network, and is also the official SILC network.«408
silcnyetsilc.silcnyet.orghttp://silcnyet.org/»where crypto matters«22
c3d2 (CCC Dresden)silc.c3d2.de bzw. silc.dresden.ccc.dehttps://www.c3d2.de/wiki/SILCsilc.toidinamai.de ist auch erreichbar als Tor hidden service via t3oisyiugzgvxph5.onion30
compsecsilc.compsec.nethttp://www.compsec.net…165
luusasilc.luusa.orghttp://www.luusa.org…Linux/Unix Usergroup Sankt Augustin19
Netz ohne Namen
silc.riseup.net
silc.immerda.ch
Dieses Netz hat keinen Namen.40
Étoilé Projektsilc.etoile-project.org1
NMRC-NEThell.nmrc.org
silc.caughq.org
dodo.unspecific.com
cheshire.unspecific.com
DC214 und NMRC27
FFII Schweizsilc.bsdprojects.net
penrose.bsdprojects.net
7
SFOBUGsilc.sfobug.orgSan Francisco OpenBSD Users Group2
zertiessilc.brokenpipe.dehttps://www.zerties.org…cccrbg7
silc.perl.ltsilc.perl.lt
tornado.ktu.lt
http://silc.perl.lt…Litauisch6
Networldsilc.networld.tohttp://silc.networld.toA small SILC Server which can be used by everybody and is used by MokSec.6
NetzwerkRound RobinEinzelserverServerlisten und InfosMotto, Beschreibung, BesonderheitAngemeldete Clients
1. Nov. 07 zwischen 22:45 und 23:00

Siehe auch

Weblinks