Custom Scripting

The ShowMon system is programmed and running on the Q-SYS Audio/Video/Control system. This platform utilizes the Lua programming language to author custom scripts for integrations. We have implemented a variety of custom scripts in ShowMon to enable all the custom automation for ensuring the show runs every night. Below are examples of some of them. 

FPP Integration

This script allows integration between ShowMon and the 26 Falcon Pi Player players in the show. This script allows us to perform commands individually and in bulk to the controllers (like set all to Test Mode). 

Camlytics Graph Integration

This script integrates Camlytics AI camera detection for car counting. Every 5 minutes it pulls the total number of cars for the night. At the top of the hour, it publishes the show attendance via push notification

FM Confidence Monitoring

This script watches the FM confidence audio and looks for the "dead air" silence between the show and the introduction announcement. If that is not present for 10 mintues, the script will assume the primary transmitter failed and automatically failover to the secondary transmitter. 

FPP Player Failover

This script monitors the primary FPP player and if it exhibits a fault during show hours, automtically fails the system over to the secondary player (disabling multisync on the primary and enabling it on the secondary). 

Pushover Transmitter

This script is what enables ShowMon to send out our Pushover notifications. There are multiple locations in ShowMon that utilize this script - Status Monitoring, Car Counting, and daily announcement from ShowHours. 

FM Power Control

This script is a helper for the Middle Atlantic RackLink plugin. It ensures we are interlocking the two outlets to ensure there is not a scenario where both transmitters are powered up at the same time. 

SNMP POE Controller

This script monitors the status of the devices wired into it and will automatically turn off and back on POE to the port if that device exhibits a fault or warning condition. In addition, it is gathering link status and basic switch information via SNMP. 

Shelly Rebooter

This script is based upon the example Shelly ping reboot script. We are using it on edge power monitors with switches connected. If the power monitor is unable to ping the primary player, secondary player, and MQTT broker then it will automatically reboot the connected switch. 

Show Hours

This script serves as the single source of truth for scheduling of the show. The script reaches out to a GitHub repo daily to check for updates to the schedule. Each day has 4 times - ShowStart, ShowStop, FM Off, and AM Off. Based on those times specified in the JSON file, the script provides logic to all the other scripts in ShowMon. In 2025 we plan on transitioning the players away from using their built in schedules and move to ShowMon being their schedule. 

UISP API Integration

This script allows us to leverage the API available in UISP to get signal strength and maximum upload/download speeds from all the AirMax antennas in the system.