################### # Engine Settings # ################### [station] station_name="Radio Aura" station_logo_url="https://o94.at/themes/custom/radio_orange/logo1.png" station_logo_size="180px" [database] db_user="aura" db_name="aura_engine" db_pass="---SECRET--PASSWORD---" db_host="localhost" db_charset="utf8" [monitoring] mail_server="mail.example.com" mail_server_port="587" mail_user="aura@subsquare.at" mail_pass="---SECRET--PASSWORD---" # If you want to send multiple adminmails, make them space separated admin_mail="david@subsquare.at" # Which from mailadress should be used from_mail="monitoring@aura.engine" # The beginning of the subject. With that you can easily apply filter rules using a mail client mailsubject_prefix="[Aura Engine]" # Server where heartbeat info is sent to heartbeat_server = "127.0.0.1" # Some UDP port heartbeat_port = 43334 # Seconds how often the vitality of the Engine should be checked (0 = disabled) heartbeat_frequency = 1 logdir="/var/log/aura" # *ossible values: debug, info, warning, error, critical loglevel="info" [api] ## STEERING ## # The URL to get the health status api_steering_status="http://aura.local:8000/api/v1/" # The URL to get the Calendar via Steering api_steering_calendar="http://aura.local:8000/api/v1/playout" ## TANK ## # The session name which is used to authenticate against Tank api_tank_session="engine" # The secret which is used to authenticate against Tank api_tank_secret="rather-secret" # The URL to get the health status api_tank_status="http://aura.local:8040/healthz/" # The URL to get playlist details via Tank api_tank_playlist="http://aura.local:8040/api/v1/playlists/${ID}" ## ENGINE-API ## # Engine ID (1 or 2) api_engine_number=1 # Engine API availability check api_engine_status="http://localhost:8008/api/v1/ui/" # Engine API endpoint to store playlogs api_engine_store_playlog="http://localhost:8008/api/v1/playlog/store" # Engine API endpoint to store clock information api_engine_store_clock="http://localhost:8008/api/v1/clock" # Engine API endpoint to store health information api_engine_store_health="http://localhost:8008/api/v1/source/health/${ENGINE_NUMBER}" [scheduling] # How often should the calendar be fetched in seconds. This determines the time of the last changes applied, before a specific show aired fetching_frequency=300 # The scheduling window defines when the entries of each schedule are queued for play-out in an ideal scenario. # The actual window (scheduling_window_start - scheduling_window_end) should be higher then the `fetching_frequency` to allow proper queuing. # Otherwise the fetch might never hit the scheduling window, because the scheduling logic is attached to the fetching logic. # # Following operations are related to the scheduling window: # # - Deletion of timeslots: Those are only accepted until the **start** of the scheduling window # - Update/Delete/Assignment of playlists and entries: Those are accepted until the **end** of the the scheduling window; existing queued entries are updated # # After the end of the scheduling window the pre-loading phase starts. # Note, the values for windows is defined as a offset minus the actual start of the schedule in seconds. scheduling_window_start=600 scheduling_window_end=60 # How many seconds before the actual schedule time the entry should be pre-rolled. Note to provide enough timeout for # contents which take longer to load (big files, bad connectivity to streams etc.) preload_offset=30 # Sometimes it might take longer to get a stream connected. Here you can define a viable length. # But note, that this may affect the preloading time (see `preload_offset`), hence affecting the # overall playout, it's delays and possible fallbacks input_stream_retry_delay=1 input_stream_max_retries=10 input_stream_buffer=3.0 [fading] # Sets the time how long we have to fade in and out, when we select another mixer input values are in seconds fade_in_time="0.5" fade_out_time="2.5" ####################### # Liquidsoap Settings # ####################### # all these settings from here to the bottom require a restart of the liquidsoap server [lqs] liquidsoap_path="/home/engineuser/.opam/4.08.0/bin/liquidsoap" liquidsoap_working_dir="modules/liquidsoap/" liquidsoap_as_root="false" # Liquidsoap execution delay in seconds; Crucial to keep things in sync lqs_delay_offset=1 [user] # the user and group under which this software will run daemongroup="engineuser" daemonuser="engineuser" [socket] socketdir="/opt/aura/engine/modules/liquidsoap" [audiosources] audio_source_folder="var/audio/source" audio_source_extension=".flac" [fallback] # track_sensitive => fallback_folder track sensitivity # max_blank => maximum time of blank from source (defaults to 20., seconds, float) # min_noise => minimum duration of noise on source to switch back over (defaults to 0, seconds, float) # threshold => power in dB under which the stream is considered silent (defaults to -40., float) fallback_max_blank="20." fallback_min_noise="0." fallback_threshold="-50." # A playlist holding music for Station Fallbacks (optonal) fallback_music_playlist= "/opt/aura/engine/config/playlists/station-fallback-playlist.m3u" # A folder holding music for Station Fallbacks (optional) fallback_music_folder="/var/audio/station" # The time in seconds how often the folder should be re-scanned # Do not reload too often when using large folders fallback_music_folder_reload="300" [soundcard] # choose your weapon # if you are starving for pain in the ass choose alsa # if you don't care about latency choose pulseaudio # if you want low latency and a bit of experimenting, choose jack soundsystem="alsa" # you can define up to 5 inputs and outputs # it is tested with # - ALSA with ONE input and ONE output # - pulseaudio with ONE input and ONE output (should work with multiple ins/outs) # - jack with multiple inputs and outputs # # boundaries: # - if you use jack, you have to kill liquidsoap. somehow liquidsoap cannot disconnect from jackd when shutting down # # with alsa you have to write the devicenames like hw:0 # with pulse and jack => an non empty value means it is used # devices with empty string are ignored and not used input_device_0="" input_device_1="" input_device_2="" input_device_3="" input_device_4="" # same same, but different output_device_0="default" output_device_1="" output_device_2="" output_device_3="" output_device_4="" # if you are using alsa, you most probably have to tweak these values # out of the box you will hear alot of cracklings and artifacts # alsa_buffer => int #alsa_buffer="8192" alsa_buffer="16384" # alsa_buffer_length => int alsa_buffer_length="25" # alsa_periods => int alsa_periods="0" # frame_duration => double frame_duration="" # frame_size => int frame_size="" ##################### # Recorder Settings # ##################### # you can define up to 5 recorder types. # flac, mp3, ogg, opus and wav is supported [recording] # flac example # enable this recorder. everything else than 'y' is considered as disabled rec_0="n" # first set a folder rec_0_folder="/var/recordings/flac" # after how many minutes the recording will be cut rec_0_duration="30" # file (or encoding-) type rec_0_encoding="flac" # bitrate (with encoding types without bitrate like flac or wav it is substituted. 32 => very poor quality. 320 => very high quality) rec_0_bitrate="128" # channels: everything else than 2 is considered as mono rec_0_channels="2" # mp3 example rec_1="n" rec_1_folder="/var/audio/rec/mp3" rec_1_duration="30" rec_1_encoding="mp3" rec_1_bitrate="320" rec_1_channels="2" # mp3 example rec_2="n" rec_2_folder="/var/audio/rec/mp3" rec_2_duration="30" rec_2_encoding="mp3" rec_2_bitrate="192" rec_2_channels="2" # ogg example rec_3="n" rec_3_folder="/var/recordings/ogg" rec_3_duration="30" rec_3_encoding="ogg" rec_3_bitrate="320" rec_3_channels="2" # opus example rec_4="n" rec_4_folder="/var/recordings/opus" rec_4_duration="30" rec_4_encoding="opus" rec_4_bitrate="32" rec_4_channels="2" # wav example #rec_4="n" #rec_4_folder="/var/recordings/wav" #rec_4_duration="30" #rec_4_filetype="wav" #rec_4_bitrate="320" #rec_4_channels="2" ################### # Stream Settings # ################### # You can define up to outgoing 5 streams # flac, mp3, ogg and opus is supported [stream] # defines enabled or not stream_0="n" # possible values: flac, mp3, ogg, opus (depending on what liquidsoap-plugins you installed) stream_0_encoding="ogg" # bitrate (with encoding types without bitrate like flac or ogg it is substituted. 32 => very poor quality. 320 => very high quality) stream_0_bitrate="128" # how many channels? everything else than 2 is considered as mono stream_0_channels="2" # to where we are streaming..? stream_0_host="localhost" # and which port? stream_0_port="8888" # the name of the mountpoint stream_0_mountpoint="aura-test-0.ogg" # username stream_0_user="source" # and the password stream_0_password="source" # stream url stream_0_url="http://www.fro.at" # the name of the stream stream_0_name="AURA Test Stream 0" # the genre of the stream stream_0_genre="mixed" # description of the stream stream_0_description="Test Stream 0" stream_1="n" stream_1_encoding="flac" stream_1_bitrate="128" stream_1_channels="2" stream_1_host="localhost" stream_1_port="8888" stream_1_mountpoint="aura-test-1.flac" stream_1_user="source" stream_1_password="source" stream_1_url="http://www.fro.at" stream_1_name="AURA Test Stream 1" stream_1_genre="mixed" stream_1_description="Test Stream 1" stream_2="n" stream_2_encoding="mp3" stream_2_bitrate="64" stream_2_channels="2" stream_2_host="localhost" stream_2_port="8888" stream_2_mountpoint="aura-test-2.mp3" stream_2_user="source" stream_2_password="source" stream_2_url="http://www.fro.at" stream_2_name="AURA Test Stream 2" stream_2_genre="mixed" stream_2_description="Test Stream 2" stream_3="n" stream_3_encoding="ogg" stream_3_bitrate="64" stream_3_channels="2" stream_3_host="localhost" stream_3_port="8888" stream_3_mountpoint="aura-test-3.ogg" stream_3_user="source" stream_3_password="source" stream_3_url="http://www.fro.at" stream_3_name="AURA Test Stream 3" stream_3_genre="mixed" stream_3_description="Test Stream 3" stream_4="n" stream_4_encoding="opus" stream_4_bitrate="64" stream_4_channels="2" stream_4_host="localhost" stream_4_port="8888" stream_4_mountpoint="aura-test-4.opus" stream_4_user="source" stream_4_password="source" stream_4_url="http://www.fro.at" stream_4_name="AURA Test Stream 3" stream_4_genre="mixed" stream_4_description="Test Stream 3"