X-Git-Url: https://git.sesse.net/?p=cubemap;a=blobdiff_plain;f=config.h;h=b5461cceae1f0978cce52d53a82de1b2cca95655;hp=d45ab08316b318c3e717d6c4a37252f047b0a9c5;hb=6a647d84c4a76fba4f91fcb75ab8185dc7628d67;hpb=2c6cd9718a5baf5a2ed5be73ec3c525d4873f45a diff --git a/config.h b/config.h index d45ab08..b5461cc 100644 --- a/config.h +++ b/config.h @@ -3,31 +3,69 @@ // Various routines that deal with parsing the configuration file. -#include +#include +#include +#include #include +#include -struct MarkPoolConfig { - int from, to; +struct StreamConfig { + std::string url; // As seen by the client. + std::string hls_url; // As seen by the client. Can be empty. + std::string src; // Can be empty. + size_t backlog_size; + size_t prebuffering_bytes; + uint32_t pacing_rate; // In bytes per second. Default is ~0U (no limit). + enum Encoding { STREAM_ENCODING_RAW = 0, STREAM_ENCODING_METACUBE }; + Encoding encoding; + Encoding src_encoding; + std::string allow_origin; + + // These only matter if hls_url is nonempty. + int hls_frag_duration = 6; // Apple recommendation (“HLS Authoring Specification for Apple Devices”, point 7.5). + size_t hls_backlog_margin = 0; }; -struct StreamConfig { - std::string stream_id; +struct UDPStreamConfig { + sockaddr_in6 dst; std::string src; // Can be empty. - int mark_pool; // -1 for none. + uint32_t pacing_rate; // In bytes per second. Default is ~0U (no limit). + int ttl; // Default is -1 (use operating system default). + int multicast_iface_index; // Default is -1 (use operating system default). +}; + +struct Gen204Config { + std::string url; // As seen by the client. + std::string allow_origin; // Can be empty. }; struct AcceptorConfig { - int port; + sockaddr_in6 addr; + + std::string certificate_chain, private_key; // In PEM format. +}; + +struct LogConfig { + enum { LOG_TYPE_FILE, LOG_TYPE_CONSOLE, LOG_TYPE_SYSLOG } type; + std::string filename; }; struct Config { + bool daemonize; int num_servers; - std::vector mark_pools; std::vector streams; + std::vector udpstreams; + std::vector pings; std::vector acceptors; + std::vector log_destinations; std::string stats_file; // Empty means no stats file. int stats_interval; + + std::string input_stats_file; // Empty means no input stats file. + int input_stats_interval; + + std::string access_log_file; // Empty means no accses_log file. }; // Parse and validate configuration. Returns false on error.