add Makefile to guide configuration and perform installation
This change replaces icecast.xml with icecast.xml.template. A complete icecast.xml is no-longer provided. Instead, to create icecast.xml run: make You can generate icecast.xml and then install it: make install This doesn't currently do any aspectss of making the system ready to run icecast (e.g. performing `sudo apt install icecast2`, or similar).
This commit is contained in:
316
icecast.xml.template
Normal file
316
icecast.xml.template
Normal file
@ -0,0 +1,316 @@
|
||||
<icecast>
|
||||
<location>The Island of Misfit Toys</location>
|
||||
<admin>yo@mammy</admin>
|
||||
<limits>
|
||||
<clients>17q000</clients>
|
||||
<sources>17</sources>
|
||||
<queue-size>524288</queue-size>
|
||||
<client-timeout>30</client-timeout>
|
||||
<header-timeout>15</header-timeout>
|
||||
<source-timeout>17</source-timeout>
|
||||
<!-- If enabled, this will provide a burst of data when a client
|
||||
first connects, thereby significantly reducing the startup
|
||||
time for listeners that do substantial buffering. However,
|
||||
it also significantly increases latency between the source
|
||||
client and listening client. For low-latency setups, you
|
||||
might want to disable this. -->
|
||||
<!-- <burst-on-connect>1</burst-on-connect> -->
|
||||
<!-- same as burst-on-connect, but this allows for being more
|
||||
specific on how much to burst. Most people won't need to
|
||||
change from the default 64k. Applies to all mountpoints -->
|
||||
<!-- <burst-size>65535</burst-size> -->
|
||||
</limits>
|
||||
|
||||
<authentication>
|
||||
<!-- Sources log in with username 'source' -->
|
||||
<source-password>@@Source_Pass@@</source-password>
|
||||
<!-- Relays log in with username 'relay' -->
|
||||
<relay-password>@@Relay_Pass@@</relay-password>
|
||||
<!-- Admin logs in with the username given below -->
|
||||
<admin-user>@@Admin_User@@</admin-user>
|
||||
<admin-password>@@Admin_Pass@@</admin-password>
|
||||
</authentication>
|
||||
|
||||
<!--
|
||||
<directory>
|
||||
<yp-url-timeout>15</yp-url-timeout>
|
||||
<yp-url>http://dir.xiph.org/cgi-bin/yp-cgi</yp-url>
|
||||
</directory>
|
||||
-->
|
||||
|
||||
<hostname>@@hostname@@</hostname>
|
||||
<listen-socket>
|
||||
<port>@@icecast2_port@@</port>
|
||||
</listen-socket>
|
||||
|
||||
<http-headers>
|
||||
<header name="Access-Control-Allow-Origin" value="*" />
|
||||
<header name="X-Clacks-Overhead" value="GNU Terry Pratchett" />
|
||||
</http-headers>
|
||||
|
||||
|
||||
<!-- Relaying
|
||||
You don't need this if you only have one server.
|
||||
Please refer to the documentation for a detailed explanation.
|
||||
-->
|
||||
<!--<master-server>127.0.0.1</master-server>-->
|
||||
<!--<master-server-port>8001</master-server-port>-->
|
||||
<!--<master-update-interval>120</master-update-interval>-->
|
||||
<!--<master-password>hackme</master-password>-->
|
||||
<!-- setting this makes all relays on-demand unless overridden, this is
|
||||
useful for master relays which do not have <relay> definitions here.
|
||||
The default is 0 -->
|
||||
<!--<relays-on-demand>1</relays-on-demand>-->
|
||||
<!--
|
||||
<relay>
|
||||
<server>127.0.0.1</server>
|
||||
<port>8080</port>
|
||||
<mount>/example.ogg</mount>
|
||||
<local-mount>/different.ogg</local-mount>
|
||||
<on-demand>0</on-demand>
|
||||
|
||||
<relay-shoutcast-metadata>0</relay-shoutcast-metadata>
|
||||
</relay>
|
||||
-->
|
||||
|
||||
|
||||
<!-- the default mount is the top of the fall-back chain
|
||||
anyone listening to something pushing to the default
|
||||
gets seomthing in our fallback chain, isntead.
|
||||
-->
|
||||
<mount type="default">
|
||||
<public>0</public>
|
||||
<!-- <intro>/server-wide-intro.ogg</intro> -->
|
||||
<!-- <max-listener-duration>3600</max-listener-duration> -->
|
||||
<username>live</username>
|
||||
<password>@@Source_Pass@@</password>
|
||||
<fallback-override>1</fallback-override>
|
||||
<fallback-mount>/live</fallback-mount>
|
||||
</mount>
|
||||
|
||||
<mount type="normal">
|
||||
<public>0</public>
|
||||
<mount-name>/live.ogg</mount-name>
|
||||
<username>live</username>
|
||||
<password>@@Source_Pass@@</password>
|
||||
<fallback-override>1</fallback-override>
|
||||
<fallback-mount>/gold.ogg</fallback-mount>
|
||||
</mount>
|
||||
<mount type="normal">
|
||||
<public>0</public>
|
||||
<mount-name>/gold.ogg</mount-name>
|
||||
<fallback-override>1</fallback-override>
|
||||
<fallback-mount>/purple.ogg</fallback-mount>
|
||||
<username>live</username>
|
||||
<password>@@Source_Pass@@</password>
|
||||
</mount>
|
||||
<mount type="normal">
|
||||
<public>0</public>
|
||||
<mount-name>/purple.ogg</mount-name>
|
||||
<fallback-override>1</fallback-override>
|
||||
<fallback-mount>/black.ogg</fallback-mount>
|
||||
<username>live</username>
|
||||
<password>@@Source_Pass@@</password>
|
||||
</mount>
|
||||
<mount type="normal">
|
||||
<public>0</public>
|
||||
<mount-name>/black.ogg</mount-name>
|
||||
<fallback-override>1</fallback-override>
|
||||
<fallback-mount>/silver.ogg</fallback-mount>
|
||||
<username>live</username>
|
||||
<password>@@Source_Pass@@</password>
|
||||
</mount>
|
||||
<mount type="normal">
|
||||
<public>0</public>
|
||||
<!-- <intro>/server-wide-intro.ogg</intro> -->
|
||||
<!-- <max-listener-duration>3600</max-listener-duration> -->
|
||||
<mount-name>/silver.ogg</mount-name>
|
||||
<fallback-override>1</fallback-override>
|
||||
<fallback-mount>/live.ogg</fallback-mount>
|
||||
<username>live</username>
|
||||
<password>@@Source_Pass@@</password>
|
||||
</mount>
|
||||
|
||||
<mount type="normal">
|
||||
<public>0</public>
|
||||
<fallback-override>1</fallback-override>
|
||||
<mount-name>/live</mount-name>
|
||||
<username>live</username>
|
||||
<password>@@Source_Pass@@</password>
|
||||
<fallback-override>1</fallback-override>
|
||||
<fallback-mount>/live.mp3</fallback-mount>
|
||||
</mount>
|
||||
<mount type="normal">
|
||||
<public>0</public>
|
||||
<mount-name>/live.mp3</mount-name>
|
||||
<username>live</username>
|
||||
<password>@@Source_Pass@@</password>
|
||||
<fallback-override>1</fallback-override>
|
||||
<fallback-mount>/gold</fallback-mount>
|
||||
</mount>
|
||||
|
||||
<mount type="normal">
|
||||
<public>0</public>
|
||||
<mount-name>/gold</mount-name>
|
||||
<fallback-override>1</fallback-override>
|
||||
<fallback-mount>/gold.mp3</fallback-mount>
|
||||
<username>live</username>
|
||||
<password>@@Source_Pass@@</password>
|
||||
</mount>
|
||||
<mount type="normal">
|
||||
<public>0</public>
|
||||
<mount-name>/gold.mp3</mount-name>
|
||||
<fallback-override>1</fallback-override>
|
||||
<fallback-mount>/gold.ogg</fallback-mount>
|
||||
<username>live</username>
|
||||
<password>@@Source_Pass@@</password>
|
||||
</mount>
|
||||
|
||||
<mount type="normal">
|
||||
<public>0</public>
|
||||
<mount-name>/purple</mount-name>
|
||||
<fallback-override>1</fallback-override>
|
||||
<fallback-mount>/purple.mp3</fallback-mount>
|
||||
<username>live</username>
|
||||
<password>@@Source_Pass@@</password>
|
||||
</mount>
|
||||
<mount type="normal">
|
||||
<public>0</public>
|
||||
<mount-name>/purple.mp3</mount-name>
|
||||
<fallback-override>1</fallback-override>
|
||||
<fallback-mount>/black</fallback-mount>
|
||||
<username>live</username>
|
||||
<password>@@Source_Pass@@</password>
|
||||
</mount>
|
||||
|
||||
<mount type="normal">
|
||||
<public>0</public>
|
||||
<!-- <intro>/server-wide-intro.ogg</intro> -->
|
||||
<!-- <max-listener-duration>3600</max-listener-duration> -->
|
||||
<mount-name>/black</mount-name>
|
||||
<fallback-override>1</fallback-override>
|
||||
<fallback-mount>/black.mp3</fallback-mount>
|
||||
<username>live</username>
|
||||
<password>@@Source_Pass@@</password>
|
||||
</mount>
|
||||
<mount type="normal">
|
||||
<public>0</public>
|
||||
<mount-name>/black.mp3</mount-name>
|
||||
<fallback-override>1</fallback-override>
|
||||
<fallback-mount>/silver</fallback-mount>
|
||||
<username>live</username>
|
||||
<password>@@Source_Pass@@</password>
|
||||
</mount>
|
||||
|
||||
<mount type="normal">
|
||||
<public>0</public>
|
||||
<!-- <intro>/server-wide-intro.ogg</intro> -->
|
||||
<!-- <max-listener-duration>3600</max-listener-duration> -->
|
||||
<mount-name>/silver</mount-name>
|
||||
<fallback-override>1</fallback-override>
|
||||
<fallback-mount>/silver.mp3</fallback-mount>
|
||||
<username>live</username>
|
||||
<password>@@Source_Pass@@</password>
|
||||
</mount>
|
||||
<mount type="normal">
|
||||
<public>0</public>
|
||||
<mount-name>/silver.mp3</mount-name>
|
||||
<fallback-override>1</fallback-override>
|
||||
<fallback-mount>/live</fallback-mount>
|
||||
<username>live</username>
|
||||
<password>@@Source_Pass@@</password>
|
||||
</mount>
|
||||
|
||||
<!-- Normal mounts -->
|
||||
<!--
|
||||
<mount type="normal">
|
||||
<mount-name>/example-complex.ogg</mount-name>
|
||||
|
||||
<username>othersource</username>
|
||||
<password>hackmemore</password>
|
||||
|
||||
<max-listeners>1</max-listeners>
|
||||
<dump-file>/tmp/dump-example1.ogg</dump-file>
|
||||
<burst-size>65536</burst-size>
|
||||
<fallback-mount>/example2.ogg</fallback-mount>
|
||||
<fallback-override>1</fallback-override>
|
||||
<fallback-when-full>1</fallback-when-full>
|
||||
<intro>/example_intro.ogg</intro>
|
||||
<hidden>1</hidden>
|
||||
<public>1</public>
|
||||
<authentication type="htpasswd">
|
||||
<option name="filename" value="myauth"/>
|
||||
<option name="allow_duplicate_users" value="0"/>
|
||||
</authentication>
|
||||
<http-headers>
|
||||
<header name="Access-Control-Allow-Origin" value="http://webplayer.example.org" />
|
||||
<header name="baz" value="quux" />
|
||||
</http-headers>
|
||||
<on-connect>/home/icecast/bin/stream-start</on-connect>
|
||||
<on-disconnect>/home/icecast/bin/stream-stop</on-disconnect>
|
||||
</mount>
|
||||
-->
|
||||
|
||||
<!--
|
||||
<mount type="normal">
|
||||
<mount-name>/auth_example.ogg</mount-name>
|
||||
<authentication type="url">
|
||||
<option name="mount_add" value="http://myauthserver.net/notify_mount.php"/>
|
||||
<option name="mount_remove" value="http://myauthserver.net/notify_mount.php"/>
|
||||
<option name="listener_add" value="http://myauthserver.net/notify_listener.php"/>
|
||||
<option name="listener_remove" value="http://myauthserver.net/notify_listener.php"/>
|
||||
<option name="headers" value="x-pragma,x-token"/>
|
||||
<option name="header_prefix" value="ClientHeader."/>
|
||||
</authentication>
|
||||
</mount>
|
||||
-->
|
||||
|
||||
<fileserve>1</fileserve>
|
||||
|
||||
<paths>
|
||||
<logdir>/var/log/icecast2</logdir>
|
||||
<webroot>/usr/share/icecast2/web</webroot>
|
||||
<adminroot>/usr/share/icecast2/admin</adminroot>
|
||||
<!-- <pidfile>/usr/share/icecast2/icecast.pid</pidfile> -->
|
||||
<!-- Aliases: treat requests for 'source' path as being for 'dest' path
|
||||
May be made specific to a port or bound address using the "port"
|
||||
and "bind-address" attributes.
|
||||
-->
|
||||
<!--
|
||||
<alias source="/foo" destination="/bar"/>
|
||||
-->
|
||||
<!-- Aliases: can also be used for simple redirections as well,
|
||||
this example will redirect all requests for http://server:port/ to
|
||||
the status page
|
||||
-->
|
||||
<alias source="/" destination="/status.xsl"/>
|
||||
<!-- The certificate file needs to contain both public and private part.
|
||||
Both should be PEM encoded.
|
||||
<ssl-certificate>/usr/share/icecast2/icecast.pem</ssl-certificate>
|
||||
-->
|
||||
</paths>
|
||||
|
||||
<logging>
|
||||
<accesslog>access.log</accesslog>
|
||||
<errorlog>error.log</errorlog>
|
||||
<playlistlog>playlist.log</playlistlog>
|
||||
<loglevel>3</loglevel> <!-- 4 Debug, 3 Info, 2 Warn, 1 Error -->
|
||||
<logsize>10000</logsize> <!-- Max size of a logfile -->
|
||||
<!-- If logarchive is enabled (1), then when logsize is reached
|
||||
the logfile will be moved to [error|access|playlist].log.DATESTAMP,
|
||||
otherwise it will be moved to [error|access|playlist].log.old.
|
||||
Default is non-archive mode (i.e. overwrite)
|
||||
-->
|
||||
<!-- <logarchive>1</logarchive> -->
|
||||
</logging>
|
||||
|
||||
<security>
|
||||
<chroot>0</chroot>
|
||||
<!--
|
||||
<changeowner>
|
||||
<user>nobody</user>
|
||||
<group>nogroup</group>
|
||||
</changeowner>
|
||||
-->
|
||||
</security>
|
||||
</icecast>
|
||||
Reference in New Issue
Block a user