Refactor configuration (work in progress)
* Move -m and -n command line options into the config file
* Restructure configuration file:
- Group into "server", "stream", "media", "metadata", "decoders", and
"encoders"
- Untangle decoder and encoder:
o Decoders match on file extensions and convert to a canonical "internal"
format
o Encoders create one of the supported stream formats, potentially using
different parameters (like bitrate)
- Consistently specify stream format
- Enable reencoding by selecting an encoder
* Architecturally separate configuration file storage from parsing
- Allows for different configuration back-ends in the future, like
YAML, SQL, REST API, ...
* Support roll-back in case of error on (re)load
* Anticipate HTTPS support
2015-05-02 06:48:53 -04:00
|
|
|
<?xml version="1.0" encoding="UTF-8"?>
|
|
|
|
|
2015-05-21 12:50:22 -04:00
|
|
|
<!--
|
|
|
|
EXAMPLE: A valid configuration that contains every configuration option
|
2015-05-21 17:30:51 -04:00
|
|
|
|
|
|
|
NB: /ezstream/metadata/program is commented out so that this configuration
|
|
|
|
can work without scripting.
|
2015-05-21 12:50:22 -04:00
|
|
|
-->
|
|
|
|
|
|
|
|
<!-- Ezstream configuration root element -->
|
Refactor configuration (work in progress)
* Move -m and -n command line options into the config file
* Restructure configuration file:
- Group into "server", "stream", "media", "metadata", "decoders", and
"encoders"
- Untangle decoder and encoder:
o Decoders match on file extensions and convert to a canonical "internal"
format
o Encoders create one of the supported stream formats, potentially using
different parameters (like bitrate)
- Consistently specify stream format
- Enable reencoding by selecting an encoder
* Architecturally separate configuration file storage from parsing
- Allows for different configuration back-ends in the future, like
YAML, SQL, REST API, ...
* Support roll-back in case of error on (re)load
* Anticipate HTTPS support
2015-05-02 06:48:53 -04:00
|
|
|
<ezstream>
|
|
|
|
|
2015-05-21 12:50:22 -04:00
|
|
|
<!--
|
|
|
|
Server configuration
|
|
|
|
-->
|
2017-11-17 19:54:14 -05:00
|
|
|
<servers>
|
|
|
|
<server>
|
|
|
|
<!-- Identifying name; default: "default" -->
|
|
|
|
<name>Default</name>
|
|
|
|
|
|
|
|
<!-- Transport protocol: HTTP, HTTPS -->
|
|
|
|
<protocol>HTTP</protocol>
|
|
|
|
<!-- Server address -->
|
|
|
|
<hostname>127.0.0.1</hostname>
|
|
|
|
<!-- Server port -->
|
|
|
|
<port>8000</port>
|
|
|
|
|
|
|
|
<!-- Login user -->
|
|
|
|
<user>source</user>
|
|
|
|
<!-- Login password (check file permissions, or everyone can see this) -->
|
|
|
|
<password>hackme</password>
|
|
|
|
|
|
|
|
<!-- Number of reconnection attempts, before giving up: -->
|
|
|
|
<reconnect_attempts>0</reconnect_attempts>
|
|
|
|
|
|
|
|
<!--
|
|
|
|
Configure TLS encryption requirement: none, may (default), required
|
|
|
|
-->
|
|
|
|
<tls>Required</tls>
|
|
|
|
|
|
|
|
<!--
|
|
|
|
Configure allowed cipher suites for TLS other than the libshout default.
|
|
|
|
See openssl(1)/ciphers(1) for details.
|
|
|
|
-->
|
|
|
|
<tls_cipher_suite>HIGH:!kRSA:!kECDH:!DH:!PKS:!aNULL:!eNULL:!3DES:!MD5:!SHA:!TLSv1</tls_cipher_suite>
|
|
|
|
|
|
|
|
<!--
|
|
|
|
Directory to use for server certificate verification in "hash format".
|
|
|
|
See openssl(1)/verify(1) for details.
|
|
|
|
-->
|
|
|
|
<ca_dir>/etc/ssl/certs</ca_dir>
|
|
|
|
|
|
|
|
<!--
|
|
|
|
CA bundle for both server certificate verification and building the
|
|
|
|
client certificate chain.
|
|
|
|
-->
|
|
|
|
<ca_file>/etc/ssl/certs/ca-certificates.crt</ca_file>
|
|
|
|
|
|
|
|
<!--
|
|
|
|
X.503 client certificate, in PEM format, containing both certificate
|
|
|
|
(with public key) and private key in the same file, for authentication.
|
|
|
|
-->
|
|
|
|
<client_cert>/etc/ssl/ezstream.crt</client_cert>
|
|
|
|
</server>
|
|
|
|
</servers>
|
Refactor configuration (work in progress)
* Move -m and -n command line options into the config file
* Restructure configuration file:
- Group into "server", "stream", "media", "metadata", "decoders", and
"encoders"
- Untangle decoder and encoder:
o Decoders match on file extensions and convert to a canonical "internal"
format
o Encoders create one of the supported stream formats, potentially using
different parameters (like bitrate)
- Consistently specify stream format
- Enable reencoding by selecting an encoder
* Architecturally separate configuration file storage from parsing
- Allows for different configuration back-ends in the future, like
YAML, SQL, REST API, ...
* Support roll-back in case of error on (re)load
* Anticipate HTTPS support
2015-05-02 06:48:53 -04:00
|
|
|
|
2015-05-21 12:50:22 -04:00
|
|
|
<!--
|
|
|
|
Stream configuration
|
|
|
|
-->
|
2017-11-17 19:54:14 -05:00
|
|
|
<streams>
|
|
|
|
<stream>
|
|
|
|
<!-- Identifying name; default: "default" -->
|
|
|
|
<name>Default</name>
|
|
|
|
|
|
|
|
<!-- Mount point on server -->
|
|
|
|
<mountpoint>/stream.ogg</mountpoint>
|
|
|
|
|
2017-11-23 12:34:57 -05:00
|
|
|
<!-- Name of the intake entry to use (default: "default") -->
|
|
|
|
<intake>Default</intake>
|
|
|
|
|
2017-11-17 19:54:14 -05:00
|
|
|
<!-- Name of the server entry to use (default: "default") -->
|
|
|
|
<server>Default</server>
|
|
|
|
|
|
|
|
<!-- Setting to allow stream to be listed in public YP directory -->
|
|
|
|
<public>No</public>
|
|
|
|
|
|
|
|
<!-- Stream format: Vorbis, MP3, Theora -->
|
|
|
|
<format>Vorbis</format>
|
|
|
|
|
|
|
|
<!-- Encoder name (defined below) to use for (re)encoding -->
|
|
|
|
<encoder>OggEnc-Q1.5</encoder>
|
|
|
|
|
|
|
|
<!-- Various other informational settings -->
|
|
|
|
<stream_name>Test Stream</stream_name>
|
|
|
|
<stream_url>http://localhost:8000/</stream_url>
|
|
|
|
<stream_genre>Beeps</stream_genre>
|
|
|
|
<stream_description>Test tones and noise</stream_description>
|
|
|
|
<stream_quality>1.5</stream_quality>
|
|
|
|
<stream_bitrate>16</stream_bitrate>
|
|
|
|
<stream_samplerate>44100</stream_samplerate>
|
|
|
|
<stream_channels>2</stream_channels>
|
|
|
|
</stream>
|
|
|
|
</streams>
|
Refactor configuration (work in progress)
* Move -m and -n command line options into the config file
* Restructure configuration file:
- Group into "server", "stream", "media", "metadata", "decoders", and
"encoders"
- Untangle decoder and encoder:
o Decoders match on file extensions and convert to a canonical "internal"
format
o Encoders create one of the supported stream formats, potentially using
different parameters (like bitrate)
- Consistently specify stream format
- Enable reencoding by selecting an encoder
* Architecturally separate configuration file storage from parsing
- Allows for different configuration back-ends in the future, like
YAML, SQL, REST API, ...
* Support roll-back in case of error on (re)load
* Anticipate HTTPS support
2015-05-02 06:48:53 -04:00
|
|
|
|
2015-05-21 12:50:22 -04:00
|
|
|
<!--
|
2017-11-23 12:34:57 -05:00
|
|
|
Intake configuration
|
2015-05-21 12:50:22 -04:00
|
|
|
-->
|
2017-11-23 12:34:57 -05:00
|
|
|
<intakes>
|
|
|
|
<intake>
|
|
|
|
<!-- Identifying name; default: "default" -->
|
|
|
|
<name>Default</name>
|
|
|
|
|
|
|
|
<!-- Media type: autodetect, file, playlist, program, stdin -->
|
|
|
|
<type>autodetect</type>
|
2015-05-21 12:50:22 -04:00
|
|
|
|
2017-11-23 12:34:57 -05:00
|
|
|
<!-- Input file, program name, or "stdin" keyword -->
|
|
|
|
<filename>playlist.m3u</filename>
|
2015-05-21 12:50:22 -04:00
|
|
|
|
2017-11-23 12:34:57 -05:00
|
|
|
<!-- Setting to shuffle playlists -->
|
|
|
|
<shuffle>Yes</shuffle>
|
2015-05-21 12:50:22 -04:00
|
|
|
|
2017-11-23 12:34:57 -05:00
|
|
|
<!-- Setting whether to stream intake indefinitely or only once -->
|
|
|
|
<stream_once>No</stream_once>
|
|
|
|
</intake>
|
|
|
|
</intakes>
|
Refactor configuration (work in progress)
* Move -m and -n command line options into the config file
* Restructure configuration file:
- Group into "server", "stream", "media", "metadata", "decoders", and
"encoders"
- Untangle decoder and encoder:
o Decoders match on file extensions and convert to a canonical "internal"
format
o Encoders create one of the supported stream formats, potentially using
different parameters (like bitrate)
- Consistently specify stream format
- Enable reencoding by selecting an encoder
* Architecturally separate configuration file storage from parsing
- Allows for different configuration back-ends in the future, like
YAML, SQL, REST API, ...
* Support roll-back in case of error on (re)load
* Anticipate HTTPS support
2015-05-02 06:48:53 -04:00
|
|
|
|
2015-05-21 12:50:22 -04:00
|
|
|
<!--
|
|
|
|
Metadata configuration
|
|
|
|
-->
|
Refactor configuration (work in progress)
* Move -m and -n command line options into the config file
* Restructure configuration file:
- Group into "server", "stream", "media", "metadata", "decoders", and
"encoders"
- Untangle decoder and encoder:
o Decoders match on file extensions and convert to a canonical "internal"
format
o Encoders create one of the supported stream formats, potentially using
different parameters (like bitrate)
- Consistently specify stream format
- Enable reencoding by selecting an encoder
* Architecturally separate configuration file storage from parsing
- Allows for different configuration back-ends in the future, like
YAML, SQL, REST API, ...
* Support roll-back in case of error on (re)load
* Anticipate HTTPS support
2015-05-02 06:48:53 -04:00
|
|
|
<metadata>
|
2015-05-21 12:50:22 -04:00
|
|
|
<!-- Program to query for metadata instead of from media files -->
|
2017-09-15 12:52:47 -04:00
|
|
|
<!-- <program>meta.sh</program> -->
|
2015-05-21 12:50:22 -04:00
|
|
|
|
|
|
|
<!-- Metadata format -->
|
|
|
|
<format_str>@a@ - @t@</format_str>
|
|
|
|
|
|
|
|
<!-- Interval for additional metadata refreshes (-1 for none) -->
|
|
|
|
<refresh_interval>-1</refresh_interval>
|
|
|
|
|
|
|
|
<!-- Setting to clean up extraneous whitespace -->
|
|
|
|
<normalize_strings>Yes</normalize_strings>
|
|
|
|
|
|
|
|
<!-- Setting to suppress all metadata udpates -->
|
|
|
|
<no_updates>No</no_updates>
|
Refactor configuration (work in progress)
* Move -m and -n command line options into the config file
* Restructure configuration file:
- Group into "server", "stream", "media", "metadata", "decoders", and
"encoders"
- Untangle decoder and encoder:
o Decoders match on file extensions and convert to a canonical "internal"
format
o Encoders create one of the supported stream formats, potentially using
different parameters (like bitrate)
- Consistently specify stream format
- Enable reencoding by selecting an encoder
* Architecturally separate configuration file storage from parsing
- Allows for different configuration back-ends in the future, like
YAML, SQL, REST API, ...
* Support roll-back in case of error on (re)load
* Anticipate HTTPS support
2015-05-02 06:48:53 -04:00
|
|
|
</metadata>
|
|
|
|
|
2015-05-21 12:50:22 -04:00
|
|
|
<!--
|
|
|
|
Decoder configurations
|
|
|
|
-->
|
Refactor configuration (work in progress)
* Move -m and -n command line options into the config file
* Restructure configuration file:
- Group into "server", "stream", "media", "metadata", "decoders", and
"encoders"
- Untangle decoder and encoder:
o Decoders match on file extensions and convert to a canonical "internal"
format
o Encoders create one of the supported stream formats, potentially using
different parameters (like bitrate)
- Consistently specify stream format
- Enable reencoding by selecting an encoder
* Architecturally separate configuration file storage from parsing
- Allows for different configuration back-ends in the future, like
YAML, SQL, REST API, ...
* Support roll-back in case of error on (re)load
* Anticipate HTTPS support
2015-05-02 06:48:53 -04:00
|
|
|
<decoders>
|
|
|
|
<decoder>
|
2015-05-21 12:50:22 -04:00
|
|
|
<!-- Decoder name -->
|
|
|
|
<name>OggDec</name>
|
|
|
|
<!-- Program and options -->
|
2015-05-21 17:30:51 -04:00
|
|
|
<program>oggdec -R -b 16 -e 1 -s 1 -o - @T@</program>
|
2015-05-21 12:50:22 -04:00
|
|
|
<!-- File extensions to use this decoder for -->
|
|
|
|
<file_ext>.ogg</file_ext>
|
|
|
|
<file_ext>.oga</file_ext>
|
|
|
|
</decoder>
|
|
|
|
|
|
|
|
<decoder>
|
|
|
|
<name>MadPlay</name>
|
|
|
|
<program>madplay -b 16 -R 44100 -S -o raw:- @T@</program>
|
|
|
|
<file_ext>.mp3</file_ext>
|
|
|
|
</decoder>
|
|
|
|
|
|
|
|
<decoder>
|
|
|
|
<name>Flac</name>
|
|
|
|
<program>flac -s -d --force-raw-format --sign=signed --endian=little -o - @T@</program>
|
|
|
|
<file_ext>.flac</file_ext>
|
Refactor configuration (work in progress)
* Move -m and -n command line options into the config file
* Restructure configuration file:
- Group into "server", "stream", "media", "metadata", "decoders", and
"encoders"
- Untangle decoder and encoder:
o Decoders match on file extensions and convert to a canonical "internal"
format
o Encoders create one of the supported stream formats, potentially using
different parameters (like bitrate)
- Consistently specify stream format
- Enable reencoding by selecting an encoder
* Architecturally separate configuration file storage from parsing
- Allows for different configuration back-ends in the future, like
YAML, SQL, REST API, ...
* Support roll-back in case of error on (re)load
* Anticipate HTTPS support
2015-05-02 06:48:53 -04:00
|
|
|
</decoder>
|
|
|
|
</decoders>
|
|
|
|
|
2015-05-21 12:50:22 -04:00
|
|
|
<!--
|
|
|
|
Encoder configurations
|
|
|
|
-->
|
Refactor configuration (work in progress)
* Move -m and -n command line options into the config file
* Restructure configuration file:
- Group into "server", "stream", "media", "metadata", "decoders", and
"encoders"
- Untangle decoder and encoder:
o Decoders match on file extensions and convert to a canonical "internal"
format
o Encoders create one of the supported stream formats, potentially using
different parameters (like bitrate)
- Consistently specify stream format
- Enable reencoding by selecting an encoder
* Architecturally separate configuration file storage from parsing
- Allows for different configuration back-ends in the future, like
YAML, SQL, REST API, ...
* Support roll-back in case of error on (re)load
* Anticipate HTTPS support
2015-05-02 06:48:53 -04:00
|
|
|
<encoders>
|
|
|
|
<encoder>
|
2015-05-21 12:50:22 -04:00
|
|
|
<!-- Encoder name -->
|
|
|
|
<name>OggEnc-Q1.5</name>
|
|
|
|
<!-- Output stream format -->
|
|
|
|
<format>Vorbis</format>
|
|
|
|
<!-- Program and options -->
|
2017-09-15 12:57:40 -04:00
|
|
|
<program>oggenc -r -B 16 -C 2 -R 44100 --raw-endianness 1 -q 1.5 -t @M@ -</program>
|
2015-05-21 12:50:22 -04:00
|
|
|
</encoder>
|
|
|
|
|
|
|
|
<encoder>
|
|
|
|
<name>Lame-CBR128</name>
|
|
|
|
<format>MP3</format>
|
|
|
|
<program>lame --preset cbr 128 -r -s 44.1 --bitwidth 16 - -</program>
|
Refactor configuration (work in progress)
* Move -m and -n command line options into the config file
* Restructure configuration file:
- Group into "server", "stream", "media", "metadata", "decoders", and
"encoders"
- Untangle decoder and encoder:
o Decoders match on file extensions and convert to a canonical "internal"
format
o Encoders create one of the supported stream formats, potentially using
different parameters (like bitrate)
- Consistently specify stream format
- Enable reencoding by selecting an encoder
* Architecturally separate configuration file storage from parsing
- Allows for different configuration back-ends in the future, like
YAML, SQL, REST API, ...
* Support roll-back in case of error on (re)load
* Anticipate HTTPS support
2015-05-02 06:48:53 -04:00
|
|
|
</encoder>
|
|
|
|
</encoders>
|
|
|
|
|
|
|
|
</ezstream>
|