From e2b9d1434ac87bf2fa160b09924eee84b9b123cb Mon Sep 17 00:00:00 2001 From: makefu Date: Thu, 20 Dec 2012 11:15:48 +0700 Subject: //god/streams/ - cleanup --- god/streams/bin/helper/streamfind | 10 +++ god/streams/bin/helper/streamwrite | 6 ++ god/streams/bin/mpdstreams | 113 ++++++++++++++++++++++++++++++ god/streams/bin/relaxxapi.py | 140 +++++++++++++++++++++++++++++++++++++ god/streams/bin/relaxxstreams | 107 ++++++++++++++++++++++++++++ god/streams/bin/stream-starter | 19 +++++ god/streams/bin/streams | 116 ++++++++++++++++++++++++++++++ 7 files changed, 511 insertions(+) create mode 100644 god/streams/bin/helper/streamfind create mode 100644 god/streams/bin/helper/streamwrite create mode 100755 god/streams/bin/mpdstreams create mode 100755 god/streams/bin/relaxxapi.py create mode 100755 god/streams/bin/relaxxstreams create mode 100755 god/streams/bin/stream-starter create mode 100755 god/streams/bin/streams (limited to 'god/streams/bin') diff --git a/god/streams/bin/helper/streamfind b/god/streams/bin/helper/streamfind new file mode 100644 index 00000000..32b84a4e --- /dev/null +++ b/god/streams/bin/helper/streamfind @@ -0,0 +1,10 @@ +#!/bin/sh +cat stream.db | while read url name;do + curl $url --max-time 1 2>/dev/null| sed -n 's/[fF]ile[0-9]=\(.*\)/\1/p' > "streamfinder/$name" + if [ "x`cat \"streamfinder/$name\"`" == "x" ];then + rm "streamfinder/$name" + echo "$name empty or not a stream" + else + echo "wrote $name" + fi +done diff --git a/god/streams/bin/helper/streamwrite b/god/streams/bin/helper/streamwrite new file mode 100644 index 00000000..a10fb155 --- /dev/null +++ b/god/streams/bin/helper/streamwrite @@ -0,0 +1,6 @@ +for i in `ls -1 streamfinder/`; +do + for j in `cat "$i"`;do + echo "$j $i" >> direct.db + done +done diff --git a/god/streams/bin/mpdstreams b/god/streams/bin/mpdstreams new file mode 100755 index 00000000..a2a5f77c --- /dev/null +++ b/god/streams/bin/mpdstreams @@ -0,0 +1,113 @@ +#!/usr/bin/python2 + +# this version cannot tell if a stream is running or just ordinary music +import os +import sys +from subprocess import Popen, PIPE + +os.chdir(os.path.dirname(os.path.realpath(sys.argv[0]))) +pidfile = "/tmp/krebs.stream.pid" +host="lounge.mpd.shack" +url_file = os.environ.get("STREAM_DB", "../db/stream.db") +urls = [] +for line in open(url_file): + urls.append(line.split()) +#print urls +mybin = sys.argv[0] +cmd = sys.argv[1] if len(sys.argv) > 1 else "you-are-made-of-stupid" +stream = sys.argv[2] if len(sys.argv) == 3 else "groove" +pipe_silent = open("/dev/null","w") + +def urlForStream(stream): + for url, s in urls: + if s == stream: + return url + +def streamForUrl(url): + for u, s in urls: + if u == url: + return stream + +def startStream(stream_url): + Popen(["mpc","--host",host,"crossfade","5"], + stdout=pipe_silent,stderr=pipe_silent) + Popen(["mpc","--host",host,"repeat","yes"], + stdout=pipe_silent,stderr=pipe_silent) + Popen(["mpc","--host",host,"clear"], + stdout=pipe_silent,stderr=pipe_silent) + Popen(["mpc","--host",host,"add",stream_url], + stdout=pipe_silent,stderr=pipe_silent).wait() + Popen(["mpc","--host",host,"play"], + stdout=pipe_silent,stderr=pipe_silent) + +def start(stream): + ret = running() + if ret: + print "!! Stream `%s` already running !" % \ + (ret) + else: + startStream(urlForStream(stream)) + print "** Starting `%s`."% stream + + +def stop(): + ret = running() + if not ret: + print "!! No Stream running!" + else: + print "** Stopping `%s`" % ret + Popen(["mpc","--host",host,"stop"], + stdout=pipe_silent,stderr=pipe_silent) + + +def running(): + try: + (out,err) = Popen(["mpc","--host",host,"current"],stdout=PIPE,stderr=PIPE).communicate() + out = out.rstrip() + return out + except Exception as e: + return "" + + +def slist(): + for url, name in urls: + print "%s : %s" % (name, url) + + +def shorthelp(): + print "start|stop|restart|status|list [audio stream]" + + +def longhelp(): + print "Usage: %s" % mybin, + shorthelp + print """ get all available streams with '/%(fil)s list' + Examples: + %(fil)s list + %(fil)s start groove + %(fil)s switch deepmix + %(fil)s status + %(fil)s stop""" % {'fil': mybin} + +if cmd == "start": + start(stream) +elif cmd == "stop": + stop() +elif cmd == "switch" or cmd == "restart": + stop() + start(stream) +elif cmd == "status": + ret = running() + if not ret: + print "** nothing running" # , e + else: + print "Now Playing: %s" % ret +elif cmd == "list": + slist() +elif cmd == "--help": + longhelp() +elif cmd == "-h": + shorthelp() +else: + print "unknown command `%s`" % cmd + print "try `%s` --help" % os.path.basename(mybin) diff --git a/god/streams/bin/relaxxapi.py b/god/streams/bin/relaxxapi.py new file mode 100755 index 00000000..f367caef --- /dev/null +++ b/god/streams/bin/relaxxapi.py @@ -0,0 +1,140 @@ +#!/usr/bin/python2 +import json +from urllib import quote +class relaxx: + + def __init__(self,relaxxurl="http://lounge.mpd.shack/"): + self.baseurl=relaxxurl + import requests + ret = requests.get(relaxxurl) # grab cookie + try: + self.r = requests.session(cookies=ret.cookies,headers={"Referer":relaxxurl}) + except: + print ("you are missing the `requests` dependency, please do a `pip install requests`") + def _status(self,value=0,data="json=null"): + """ + value is some weird current playlist value, 0 seems to work + data is url encoded kv-store + """ + # TODO get the current playlist value + url=self.baseurl+"include/controller-ping.php?value=%s"%value + return self.r.post(url,data="json=null").text + + def _playlist(self,action,value="",json="null",method="get"): + """ + This function is the interface to the controller-playlist api + use it if you dare + Possible actions: + clear + addSong url_encoded_path + moveSong 1:2 + getPlaylists + getPlaylistInfo 1 + listPlaylistInfo + as everything seems to be a get request, the method is set to GET as + default + """ + url=self.baseurl+"include/controller-playlist.php?action=%s&value=%s&json=%s"%(action,value,json) + if method== "get": + return self.r.get(url).text + elif method == "post": + return r.post(url).text + else: + raise Exception("unknown method %s") + + def _playback(self,action,value="",json="null",method="get"): + """ + play + continue + stop + setCrossfade + """ + url=self.baseurl+"include/controller-playback.php?action=%s&value=%s&json=%s"%(action,value,json) + # probably obsolete because everything is "get" + if method== "get": + return self.r.get(url).text + elif method == "post": + return r.post(url).text + else: + raise Exception("unknown method %s") + + def _radio(self,playlist=""): + """ + both, post and get the url seem to work here... + """ + url=self.baseurl+"include/controller-netradio.php?playlist=%s"%quote(playlist) + return self.r.get(url).text + + def add_radio(self,playlist=""): + print playlist + print self._radio(playlist) + print json.loads(self._radio(playlist)) #[1:-1])["url"] + resolved_url= json.loads(self._radio(playlist)[1:-1])["url"] + self.add_song(resolved_url) + + def add_song(self,path): + return self._playlist("addSong",path) + + def get_first(self): + return json.loads(self._playlist("getPlaylistInfo","0",""))[0] + + def get_first(self): + return json.loads(self._playlist("getPlaylistInfo","0",""))[-1] + + def clear(self): + return self._playlist("clear") + + def crossfade(self,ident="0"): + """ + default: no crossfade + """ + return self._playback("setCrossfade",ident) + + def repeat(self,ident="1"): + """ + default: do repeat + """ + return self._playback("repeat",ident) + + def play(self,ident): + return self._playback("play",ident) + + def stop(self): + return self._playback("stop") + + def cont(self,ident): + return self._playback("continue",ident) + + def play_first(self): + return self.play(self.get_first()["Id"]) + + def play_last(self): + return self.play(self.get_last()["Id"]) + + def state(self): + return json.loads(self._status()) + + def is_running(self): + return self.state()["status"]["state"] == "play" + + def playing(self): + """ returns "" if not running + """ + state = self.state() + if state["status"]["state"] == "play" : + ident = state["status"]["song"] + current = state["playlist"]["file"][int(ident)] + return current.get("Name",current.get("Artist")) + " - " + current["Title"] + else: + return "" + +if __name__ == "__main__": + r = relaxx() + print r.state() + print r.playing() + print r.add_radio("http://deluxetelevision.com/livestreams/radio/DELUXE_RADIO.pls") + #print r.clear() + #print r.add_radio("http://somafm.com/lush.pls") + #print r.get_first()["Id"] + #print r.play_first() + #print r.add_radio("http://somafm.com/lush.pls") diff --git a/god/streams/bin/relaxxstreams b/god/streams/bin/relaxxstreams new file mode 100755 index 00000000..0d3813a7 --- /dev/null +++ b/god/streams/bin/relaxxstreams @@ -0,0 +1,107 @@ +#!/usr/bin/python2 + +# this version cannot tell if a stream is running or just ordinary music +import os +import sys +import json +from urllib import quote +from relaxxapi import relaxx + +try: + import requests +except: + print ("you are missing the `requests` dependency, please do a `pip install requests`") +from subprocess import Popen, PIPE + +os.chdir(os.path.dirname(os.path.realpath(sys.argv[0]))) +pidfile = "/tmp/krebs.stream.pid" +baseurl="http://lounge.mpd.shack/" +url=baseurl+"include/controller-playlist.php?action=%s&value=%s&json=%s" +url_file = os.environ.get("STREAM_DB", "../db/direct.db") +urls = [] + +for line in open(url_file): + urls.append(line.split()) +#print urls +mybin = sys.argv[0] +cmd = sys.argv[1] if len(sys.argv) > 1 else "you-are-made-of-stupid" +stream = sys.argv[2] if len(sys.argv) == 3 else "groove" +pipe_silent = open("/dev/null","w") +api = relaxx(baseurl) + +def urlForStream(stream): + for url, s in urls: + if s == stream: + return url + +def streamForUrl(url): + for u, s in urls: + if u == url: + return stream + +def startStream(stream_url): + print api.crossfade("5") + print api.repeat("1") + print api.clear() + print api.add_song(stream_url) + print api.play_first() + +def start(stream): + ret = api.playing() + if ret: + print "!! Stream `%s` already running !" % \ + (ret) + else: + startStream(urlForStream(stream)) + print "** Starting `%s`."% stream + + +def stop(): + ret = api.playing() + if not ret: + print "!! No Stream running!" + else: + print "** Stopping `%s`" % ret + api.stop() + +def slist(): + for url, name in urls: + print "%s : %s" % (name, url) + +def shorthelp(): + print "start|stop|restart|status|list [audio stream]" + + +def longhelp(): + print "Usage: %s" % mybin, + shorthelp + print """ get all available streams with '/%(fil)s list' + Examples: + %(fil)s list + %(fil)s start groove + %(fil)s switch deepmix + %(fil)s status + %(fil)s stop""" % {'fil': mybin} + +if cmd == "start": + start(stream) +elif cmd == "stop": + stop() +elif cmd == "switch" or cmd == "restart": + stop() + start(stream) +elif cmd == "status": + ret = api.playing() + if not ret: + print "** nothing running" # , e + else: + print "Now Playing: %s" % ret +elif cmd == "list": + slist() +elif cmd == "--help": + longhelp() +elif cmd == "-h": + shorthelp() +else: + print "unknown command `%s`" % cmd + print "try `%s` --help" % os.path.basename(mybin) diff --git a/god/streams/bin/stream-starter b/god/streams/bin/stream-starter new file mode 100755 index 00000000..4d3a406f --- /dev/null +++ b/god/streams/bin/stream-starter @@ -0,0 +1,19 @@ +#! /bin/bash +set -euf +HERE=$(dirname $(readlink -f $0)) +STR=$HERE/streams +NAME=`basename $0` +case "$1" in + start) + $STR start $NAME + ;; + stop) + $STR stop + ;; + restart) + $STR restart $NAME + ;; + *) + echo "aidsballs" + ;; +esac diff --git a/god/streams/bin/streams b/god/streams/bin/streams new file mode 100755 index 00000000..ea6e9a90 --- /dev/null +++ b/god/streams/bin/streams @@ -0,0 +1,116 @@ +#!/usr/bin/python +import os +import sys +from subprocess import Popen, PIPE + +os.chdir(os.path.dirname(os.path.realpath(sys.argv[0]))) +pidfile = "/tmp/krebs.stream.pid" +url_file = os.environ.get("STREAM_DB", "../db/stream.db") +urls = [] +#urls = [ url,f for (url,f) in open(url_file).readline() ] +for line in open(url_file): + urls.append(line.split()) +#print urls +mybin = sys.argv[0] +cmd = sys.argv[1] if len(sys.argv) > 1 else "you-are-made-of-stupid" +stream = sys.argv[2] if len(sys.argv) == 3 else "groove" + + +def check_pid(pid): + """ Check For the existence of a unix pid. """ + try: + os.kill(pid, 0) + except OSError: + return False + else: + return True + + +def urlForStream(stream): + for url, s in urls: + if s == stream: + return url + + +def start(stream): + ret = running() + if ret: + print "!! Stream `%s` already running with pid `%s` !" % \ + (ret[1], ret[0]) + else: + pipe_silent = open('/dev/null', 'w') + url = urlForStream(stream) + mpl = Popen(["mplayer", url], + stdout=pipe_silent, stderr=pipe_silent).pid + print >> open(pidfile, "w+"), "%d %s" % (mpl, stream) + + +def stop(): + ret = running() + if not ret: + print "!! No Stream running!" + else: + pid, name = ret + print "** Killing `%s` with pid %s" % (name, pid) + os.kill(int(pid), 15) + #if check_pid(int(pid)): + # print "!! trying harder to kill process" + # os.kill(int(pid), 9) + os.remove(pidfile) + + +def running(): + try: + pid, currstream = open(pidfile).read().split() + if check_pid(int(pid)): + return (pid, currstream) + else: + print "!! removing stale pidfile" + os.remove(pidfile) + raise Exception("Pidfile stale") + except Exception as e: + return () + + +def slist(): + for url, name in urls: + print "%s : %s" % (name, url) + + +def shorthelp(): + print "start|stop|restart|status|list [audio stream]" + + +def longhelp(): + print "Usage: %s" % mybin, + shorthelp + print """ get all available streams with '/%(fil)s list' + Examples: + %(fil)s list + %(fil)s start groove + %(fil)s switch deepmix + %(fil)s status + %(fil)s stop""" % {'fil': mybin} + +if cmd == "start": + start(stream) +elif cmd == "stop": + stop() +elif cmd == "switch" or cmd == "restart": + stop() + start(stream) +elif cmd == "status": + ret = running() + if not ret: + print "** no stream running" # , e + else: + print "%s is running(%s)" % (ret[1], urlForStream(ret[1])) +elif cmd == "list": + slist() +elif cmd == "--help": + longhelp() +elif cmd == "-h": + shorthelp() +else: + print "unknown command `%s`" % cmd + print "try `%s` --help" % os.path.basename(mybin) -- cgit v1.2.3