/* * 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 { namespace TLS { /** * TLS Server */ class BOTAN_DLL Server : public Channel { public: /** * Server initialization */ Server(std::tr1::function socket_output_fn, std::tr1::function proc_fn, std::tr1::function handshake_complete, Session_Manager& session_manager, Credentials_Manager& creds, const 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 Policy& policy; RandomNumberGenerator& rng; Session_Manager& session_manager; Credentials_Manager& creds; std::vector m_possible_protocols; std::string m_hostname; std::string m_next_protocol; }; } } #endif