diff --git a/docs/source/platypush/plugins/assistant.echo.rst b/docs/source/platypush/plugins/assistant.echo.rst deleted file mode 100644 index f4002cd342..0000000000 --- a/docs/source/platypush/plugins/assistant.echo.rst +++ /dev/null @@ -1,6 +0,0 @@ -``assistant.echo`` -==================================== - -.. automodule:: platypush.plugins.assistant.echo - :members: - diff --git a/docs/source/plugins.rst b/docs/source/plugins.rst index c43fd3cd19..a602352fc4 100644 --- a/docs/source/plugins.rst +++ b/docs/source/plugins.rst @@ -10,7 +10,6 @@ Plugins platypush/plugins/alarm.rst platypush/plugins/application.rst platypush/plugins/arduino.rst - platypush/plugins/assistant.echo.rst platypush/plugins/assistant.google.rst platypush/plugins/autoremote.rst platypush/plugins/bluetooth.rst diff --git a/platypush/plugins/assistant/echo/__init__.py b/platypush/plugins/assistant/echo/__init__.py deleted file mode 100644 index c9429ba876..0000000000 --- a/platypush/plugins/assistant/echo/__init__.py +++ /dev/null @@ -1,133 +0,0 @@ -import os -from typing import Optional - -from platypush.context import get_bus -from platypush.plugins import action -from platypush.plugins.assistant import AssistantPlugin - -from platypush.message.event.assistant import ( - ConversationStartEvent, - ConversationEndEvent, - SpeechRecognizedEvent, - ResponseEvent, -) - - -class AssistantEchoPlugin(AssistantPlugin): - """ - Amazon Echo/Alexa assistant plugin. - - In order to activate the Echo service on your device follow these steps: - - 1. Install avs (``pip install git+https://github.com/BlackLight/avs.git``) - 2. Run the ``alexa-auth`` script. A local webservice will start on port 3000 - 3. If a browser instance doesn't open automatically then head to http://localhost:3000 - 4. Log in to your Amazon account - 5. The required credentials will be stored to ~/.avs.json - - """ - - def __init__( - self, - avs_config_file: Optional[str] = None, - audio_device: str = 'default', - audio_player: str = 'default', - **kwargs - ): - """ - :param avs_config_file: AVS credentials file - default: ~/.avs.json. If the file doesn't exist then - an instance of the AVS authentication service will be spawned. You can login through an Amazon - account either in the spawned browser window, if available, or by opening http://your-ip:3000 - in the browser on another machine. - - :param audio_device: Name of the input audio device (default: 'default') - :param audio_player: Player to be used for audio playback (default: 'default'). - Supported values: 'mpv', 'mpg123', 'gstreamer' - """ - from avs.alexa import Alexa - from avs.config import DEFAULT_CONFIG_FILE - from avs.mic import Audio - - super().__init__(**kwargs) - - if not avs_config_file: - avs_config_file = DEFAULT_CONFIG_FILE - - if not avs_config_file or not os.path.isfile(avs_config_file): - from avs.auth import auth - - auth(None, avs_config_file) - self.logger.warning( - 'Amazon Echo assistant credentials not configured. Open http://localhost:3000 ' - + 'to authenticate this client' - ) - - self.audio_device = audio_device - self.audio_player = audio_player - self.audio = Audio(device_name=audio_device) - self.alexa = Alexa(avs_config_file, audio_player=audio_player) - self._ready = False - - self.alexa.state_listener.on_ready = self._on_ready() - self.alexa.state_listener.on_listening = self._on_listening() - self.alexa.state_listener.on_speaking = self._on_speaking() - self.alexa.state_listener.on_thinking = self._on_thinking() - self.alexa.state_listener.on_finished = self._on_finished() - self.alexa.state_listener.on_disconnected = self._on_disconnected() - - self.audio.link(self.alexa) - self.alexa.start() - - def _on_ready(self): - def _callback(): - self._ready = True - - return _callback - - def _on_listening(self): - def _callback(): - get_bus().post(ConversationStartEvent(assistant=self)) - - return _callback - - def _on_speaking(self): - def _callback(): - # AVS doesn't provide a way to access the response text - get_bus().post(ResponseEvent(assistant=self, response_text='')) - - return _callback - - def _on_finished(self): - def _callback(): - get_bus().post(ConversationEndEvent(assistant=self)) - - return _callback - - def _on_disconnected(self): - def _callback(): - self._ready = False - - return _callback - - def _on_thinking(self): - def _callback(): - # AVS doesn't provide a way to access the detected text - get_bus().post(SpeechRecognizedEvent(assistant=self, phrase='')) - - return _callback - - @action - def start_conversation(self, **_): - if not self._ready: - raise RuntimeError('Echo assistant not ready') - - self.audio.start() - self.alexa.listen() - - @action - def stop_conversation(self): - self.audio.stop() - self._on_finished()() - - -# vim:sw=4:ts=4:et: diff --git a/platypush/plugins/assistant/echo/manifest.yaml b/platypush/plugins/assistant/echo/manifest.yaml deleted file mode 100644 index b19df7be1d..0000000000 --- a/platypush/plugins/assistant/echo/manifest.yaml +++ /dev/null @@ -1,13 +0,0 @@ -manifest: - events: - platypush.message.event.assistant.ConversationEndEvent: when a new conversation - ends - platypush.message.event.assistant.ConversationStartEvent: when a new conversation - starts - platypush.message.event.assistant.SpeechRecognizedEvent: when a new voice command - is recognized - install: - pip: - - avs - package: platypush.plugins.assistant.echo - type: plugin diff --git a/setup.py b/setup.py index fee1bf083d..129ee380d8 100755 --- a/setup.py +++ b/setup.py @@ -190,8 +190,6 @@ setup( 'flic': [ 'flic @ https://github.com/50ButtonsEach/fliclib-linux-hci/tarball/master' ], - # Support for Alexa/Echo plugin - 'alexa': ['avs @ https://github.com/BlackLight/avs/tarball/master'], # Support for Bluetooth devices 'bluetooth': [ 'bleak',