- SILC (protocol)
SILC (Secure Internet Live Conferencing protocol) is a protocol that provides secure
synchronous conferencing services over theInternet .Components
The SILC protocol can be divided in three main parts: SILC Key Exchange (SKE) protocol, SILC Authentication protocol and SILC Packet protocol. SILC protocol additionally defines SILC Commands that are used to manage the SILC session. SILC provides channels (groups), nicknames, private messages, and other common features. However, SILC nicknames, in contrast to many other protocols ("e.g." IRC), are not unique; a user is able to use any nickname, even if one is already in use. The real identification in the protocol is performed by unique Client ID [ [http://www.silcnet.org/general/about/features.php SILC Secure Internet Live Conferencing ] ] . The SILC protocol uses this to overcome nickname collision, a problem present in many other protocols. All messages sent in a SILC network are binary, allowing them to contain any type of data, including text, video, audio, and other
multimedia data.The SKE protocol is used to establishsession key and other security parameters for protecting the SILC Packet protocol. The SKE itself is based on theDiffie-Hellman key exchange algorithm (a form ofasymmetric cryptography ) and the exchange is protected withdigital signatures . The SILC Authentication protocol is performed after successful SKE protocol execution to authenticate a client and/or a server. The authentication may be based onpassphrase or ondigital signatures , and if successful gives access to the relevant SILC network. The SILC Packet protocol is intended to be a secure binary packet protocol, assuring that the content of each packet (consisting of a packet header and packet payload) is secured and authenticated. The packets are secured using algorithms based onsymmetric cryptography and authenticated by usingMessage Authentication Code algorithm,HMAC .SILC channels (groups) are protected by using symmetric channel keys. It is optionally possible to digitally sign all channel messages. It is also possible to protect messages with a privately-generated channel key that has been previously agreed upon by channel members. Private messages between users in a SILC network are protected with session keys. It is, however, possible to execute SKE protocol between two users and use the generated key to protect private messages. Private messages may be optionally digitally signed. When messages are secured with key material generated with the SKE protocol or previously agreed upon key material (for example,
passphrase s) SILC provides security even when the SILC server may be compromised.History
SILC was designed by
Pekka Riikonen between1996 and1999 and first released in public in summer2000 [ [http://www.silcnet.org/general/history.php SILC Secure Internet Live Conferencing ] ] . A client and a server were written. Protocol specifications have been iterated through theIETF . At present time, there are several clients, the most advanced being the official SILC client and anirssi plugin. SILC protocol is also integrated to the popular Pidgin instant messaging client. OtherGUI clients are Silky and Colloquy.The Silky client was put on hold and abandoned on the 18th of July 2007, due to inactivity for a couple of years [ [http://sourceforge.net/forum/forum.php?forum_id=717434 SourceForge.net: project closed ] ] . The latest news on the Silky website was that the client was to be completely rewritten.As of 2008, three SILC protocol implementations have been written [http://silcnet.org/community/links/] .Most SILC clients use libsilc, part of the SILC Toolkit.The SILC Toolkit is dual-licensed and distributed under both the GNU General Public License (GPL) and the revised BSD license [http://silcnet.org/software/developers/toolkit/licensing.php] .
See also
*
Synchronous conferencing
*Comparison of instant messaging protocols
*Multiprotocol instant messaging application
*Public-key cryptography References
External links
* [http://www.silcnet.org The SILC Project]
* [http://silky.sf.net Silky, GUI SILC client]
* [http://brokenpipe.de/hp/wiki.cgi/SilcImproved Silc Improved, minimalistic SILC client using FIFOs]
* [http://brokenpipe.de/hp/wiki.cgi/KopeteSilc Kopete SILC Plugin]
* [http://sourceforge.net/projects/ede/ Silsa, GUI SILC Client, part of Equinox Desktop Environment (EDE)]
Wikimedia Foundation. 2010.