diff --git a/docs/engine-features.md b/docs/engine-features.md index 8ab817e8e654f729733821964637d854f01a6732..272372e8c3aa2168a1de39c0af69564465ac8df6 100644 --- a/docs/engine-features.md +++ b/docs/engine-features.md @@ -5,15 +5,16 @@ This page gives a more detailed overview of the Aura Engine features and how to <!-- TOC --> - [Aura Engine Features](#aura-engine-features) - - [Input](#input) - - [Play audio from multiple sources](#play-audio-from-multiple-sources) - - [Dynamic switching of sources](#dynamic-switching-of-sources) - - [Output](#output) + - [Multi-channel Input (Filesystem, Stream, Analog)](#multi-channel-input-filesystem-stream-analog) + - [Multi-channel output](#multi-channel-output) + - [Analog line-out](#analog-line-out) + - [Stream to Icecast](#stream-to-icecast) - [Record output to filesystem](#record-output-to-filesystem) - - [Stream output to an Icecast Server](#stream-output-to-an-icecast-server) - - [Multichannel Line-out](#multichannel-line-out) - - [Blank Detenction / Silence Detecter](#blank-detenction--silence-detecter) - - [Auto Pilot a.k.a. Fallback Handling](#auto-pilot-aka-fallback-handling) + - [Secure Scheduling](#secure-scheduling) + - [Fallback Stages](#fallback-stages) + - [Scheduling Stages](#scheduling-stages) + - [Pro-active Fallback Handling (1st Level Fallback)](#pro-active-fallback-handling-1st-level-fallback) + - [Fallback Handling using the Silence Detector (2nd Level Fallback)](#fallback-handling-using-the-silence-detector-2nd-level-fallback) - [API Endpoints](#api-endpoints) - [Web Applications](#web-applications) - [Monitoring](#monitoring) @@ -25,53 +26,157 @@ This page gives a more detailed overview of the Aura Engine features and how to <!-- /TOC --> -## Input +## Multi-channel Input (Filesystem, Stream, Analog) -### Play audio from multiple sources +It's possible to schedules playlists with music or pre-recorded show stored on the **filessystem**, +via external **streams** or live from an **analog input** in the studio. All types of sources can +be mixed in a single playlist. -It's possible to air playlists with music or recordings stored on the **filessystem**, -via external **streams** or live from a **studio**. +> Note: Since live sources and streams do not specific a length property, any playlists populated +with such source are expecting this item to run until the end of the schedule. Any other entries +following such item are therfore skipped. This might change in a future version of AURA Tank, +allowing to set a length property. -### Dynamic switching of sources +The switching between types of audio source is handled automatically. To learn more check-out the +[Scheduling](### Secure Scheduling) section. - TODO extend: * switch the soundserver at the correct time to a given source for a specific show +## Multi-channel output -## Output +### Analog line-out + +In most scenarios it might be sufficient to broadcast via only one analog stereo output channel. +If need you can configure up to five stereo pairs. + +### Stream to Icecast + +Engine allows to stream to multiple Icecast Servers simultaniousely. It is also sending meta information +to the streaming server, using the *Icy* protocol. + +To configure your Icecast connectivity check-out the `[stream]` section in your configuration. ### Record output to filesystem - TODO extend: * record what is broadcasted +Engine allows recording broadcasts to the filesystem using up to multiple recorders. Each recorder can +be configured to save in a different resolution in audio quality. + +## Secure Scheduling + +Engine performs scheduling in a secured way, to meet the requirements of community +radios. It tries to pro-actively reacted to scenarios, where the upload of some +pre-recorded show has been forgotten, or some live schedule is not taking place. + +Usually in such cases the broadcast might end up with some timeslot filled with silence. +To avoid this, Engine implements multiple levels of fallback handling. -### Stream output to an Icecast Server +### Fallback Stages - TODO extend: * stream to an icecast server +The available fallbacks are evaluated in following order: -### Multichannel Line-out +1. **Show Fallback**: If the schedule for some show has no playlist assigned, the + playlist assigned as a *show fallback* is used instead. In the dashboard this can + be done as seen in the screenshot below. - TODO extend: * play to line-out +  + +2. **Timeslot Fallback**: If the show fallback is not assigned, a configured fallback + playlist for the related timeslot is used. + +3. **Station Fallback**: If everything goes wrong, meaning all the previous fallback + playlists are missing or are invalid, the *station fallback* will be triggered. This + fallback type is specified by a playlist ID set in the Engine's configuration + (see `scheduling_station_fallback_id` in `engine.ini`) + +### Scheduling Stages + +To understand how fallbacks are handled by Engine, it's good to know how the Engine's +scheduling is structured. Below you see a timline with one schedule planned at a certain +point in time and the involved phase before: + +``` +=====[ Scheduling Window ]-[ Pre-Rolling ]-[ Schedule Play-out ]===== +``` -## Blank Detenction / Silence Detecter +- **Scheduling Window**: Within the scheduling window any commands for controlling + the mixer of the soundsystem are prepared and queued. -The engine offers a simple way to detect scenarios where no music is on air. -It possible to configure the sensitivity of the Silence Detector and automatically -transition play-out to a Fallback Playlist (see Auto Pilot). + Until the start of the window, schedules can be added or removed + via external API Endpoints (e.g. using Steering or Dashboard). Until here any + changes on the schedule itself will be reflected in the actual play-out. Be aware, + that this only affects the schedule ("timeslot") itself, it does not involve related + playlists and their entries. The latter can still be modified within the scheduling + window. -## Auto Pilot a.k.a. Fallback Handling + The start and the end of the window is defined by the start of the schedule minus + a configured amount of seconds (see `scheduling_window_start` and `scheduling_window_end` + in `engine.ini`). -In case there is no schedule delivered by Steering, engine provides multiple -fallback handling scenarios. The available fallbacks are evaluated in following order: + During the scheduling window, the external API Endpoints are pulled continiously, to + check for updated schedules and related playlists. Also, any changes to playlists and + its entries are respected within that window (see `fetching_frequency` in `engine.ini`). -1. **Timeslot Fallback**: + <u>Pro-active fallbach handling</u> is already happening at this phase. -2. **Show Fallback**: + > Important: It's vital that the the scheduling window is wider than the fetching frequency. + Otherwise one fetch might never hit a scheduling window, hence not being able to schedule stuff. -3. **Station Fallback**: +- **Pre-Rolling**: Now, the playlist entries are going to be "pre-rolled". This means that filesystem + entries are pre-loaded and entries which are based on audio streams are buffered. This + is required to allow a seamless play-out, when its time to do so (in the next stage). + Due to their nature, playlist entries which hold live audio sources are not affected by + this stage at all. -3.1 Station Fallback via remote playlist + Within this stage users can neither change playlists nor its entries anymore. <u>Pro-active + fallback handling</u> will happen though (see next chapter below for an explanation). -3.2 Station Fallback via local music folder + Set the maximum time reserved for pre-rolling in your configuration (compare `preroll_offset` + in `engine.ini`). + + > Important: This stage can require up to 4x pre-rolling steps, one for default play-out + and for each of the 3 fallback types. So the expected time to load some source multiplied + by 4 should be set as the actual value. Also, the offset should not exceed the time between + the end of the scheduling-window and the start of the actual schedule playout. + +- **Schedule-Playout**: Finally the actual play-out is happening. The faders of the virtual + mixers are pushed all the way up and transitions between playlist entries with different + types of sources (file, stream and analog inputs) are performed automatically. At the end + of each schedule the channel is faded-out, no matter if the total length of the playlist + entries would require a longer timeslot. + + If for some reason the playout is corrupted, stopped or too silent to make any sense, then + this <u>triggers a 2nd level fallback using the silence detector</u> (see chapter below). + +### Pro-active Fallback Handling (1st Level Fallback) + +This type of fallback handling is performed before the actual playout, within the scheduling +window and pre-rolling stage. Here Engine pro-actively verifies the validity of the playlists. +For example it checks if some playlist ist existing at all, if it holds entries or if the +entries are existing. + +Furthermore, it checks for any unexpected error when entries are pre-rolled. For example Engine +tries to buffer some HTTP Audio Stream, but it is not reachable. In this case this will +trigger the scheduling of some fallback playlist. + +Pro-active fallback handling has the advantage that any (even short) periods of silence +during playlist can be avoided. Still, there are cases, where any failure cannot be detected +beforehand. Therefore a 2nd level fallback solution is required (see below). + +### Fallback Handling using the Silence Detector (2nd Level Fallback) + +Engine offers a simple way to detect situations where no sound is on air, the so-called +Silence Detector. It allows detection of absoulte silence, weak signals or even noise. + +To configure the sensitivity of the Silence Detector check-out following properties in +`engine.ini`: + +``` +# 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." +``` -Note: All filenames in the music folder should be ASCII encoded, otherwise this may cause engine failures. ## API Endpoints diff --git a/docs/images/dashboard-fallback-setting.png b/docs/images/dashboard-fallback-setting.png new file mode 100644 index 0000000000000000000000000000000000000000..5c00586fe02a3d26c32d6ab58fd9eb5f8f03150d Binary files /dev/null and b/docs/images/dashboard-fallback-setting.png differ