// Copyright (c) 2011 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #include "net/tools/flip_server/flip_config.h" #include <unistd.h> namespace net { FlipAcceptor::FlipAcceptor(enum FlipHandlerType flip_handler_type, std::string listen_ip, std::string listen_port, std::string ssl_cert_filename, std::string ssl_key_filename, std::string http_server_ip, std::string http_server_port, std::string https_server_ip, std::string https_server_port, int spdy_only, int accept_backlog_size, bool disable_nagle, int accepts_per_wake, bool reuseport, bool wait_for_iface, void* memory_cache) : flip_handler_type_(flip_handler_type), listen_ip_(listen_ip), listen_port_(listen_port), ssl_cert_filename_(ssl_cert_filename), ssl_key_filename_(ssl_key_filename), http_server_ip_(http_server_ip), http_server_port_(http_server_port), https_server_ip_(https_server_ip), https_server_port_(https_server_port), spdy_only_(spdy_only), accept_backlog_size_(accept_backlog_size), disable_nagle_(disable_nagle), accepts_per_wake_(accepts_per_wake), memory_cache_(memory_cache), ssl_session_expiry_(300), // TODO(mbelshe): Hook these up! ssl_disable_compression_(false), idle_socket_timeout_s_(300) { VLOG(1) << "Attempting to listen on " << listen_ip_.c_str() << ":" << listen_port_.c_str(); if (!https_server_ip_.size()) https_server_ip_ = http_server_ip_; if (!https_server_port_.size()) https_server_port_ = http_server_port_; while (1) { int ret = CreateListeningSocket(listen_ip_, listen_port_, true, accept_backlog_size_, true, reuseport, wait_for_iface, disable_nagle_, &listen_fd_); if (ret == 0) { break; } else if (ret == -3 && wait_for_iface) { // Binding error EADDRNOTAVAIL was encounted. We need // to wait for the interfaces to raised. try again. usleep(200000); } else { LOG(ERROR) << "Unable to create listening socket for: ret = " << ret << ": " << listen_ip_.c_str() << ":" << listen_port_.c_str(); return; } } FlipSetNonBlocking(listen_fd_); VLOG(1) << "Listening on socket: "; if (flip_handler_type == FLIP_HANDLER_PROXY) VLOG(1) << "\tType : Proxy"; else if (FLIP_HANDLER_SPDY_SERVER) VLOG(1) << "\tType : SPDY Server"; else if (FLIP_HANDLER_HTTP_SERVER) VLOG(1) << "\tType : HTTP Server"; VLOG(1) << "\tIP : " << listen_ip_; VLOG(1) << "\tPort : " << listen_port_; VLOG(1) << "\tHTTP Server : " << http_server_ip_ << ":" << http_server_port_; VLOG(1) << "\tHTTPS Server : " << https_server_ip_ << ":" << https_server_port_; VLOG(1) << "\tSSL : " << (ssl_cert_filename.size() ? "true" : "false"); VLOG(1) << "\tCertificate : " << ssl_cert_filename; VLOG(1) << "\tKey : " << ssl_key_filename; VLOG(1) << "\tSpdy Only : " << (spdy_only ? "true" : "false"); } FlipAcceptor::~FlipAcceptor() {} FlipConfig::FlipConfig() : server_think_time_in_s_(0), log_destination_(logging::LOG_TO_SYSTEM_DEBUG_LOG), wait_for_iface_(false) {} FlipConfig::~FlipConfig() {} void FlipConfig::AddAcceptor(enum FlipHandlerType flip_handler_type, std::string listen_ip, std::string listen_port, std::string ssl_cert_filename, std::string ssl_key_filename, std::string http_server_ip, std::string http_server_port, std::string https_server_ip, std::string https_server_port, int spdy_only, int accept_backlog_size, bool disable_nagle, int accepts_per_wake, bool reuseport, bool wait_for_iface, void* memory_cache) { // TODO(mbelshe): create a struct FlipConfigArgs{} for the arguments. acceptors_.push_back(new FlipAcceptor(flip_handler_type, listen_ip, listen_port, ssl_cert_filename, ssl_key_filename, http_server_ip, http_server_port, https_server_ip, https_server_port, spdy_only, accept_backlog_size, disable_nagle, accepts_per_wake, reuseport, wait_for_iface, memory_cache)); } } // namespace net