/* * TLS Server * (C) 2004-2011 Jack Lloyd * * Released under the terms of the Botan license */ #ifndef BOTAN_TLS_SERVER_H__ #define BOTAN_TLS_SERVER_H__ #include #include #include #include namespace Botan { /** * TLS Server */ class BOTAN_DLL TLS_Server : public TLS_Channel { public: /** * TLS_Server initialization */ TLS_Server(std::tr1::function socket_output_fn, std::tr1::function proc_fn, std::tr1::function handshake_complete, TLS_Session_Manager& session_manager, Credentials_Manager& creds, const TLS_Policy& policy, RandomNumberGenerator& rng, const std::vector& protocols = std::vector()); void renegotiate(); /** * Return the server name indicator, if sent by the client */ std::string server_name_indicator() const { return m_hostname; } /** * Return the protocol negotiated with NPN extension */ std::string next_protocol() const { return m_next_protocol; } private: void read_handshake(byte, const MemoryRegion&); void process_handshake_msg(Handshake_Type, const MemoryRegion&); void alert_notify(bool is_fatal, Alert_Type type); const TLS_Policy& policy; RandomNumberGenerator& rng; TLS_Session_Manager& session_manager; Credentials_Manager& creds; std::vector m_possible_protocols; std::string m_hostname; std::string m_next_protocol; }; } #endif