Here’s how to make a proxy for streaming mp3s. It transcodes on-the-fly to 64kpbs MP3 using lame. When transcoding is finished, it calls the ./posthandler.sh script, which can either just delete the file, or potentially archive it so you don’t need to transcode it again.

#!/bin/bash
read method url version

method="${method%$CR}"
url="${url%$CR}"
version="${version%$CR}"

echo -ne "HTTP/1.0 200 OK\r\nContent-type: audio/mpeg\r\n\r\n"

BR=64 #birate to transcode to.
PIPE="/tmp/$$.pipe"
mkfifo "$PIPE"

OUTFILE="./tmp.$$.$BR.mp3"
rm $OUTFILE
url=`echo "$url" | sed 's/\///'`
echo "** GET $url" >&2

nohup lynx --source "$url" \
    | (lame --preset cbr $BR --mp3input - - 2>/dev/null \
      && (echo "** Finished transcoding $url" >&2 ; \
          ./posthandler.sh "$OUTFILE"&))\
    | tee -i "$PIPE" > $OUTFILE &

cat < $PIPE
rm $PIPE

One interesting limitation seems to be the buffer size of a fifo pipe in linux. Even though the transcoding step is pretty quick, if a client is connected the transcoding only manages to fill the pipe a couple of hundred k ahead of what is being read.

The -i flag to tee means it ignores interrupts, and will finish transcoding the file and call the posthandler even if the client disconnects.

Run is like this:

$ while [ 1 ]; do nc -vlp 8080 -c './transstreamer.sh' ; done

Then hit up a url of your choice using your awesome new proxy:

$ URL="http://freedownloads.last.fm/download/105468518/Letters%2BFrom%2BThe%2BBoatman.mp3"
$ mpg321 "http://localhost:8080/$URL"

Not the most scalable solution, but a mildly amusing quick hack.