morphbr@453: #!/usr/bin/python morphbr@453: morphbr@453: import sys morphbr@453: import os morphbr@453: import ConfigParser morphbr@453: morphbr@453: def now(): morphbr@453: return time.strftime("%Y-%m-%d %H:%M:%S"); morphbr@453: morphbr@453: morphbr@453: config = ConfigParser.ConfigParser() morphbr@453: config.read("stream.conf") morphbr@453: morphbr@453: media_plugin = config.get("Media", "engine") morphbr@453: exec("from plugins.media.%s import *" % media_plugin) morphbr@453: morphbr@453: media = Media(config) morphbr@453: morphbr@453: comm_plugin = config.get("Comm", "engine") morphbr@453: exec("from plugins.comm.%s import *" % comm_plugin) morphbr@453: morphbr@453: # Start Our Server: morphbr@453: server = Server(config) morphbr@453: morphbr@453: print "--> Starting the server..." morphbr@453: morphbr@453: while (server.finish == 0): morphbr@453: con, client = server.getRequest() morphbr@453: morphbr@453: while True: morphbr@453: msg = server.getMsg(1024).strip() morphbr@453: morphbr@453: if not msg: break morphbr@453: morphbr@453: elif (msg == "SETUP"): morphbr@453: setup = server.getMsg(1024).strip().split(" ") morphbr@453: media.setup(setup[0], setup[1], setup[2], \ morphbr@466: setup[3], setup[4], setup[5], morphbr@466: setup[6], setup[7], setup[8], morphbr@466: setup[9]) morphbr@453: morphbr@453: elif (msg == "PLAY"): morphbr@453: media.play() morphbr@453: morphbr@453: elif (msg == "STOP"): morphbr@453: media.stop() morphbr@453: morphbr@453: elif (msg == "CLOSE"): morphbr@453: server.finish = 1 morphbr@453: media.stop() morphbr@453: break morphbr@453: morphbr@453: print "[%s] %s: %s" % (now(), client, msg) morphbr@453: morphbr@453: print "[%s] Closing connection with %s" % (now(), client) morphbr@453: server.disconnect_client(con) morphbr@453: morphbr@453: server.stop() morphbr@466: del(server) morphbr@453: print "--> Server stopped..."