Copyright © 2001 - 2005 SILC Project
SILC Project Website
SILC Toolkit Reference Manual
Index

SILC Toolkit Reference Manual
SILC Core Library
    SILC Authentication Interface
    SILC Message Interface
    SILC Channel Interface
    SILC Command Interface
    SILC Notify Interface
    SILC Status Types
    SILC Modes
    SILC ID Interface
    SILC ID Cache Interface
    SILC Argument Interface
    SILC Attributes Interface
    Packet Protocol Interface
SILC Utility Library
    Basic SILC Types
    SILC Buffer Interface
    SILC Buffer Format Interface
    SILC Hash Table Interface
    SILC Logging Interface
    SILC Memory Interface
    SILC Mutex Interface
    SILC Thread Interface
    SILC Network Interface
    SILC Schedule Interface
    SILC Socket Interface
    SILC Protocol Interface
    SILC Config Interface
    SILC File Util Interface
    SILC String Util Interface
    SILC UTF-8 Interface
    SILC Stringprep Interface
    SILC Util Interface
    SILC List Interface
    SILC Dynamic List Interface
    SILC VCard Interface
    SILC Application Utilities
    SILC MIME Interface
SILC Crypto Library
    Introduction to SILC RNG
    SILC RNG Interface
    SILC Cipher API
    SILC PKCS API
    SILC PKCS#1 API
    SILC Hash Interface
    SILC HMAC Interface
SILC SFTP Library
    SILC SFTP Interface
    SFTP Filesystems Interface
SILC Client Library
    Using SILC Client Library Tutorial
    Arguments for command_reply Client Operation
    SilcStatus Error Arguments in command_reply Client Operation
    Arguments for notify Client Operation
    Unicode and UTF-8 Strings in Client Library
    Client Library Interface Reference
SILC Key Exchange Library
    SILC SKE Interface
    SKE Status Types
    SKE Diffie Hellman Groups
    SKE Payloads
SILC Math Library
    SILC MP Interface
    SILC Math Interface

Resource Links
SILC Project Website
SILC Protocol Documentation
SILC White Paper
SILC FAQs





silcske.html
SILC SKE Interface
Header: silcske.h

DESCRIPTION

 Implementation of the SILC Key Exchange Protocol (SKE). The SKE protocol
 is used to negotiate secret key material between two parties, to be used
 as session key or some other key. For example, when client connects to
 server SKE is performed to exchange public keys, and to generate the key
 that is then used as session key. Two clients can execute SKE as well
 two create secret key material for securing for example file transfer
 stream.

 SKE is based on Diffie-Hellman, and it derives its functionality from
 SSH2 Key Exchange protocol, OAKLEY Key Determination protocol and
 Station-To-Station (STS) protocols.

 This SKE implementation provides easy interface for application
 that wants to use SKE. In fact, the interface is designed to be 
 application independent, and does not expect that the application using
 SKE would actually relate in any way to SILC. Hence, the interface
 can be used in any kind of application needing to perform key exchange
 protocol with two parties. The network connection is also handled
 outside the SKE interface. For the interface application must provide
 a packet sending function which SKE library can call when it wants
 to send packet to the remote host. The actual network connection
 therefore is handled in the application and not by the SKE library.

 The protocol has initiator and responder. The initiator is the one
 that starts the protocol, and the responder is the one that receives
 negotiation request. The protocol has phases, and the interface is
 split into several phases that the application may call when
 needed. Heavy operations has been splitted so that application may
 call next phase with a timeout to give processing times to other
 things in the application. On the other hand, if application does
 not care about this it may call the phases immediately without any
 timeout.

  • SilcSKE
  • SilcSKESecurityProperties
  • SilcSKEPKType
  • SilcSKESendPacketCb
  • SilcSKECb
  • SilcSKEVerifyCbCompletion
  • SilcSKEVerifyCb
  • SilcSKECheckVersion
  • SilcSKEKeyMaterial
  • SilcSKESecurityPropertyFlag
  • SilcSKESecurityPropertiesStruct
  • SilcSKEStruct
  • silc_ske_alloc
  • silc_ske_free
  • silc_ske_set_callbacks
  • silc_ske_initiator_start
  • silc_ske_initiator_phase_1
  • silc_ske_initiator_phase_2
  • silc_ske_initiator_finish
  • silc_ske_responder_start
  • silc_ske_responder_phase_1
  • silc_ske_responder_phase_2
  • silc_ske_responder_finish
  • silc_ske_end
  • silc_ske_abort
  • silc_ske_assemble_security_properties
  • silc_ske_select_security_properties
  • silc_ske_process_key_material
  • silc_ske_process_key_material_data
  • silc_ske_free_key_material
  • silc_ske_parse_version








  • Copyright © 2001 - 2005 SILC Project
    SILC Project Website
    SILC Toolkit Reference Manual
    Index