X-Git-Url: https://git.sesse.net/?p=cubemap;a=blobdiff_plain;f=config.h;h=b5461cceae1f0978cce52d53a82de1b2cca95655;hp=cf3fdfbfb189d9d936e83c9cc2860decc9450937;hb=6a647d84c4a76fba4f91fcb75ab8185dc7628d67;hpb=8cdf715a5a6320a0b8c1152a28c40bc0dd86676b diff --git a/config.h b/config.h index cf3fdfb..b5461cc 100644 --- a/config.h +++ b/config.h @@ -9,26 +9,40 @@ #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; - int mark_pool; // -1 for none. - enum { STREAM_ENCODING_RAW = 0, STREAM_ENCODING_METACUBE } encoding; + 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 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 { @@ -39,15 +53,18 @@ struct LogConfig { 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. };