summaryrefslogtreecommitdiff
path: root/voctocore/lib/commands.py
diff options
context:
space:
mode:
authorMaZderMind <git@mazdermind.de>2015-09-02 15:08:49 +0200
committerMaZderMind <git@mazdermind.de>2015-09-02 15:08:49 +0200
commitc61fe2b667079168387376da1c09823967476b21 (patch)
tree4e281f520c228b0525df403706903962d6c84da9 /voctocore/lib/commands.py
parent46aace37db5c035a6d6b432db261dc7c417456f4 (diff)
refactor commands and notify code
Diffstat (limited to 'voctocore/lib/commands.py')
-rw-r--r--voctocore/lib/commands.py207
1 files changed, 113 insertions, 94 deletions
diff --git a/voctocore/lib/commands.py b/voctocore/lib/commands.py
index c972c69..dd4ef0d 100644
--- a/voctocore/lib/commands.py
+++ b/voctocore/lib/commands.py
@@ -2,127 +2,146 @@
import logging
import json
-
from lib.config import Config
from lib.videomix import CompositeModes
+from lib.response import NotifyResponse, OkResponse
-class ControlServerCommands():
- def __init__(self, pipeline):
- self.log = logging.getLogger('ControlServerCommands')
+def decodeName(items, name_or_id):
+ try:
+ name_or_id = int(name_or_id)
+ if name_or_id < 0 or name_or_id >= len(items):
+ raise IndexError("unknown index %d" % name_or_id)
- self.pipeline = pipeline
- self.sources = Config.getlist('mix', 'sources')
- self.blankersources = Config.getlist('stream-blanker', 'sources')
+ return name_or_id
- def decodeSourceName(self, src_name_or_id):
- if isinstance(src_name_or_id, str):
- try:
- return self.sources.index(src_name_or_id)
- except Exception as e:
- raise IndexError("source %s unknown" % src_name_or_id)
+ except ValueError as e:
+ try:
+ return items.index(name_or_id)
+
+ except ValueError as e:
+ raise IndexError("unknown name %s" % name_or_id)
+
+def decodeEnumName(enum, name_or_id):
+ try:
+ name_or_id = int(name_or_id)
+ if name_or_id < 0 or name_or_id >= len(enum):
+ raise IndexError("unknown index %d" % name_or_id)
- if src_name_or_id < 0 or src_name_or_id >= len(self.sources):
- raise IndexError("source %s unknown" % src_name_or_id)
+ return name_or_id
- def encodeSourceName(self, src_id):
+ except ValueError as e:
try:
- return self.sources[src_id]
- except Exception as e:
- raise IndexError("source %s unknown" % src_id)
+ return enum[name_or_id]
- def decodeBlankerSourceName(self, src_name_or_id):
- if isinstance(src_name_or_id, str):
- try:
- return self.blankersources.index(src_name_or_id)
- except Exception as e:
- raise IndexError("source %s unknown" % src_name_or_id)
+ except KeyError as e:
+ raise IndexError("unknown name %s" % name_or_id)
- if src_name_or_id < 0 or src_name_or_id >= len(self.blankersources):
- raise IndexError("source %s unknown" % src_name_or_id)
+def encodeName(items, id):
+ try:
+ return items[id]
+ except IndexError as e:
+ raise IndexError("unknown index %d" % id)
- def encodeBlankerSourceName(self, src_id):
- try:
- return self.blankersources[src_id]
- except Exception as e:
- raise IndexError("source %s unknown" % src_id)
+def encodeEnumName(enum, id):
+ try:
+ return enum(id).name
+ except ValueError as e:
+ raise IndexError("unknown index %d" % id)
+
+class ControlServerCommands(object):
+ def __init__(self, pipeline):
+ self.log = logging.getLogger('ControlServerCommands')
+
+ self.pipeline = pipeline
+
+ self.sources = Config.getlist('mix', 'sources')
+ self.blankerSources = Config.getlist('stream-blanker', 'sources')
# Commands are defined below. Errors are sent to the clients by throwing
# exceptions, they will be turned into messages outside.
- def fetch(self, command):
- if command not in ['set', 'get', 'message', 'signal']:
- raise Exception("unknown command")
- return getattr(self, command)
-
def message(self, *args):
- return " ".join(args), True
+ return NotifyResponse('message', args)
- def signal(self, *args):
- return "", True
- def get(self, subcommand, *args, signal=False):
- return getattr(self, "_get_"+subcommand)(*args), signal
+ def _get_video_status(self):
+ a = encodeName( self.sources, self.pipeline.vmix.getVideoSourceA() )
+ b = encodeName( self.sources, self.pipeline.vmix.getVideoSourceB() )
+ return [a, b]
- def set(self, subcommand, *args):
- getattr(self, "_set_"+subcommand)(*args)
- return self.get(subcommand, *args, signal=True)
+ def get_video(self):
+ status = self._get_video_status()
+ return OkResponse('videoStatus', *status)
- def _get_video(self, target, _=None):
- if target not in ['a', 'b']:
- raise Exception("invalid video source name: 'a' or 'b' expected.")
- cmd = "getVideoSource" + target.upper()
- src_id = getattr(self.pipeline.vmix, cmd)()
- return self.encodeSourceName(src_id)
+ def set_video_a(self, src_name_or_id):
+ src_id = decodeName(self.sources, src_name_or_id)
+ self.pipeline.vmix.setVideoSourceA(src_id)
- def _set_video(self, target, src_name_or_id):
- if target not in ['a', 'b']:
- raise Exception("invalid video source name: 'a' or 'b' expected.")
- src_id = self.decodeSourceName(src_name_or_id)
- getattr(self.pipeline.vmix, 'setVideoSource' + target.upper())(src_id)
+ status = self._get_video_status()
+ return NotifyResponse('videoStatus', *status)
- def _set_audio(self, src_name_or_id):
- src_id = self.decodeSourceName(src_name_or_id)
- self.pipeline.amix.setAudioSource(src_id)
+ def set_video_b(self, src_name_or_id):
+ src_id = decodeName(self.sources, src_name_or_id)
+ self.pipeline.vmix.setVideoSourceB(src_id)
+
+ status = self._get_video_status()
+ return NotifyResponse('videoStatus', *status)
- def _get_audio(self, _=None):
+
+ def _get_audio_status(self):
src_id = self.pipeline.amix.getAudioSource()
- return self.encodeSourceName(src_id)
+ return encodeName(self.sources, src_id)
- def _set_composite(self, composite_mode):
- try:
- mode = CompositeModes[composite_mode]
- except KeyError as e:
- raise KeyError("composite-mode %s unknown" % composite_mode)
+ def get_audio(self):
+ status = self._get_audio_status()
+ return OkResponse('audioStatus', status)
+
+ def set_audio(self, src_name_or_id):
+ src_id = decodeName(self.sources, src_name_or_id)
+ self.pipeline.amix.setAudioSource(src_id)
+ status = self._get_audio_status()
+ return NotifyResponse('audioStatus', status)
+
+
+ def _get_composite_status(self):
+ mode = self.pipeline.vmix.getCompositeMode()
+ return encodeEnumName(CompositeModes, mode)
+
+ def get_composite(self):
+ status = self._get_composite_status()
+ return OkResponse('compositeMode', status)
+
+ def set_composite(self, mode_name_or_id):
+ mode = decodeEnumName(CompositeModes, mode_name_or_id)
self.pipeline.vmix.setCompositeMode(mode)
- def _get_composite(self, _=None):
- try:
- mode = self.pipeline.vmix.getCompositeMode()
- return mode.name
- except Exception as e:
- raise KeyError("composite-mode %s unknown" % mode)
+ status = self._get_composite_status()
+ return NotifyResponse('compositeMode', status)
- def _set_status(self, *args):
- try:
- if args[0] == "live":
- self.pipeline.streamblanker.setBlankSource(None)
- elif args [0] == "blank":
- src_id = self.decodeBlankerSourceName(args[1])
- self.pipeline.streamblanker.setBlankSource(src_id)
- else:
- raise IndexError()
- except IndexError as e:
- raise Exception("invocation: set_status (live | blank <mode>)")
-
- def _get_status(self, *args):
- if self.pipeline.streamblanker.blankSource is None:
- return "live"
-
- name = self.encodeBlankerSourceName(self.pipeline.streamblanker.blankSource)
- return "blank " + name
-
- def _get_config(self):
- confdict = {k: dict(v) for k, v in dict(Config).items()}
- return json.dumps(confdict)
+ def _get_stream_status(self):
+ blankSource = self.pipeline.streamblanker.blankSource
+ return encodeName(self.blankerSources, blankSource)
+
+ def get_stream_status(self):
+ status = self._get_stream_status()
+ return OkResponse('streamStatus', status)
+
+ def set_stream_blank(self, source_name_or_id):
+ src_id = decodeName(self.blankerSources, source_name_or_id)
+ self.pipeline.streamblanker.setBlankSource(src_id)
+
+ status = self._get_stream_status()
+ return NotifyResponse('streamStatus', status)
+
+ def set_stream_live(self):
+ self.pipeline.streamblanker.setBlankSource(None)
+
+ status = self._get_stream_status()
+ return NotifyResponse('streamStatus', status)
+
+
+ def get_config(self):
+ confdict = {header: dict(section) for header, section in dict(Config).items()}
+ return json.dumps(confdict)