/* * 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 namespace Botan { namespace TLS { /** * TLS Server */ class BOTAN_DLL Server : public Channel { public: /** * Server initialization */ Server(std::function socket_output_fn, std::function proc_fn, std::function handshake_complete, Session_Manager& session_manager, Credentials_Manager& creds, const Policy& policy, RandomNumberGenerator& rng, const std::vector& protocols = std::vector()); /** * 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 initiate_handshake(Handshake_State& state, bool force_full_renegotiation) override; void process_handshake_msg(const Handshake_State* active_state, Handshake_State& pending_state, Handshake_Type type, const std::vector& contents) override; Handshake_State* new_handshake_state() override; const Policy& m_policy; Credentials_Manager& m_creds; std::vector m_possible_protocols; std::string m_hostname; std::string m_next_protocol; }; } } #endif