streamrecord/Readme.md

1.4 KiB

Streamrecord


A python3 web app to record internet radio streams and present them in a podcast

Requirements

  • python3
  • sqlite3
  • jinja2
  • cherrypy
  • uwsgi
  • mkvmerge
  • avconv

Installation

  • Checkout the source to somewhere on your hard disk. In the examples below, the path to the root of the source is /home/streamrecord/app/. Cd to here.
  • Use the sqlite3 command line client to called "db.sqlite", and execute the two create table queries in lib/database.py. Syntax is: `sqlite3 db.sqlite ''.
  • Write the config for uwsgi, start that daemon
  • Write the config for nginx, and view the page.

Podcast usage: each schedule has a numerical id. To view the podcast, http://my.server/api/getPodcast?id=

Uwsgi config

Something like:

[uwsgi]
uid = streamrecord
pid = streamrecord
plugins = python3
touch-reload = /home/streamrecord/app/app.py
chdir = /home/streamrecord/app/
wsgi-file = /home/streamrecord/app/app.py
callable = application
master = true
processes = 1
socket = 127.0.0.1:3330
pidfile = /tmp/streamrecord.pid
enable-threads = true
no-threads-wait = true
die-on-term = true

Nginx config

Something like:

server {
	listen 30000;
	listen [::]:30000 ipv6only=on;
	include uwsgi_params;
	access_log /var/log/nginx/stremrecord.log;
	location / {
		uwsgi_pass 127.0.0.1:3330;
	}
	location /streamrecord/static/ {
		autoindex on;
		alias /home/streamrecord/app/static/;
	}
}