Skip to content

Latest commit

 

History

History
99 lines (73 loc) · 4.99 KB

README.md

File metadata and controls

99 lines (73 loc) · 4.99 KB

Jamulus Jam Exporter

General note:

The scripts here are what I use on my own server - so they might not be best suited to how you run yours. Please read both this document and the scripts themselves before use.

There are two scripts for the Jam Exporter:

  • A bash script to monitor the Jamulus recording base directory for new recordings
  • A bash script to apply some judicious rules and compression before uploading the recordings offsite

Systemd Service

Also supplied is a systemd service file to start the monitor script:

  • src/systemd/inotify-publisher.service

This contains the path to the monitor script in the ExecStart= line and the User= and Group= lines need to match how you usually run Jamulus.

inotify-publisher.sh monitoring script

The configuration section at the top has the following:

  • JAMULUS_ROOT=/opt/Jamulus
  • JAMULUS_RECORDING_DIR=${JAMULUS_ROOT}/run/recording
  • NEW_JAMDIR_INTERVAL=$(( 5 * 60 ))
  • JAMULUS_LOGFILE=${JAMULUS_ROOT}/log/Jamulus.log
  • NO_CLIENT_INTERVAL=$(( 30 ))
  • NO_CLIENT_CONNECTED=',, server \(stopped\|idling\) --*-$'
  • LOG_WRITE_INTERVAL=$(( 5 * 60 ))
  • PUBLISH_SCRIPT=${JAMULUS_ROOT}/bin/publish-recordings.sh

You may need to edit more than just JAMULUS_ROOT - adjust to suit. I'm not sure if the server log file entry NO_CLIENT_CONNECT gets translated - if so, the local value is needed here.

The ..._INTERVAL entries are used to tune the amount of checking the script does... and reduce the amount of logging. I like to know the script is running, so I set the time out to something that won't generate too much cruft but will show a regular pulse to let me know it's alive. NO_CLIENT_INTERVAL allows the server time to decide all departed clients have really left and write the idling line.

The script uses one program that you might not have installed by default, inotifywait.

I would expect your distribution makes this available.

publish-recordings.sh prepare and upload script

NOTE PLEASE read and understand, at least basically, what this does before using it. It makes destructive edits to recordings that you might not want. It was written to do what I needed and is provided for people to have a base to work from, not as a working solution to your needs.

Configuration

The configuration section here is simpler:

  • RECORDING_DIR=/opt/Jamulus/run/recording
  • RECORDING_HOST=drealm.info
  • RECORDING_HOST_DIR=public_html/jamulus
  • TRANSPORT=scp

There is one main dependency here: the FFMpeg suite - both ffprobe and ffmpeg itself are used.

It also uses zip.

Most distributions provide versions that will be adequate.

What it does

The main point of this is to publish to publicly accessibly locations recordings that have been made by the Jamulus server. Given the right RECORDING_DIR, this iterates over all subdirectories, looking for Reaper RPP files or Audacity LOF files.

The logical processing is as follows.

For each recording directory, the WAV files are examined to determine their audio length and (EBU) volume. Where the file is considered "too short" or "too quiet", it is removed (deleted on disk and edited out of the RPP and LOF files). Retained files then have audio compression applied, updating the RPP and LOF files with the new name (i.e. WAV -> OPUS). Any RPP track that now has no entries is also removed. If the RPP or LOF project has no tracks, the recording directory is deleted.

After the above processing, any remaining recording directory gets zipped and uploaded to RECORDING_HOST_DIR on RECORDING_HOST, using TRANSPORT, which can be scp or ftp.

If run from inotify-publisher.sh under the systemd service, the script will be run as the User= user. Ensuring the script has access to authentication details relies on either .ssh/config (for ssh) or .netrc (for ftp) for the user running the script. For ssh, make sure you have also installed that user's public key in your hosting provider's authorized_keys (using the expected key type).

recover-recording.sh

Also included is a "recovery mode" script. This helps you recreate any lost Reaper RPP or Audacity LOF project files from a Jamulus recording directory. There is a --help option that provides the full syntax.

The intent of this script is to take an existing collection of Jamulus recorded WAVE files and generate the Reaper RPP and Audacity LOF project files that match the one the server should have created. It may sometimes be needed, for example when the server fails to terminate the recording correctly (as that is when the project files gets written).

The script should be run from the directory containing the "failed" recording. By default, the script writes both RPP and LOF projects to files, using the working directory name and appropriate suffix. --rpp and --lof can optionally be followed by a filename, which can be - for stdout. If only one of the two is specified, the other is not written at all.