This adapter uses Sentry libraries to automatically report exceptions and code errors to the developers. For more details and for information how to disable the error reporting see Sentry-Plugin Documentation! Sentry reporting is used starting with js-controller 3.0.
SayIt Adapter can convert text to speech and play it on some device.
Actually, the following outputs are supported:
-
Browser - browser will play the text within opened
iobroker.vis
page. It is supported almost by every desktop browser and by few mobile Browsers. -
Home24- MediaPlayer - the text will be sent and played to the Android device with Home24 - MediaPlayer installed. For this will be used build in Android text to speech engine. The port cannot be changed and set to 50000.
-
Home24 - MediaPlayer and FTP Server - the text will be sent and played on the Android device with Home24 - MediaPlayer installed. For this will be used the Google text to speech engine. Generated mp3 file will be copied over FTP to an Android device and played with Home24 - MediaPlayer. Both apps have to have same home directories. (E.g., root directory of "sd card").
-
System - the text will be played by OS, where the ioBroker adapter runs. Following OS are supported: Windows, linux, Mac OSx.
-
Windows engine - the text will be played by windows, where the sayIt adapter runs. For this will be used the Windows text to speech engine, that should be preconfigured by user. You can check here how to set up it.
-
Sonos - play text on the Sonos device. Be sure the Web Adapter is enabled. It is required to enable SONOS to read the generated mp3 files.
-
Heos - play text on HEOS device. Be sure the Web Adapter is enabled. It is required to enable HEOS to read the generated mp3 files.
-
Chromecast - play text on a Chromecast device.
-
MPD - play text on Music Player Daemon. Use only http for web adapter, don't use https.
To enable the text to speech on RaspberryPI or linux system call one time following command sudo apt-get -y install mpg321
to install mpg321.
The mp3/wav files can be played to by writing its name into the object. (e.g. /vis.0/main/img/door-bell.mp3
)
The file must be first loaded.
Online:
- Google: English, German, Russian, Italian, Spanish, French;
- Yandex: Russian To use Yandex voices you must request the API key here: https://tech.yandex.ru/speechkit/cloud/doc/dg/concepts/About-docpage/. [This service will be disabled 1st of Jan 2019 and replaced by Yandex.cloud] To use Yandex.cloud you should register here: [https://cloud.yandex.ru/], install SpeechKIT API in the Cloud and get Auth Token and Folder ID as described in API instructions.
- Cloud: To use Cloud voices you need configured and running
cloud
adapter or enter app-key directly in settings - Amazon Web Services Polly: To use AWS Polly voices, you need to create an access key and secret key here. The Amazon documentation can you find here.
Offline:
-
PicoTTS (linux only): English, German, Italian, Spanish, French; For PicoTTS it is necessary to install the following packages:
libttspico-utils
and lame. Installation command:sudo apt-get install libttspico-utils lame
-
Coqui TTS: English, German, Spanish, French, Dutch, Japanese, Chinese; For instructions how to use go to the official documentation
You can format your text with Speech Synthesis Markup Language.
Most useful features:
<break time="3s"/>
- make a pause for x seconds (max 10 seconds).<emphasis> big </emphasis>
- make an emphasis on some word.<prosody volume="+6dB" rate="90%">I am speaking this</prosody>
- control speed and volume parameters.<say-as interpret-as="digits">12345</say-as>
- say every digit separately.
More info.
If you have some program, that can play audio files locally or somewhere else, you can write this command here. E.g.
myCustomPlayer --option
If System output is selected, the sayit
adapter will execute the following command on a local system:
myCustomPlayer --option /opt/iobroker/node_modules/iobroker.sayit/say.mp3
If file name must stay somewhere in the middle, you can use %s to specify where the file name must be placed:
myCustomPlayer --option "%s" > /dev/null
sayIt will make myCustomPlayer --option "/opt/iobroker/node_modules/iobroker.sayit/say.mp3" > /dev/null
from it.
SayIt adapter cannot be used alone. It must be controlled from javascript adapter or from "vis" with specific widget. After creation of adapter instance, you can find the following objects:
sayit.N.tts.text
: Phrase to be spoken.sayit.N.tts.volume
: volume which will be used by playing of the phrase.sayit.N.tts.playing
: true if a text is now playing and false if not. Supported only for "windows" and "system" play mode.sayit.N.tts.cachetext
: Phrase to be cached, and then it can be used without an internet. E.g., you can enter here manually "No internet" and if ping to google.com is negative, write "No internet" to "tts.text" and it will be pronounced. Of course, cache must be enabled.
State tts.text
supports extended syntax, so the language/engine and volume can be defined together with text. It is used to enable multi-language text2speech engines.
E.g., if adapter has engine Google-english
, it is possible with phrase de:Sag es
to force using Google-Deutsch speech engine.
With ru;75;Погода хорошая
we can force using russian language and volume 75%.
You can specify the volume of announcement in percent from current or given volume (not from maximal). E.g., if command is de;75;Gutes Wetter
and "announce volume" is 50%, the announcement will be played with volume 38% from 100% possible.
The system command to play the mp3 file can be specified too. If you leave it blank, the default settings will be used: windows - cmdmp3.exe
, OSX - /usr/bin/afplay
, linux - mpg321
or omxplayer
(recommended).
To install omxplayer write sudo apt-get install omxplayer
or write sudo apt-get install mpg321
to install mpg321.
Note: The default announce selection will be possible only after the start of the instance.
To immediately pronounce the text despite the queued texts, you have two possibilities:
- place "!" as a first character in text, so this text will be pronounced immediately after the current one.
- write true into "tts.clearQueue" state and the queue will be cleared. After that you can write a new text into
tts.text
, but all queued texts are thrown away.
The following values for engines are possible:
- en - English
- de - Deutsch
- pl - Polski
- ru - Русский
- uk - український
- it - Italiano
- es - Espaniol
- fr - Français
- nl - Nederlands
- zh-CN - 简体中文
- pt - Português
- ru_YA:Yandex - Русский
- ru_YA_CLOUD:Yandex Cloud - Русский [Yandex.Cloud API generates files in OGG format. To play ogg files on linux mplayer should be installed and selected as system player]
- ru-RU_CLOUD_Female - Русский - Татьяна
- ru-RU_CLOUD_Male - Русский - Максим
- de-DE_CLOUD_Female - Deutsch - Marlene
- de-DE_CLOUD_Male - Deutsch - Hans
- de-DE_CLOUD_Female_Vicki - Deutsch - Vicki
- de-DE_CLOUD_Male_Daniel - Deutsch - Daniel
- de-AT_CLOUD_Female_Hannah - Österreich - Hannah
- en-US_CLOUD_Female - en-US - Female - Salli
- en-US_CLOUD_Male - en-US - Male - Joey
- da-DK_CLOUD_Female - da-DK - Female - Naja
- da-DK_CLOUD_Male - da-DK - Male - Mads
- en-AU_CLOUD_Female - en-AU - Female - Nicole
- en-AU_CLOUD_Male - en-AU - Male - Russell
- en-GB_CLOUD_Female_Amy - en-GB - Female - Amy
- en-GB_CLOUD_Male - en-GB - Male - Brian
- en-GB_CLOUD_Female_Emma - en-GB - Female - Emma
- en-GB-WLS_CLOUD_Female - en-GB-WLS - Female - Gwyneth
- en-GB-WLS_CLOUD_Male - en-GB-WLS - Male - Geraint
- cy-GB_CLOUD_Female - cy-GB - Female - Gwyneth
- cy-GB_CLOUD_Male - cy-GB - Male - Geraint
- en-IN_CLOUD_Female - en-IN - Female - Raveena
- en-US_CLOUD_Male_Chipmunk - en-US - Male - Chipmunk
- en-US_CLOUD_Male_Eric - en-US - Male - Eric
- en-US_CLOUD_Female_Ivy - en-US - Female - Ivy
- en-US_CLOUD_Female_Jennifer - en-US - Female - Jennifer
- en-US_CLOUD_Male_Justin - en-US - Male - Justin
- en-US_CLOUD_Female_Kendra - en-US - Female - Kendra
- en-US_CLOUD_Female_Kimberly - en-US - Female - Kimberly
- es-ES_CLOUD_Female - es-ES - Female - Conchita
- es-ES_CLOUD_Male - es-ES - Male - Enrique
- es-US_CLOUD_Female - es-US - Female - Penelope
- es-US_CLOUD_Male - es-US - Male - Miguel
- fr-CA_CLOUD_Female - fr-CA - Female - Chantal
- fr-FR_CLOUD_Female - fr-FR - Female - Celine
- fr-FR_CLOUD_Male - fr-FR - Male - Mathieu
- is-IS_CLOUD_Female - is-IS - Female - Dora
- is-IS_CLOUD_Male - is-IS - Male - Karl
- it-IT_CLOUD_Female - it-IT - Female - Carla
- it-IT_CLOUD_Male - it-IT - Male - Giorgio
- nb-NO_CLOUD_Female - no-NO - Female - Liv
- no-NO_CLOUD_Female - no-NO - Female - Ida
- nl-NL_CLOUD_Female - nl-NL - Female - Lotte
- nl-NL_CLOUD_Male - nl-NL - Male - Ruben
- pl-PL_CLOUD_Female_Agnieszka - pl-PL - Female - Agnieszka
- pl-PL_CLOUD_Male_Jacek - pl-PL - Male - Jacek
- pl-PL_CLOUD_Female_Ewa - pl-PL - Female - Ewa
- pl-PL_CLOUD_Male_Jan - pl-PL - Male - Jan
- pl-PL_CLOUD_Female - pl-PL - Female - Maja
- pt-BR_CLOUD_Female - pt-BR - Female - Vitoria
- pt-BR_CLOUD_Female_Camila - pt-BR - Female - Camila
- pt-BR_CLOUD_Male - pt-BR - Male - Ricardo
- pt-PT_CLOUD_Male - pt-PT - Male - Cristiano
- pt-PT_CLOUD_Female - pt-PT - Female - Ines
- ro-RO_CLOUD_Female - ro-RO - Female - Carmen
- sv-SE_CLOUD_Female - sv-SE - Female - Astrid
- tr-TR_CLOUD_Female - tr-TR - Female - Filiz
- pt-BR_CLOUD_Female_Camila - pt-BR - Female - Camila
- en-US - Englisch US
- en-GB - Englisch GB
- de-DE - Deutsch
- it-IT - Italiano
- es-ES - Espaniol
- fr-FR - Français
- English
- Deutsch
- Espanol
- Francais
- Nederlands
- 日本
- ru-RU_AP_Female - Русский - Татьяна
- ru-RU_AP_Male - Русский - Максим
- de-DE_AP_Female - Deutsch - Marlene
- de-DE_AP_Female_Vicki - Deutsch - Vicki
- de-DE_AP_Male - Deutsch - Hans
- en-US_AP_Female - en-US - Female - Salli
- en-US_AP_Male - en-US - Male - Joey
- da-DK_AP_Female - da-DK - Female - Naja
- da-DK_AP_Male - da-DK - Male - Mads
- en-AU_AP_Female - en-AU - Female - Nicole
- en-AU_AP_Male - en-AU - Male - Russell
- en-GB_AP_Female_Amy - en-GB - Female - Amy
- en-GB_AP_Male - en-GB - Male - Brian
- en-GB_AP_Female_Emma - en-GB - Female - Emma
- en-GB-WLS_AP_Female - en-GB-WLS - Female - Gwyneth
- en-GB-WLS_AP_Male - en-GB-WLS - Male - Geraint
- cy-GB_AP_Female - cy-GB - Female - Gwyneth
- cy-GB_AP_Male - cy-GB - Male - Geraint
- en-IN_AP_Female - en-IN - Female - Raveena
- en-US_AP_Male_Chipmunk - en-US - Male - Chipmunk
- en-US_AP_Male_Eric - en-US - Male - Eric
- en-US_AP_Female_Ivy - en-US - Female - Ivy
- en-US_AP_Female_Jennifer - en-US - Female - Jennifer
- en-US_AP_Male_Justin - en-US - Male - Justin
- en-US_AP_Female_Kendra - en-US - Female - Kendra
- en-US_AP_Female_Kimberly - en-US - Female - Kimberly
- es-ES_AP_Female - es-ES - Female - Conchita
- es-ES_AP_Male - es-ES - Male - Enrique
- es-US_AP_Female - es-US - Female - Penelope
- es-US_AP_Male - es-US - Male - Miguel
- fr-CA_AP_Female - fr-CA - Female - Chantal
- fr-FR_AP_Female - fr-FR - Female - Celine
- fr-FR_AP_Male - fr-FR - Male - Mathieu
- is-IS_AP_Female - is-IS - Female - Dora
- is-IS_AP_Male - is-IS - Male - Karl
- it-IT_AP_Female - it-IT - Female - Carla
- it-IT_AP_Male - it-IT - Male - Giorgio
- nb-NO_AP_Female - nb-NO - Female - Liv
- nl-NL_AP_Female - nl-NL - Female - Lotte
- nl-NL_AP_Male - nl-NL - Male - Ruben
- pl-PL_AP_Female_Agnieszka - pl-PL - Female - Agnieszka
- pl-PL_AP_Male_Jacek - pl-PL - Male - Jacek
- pl-PL_AP_Female_Ewa - pl-PL - Female - Ewa
- pl-PL_AP_Male_Jan - pl-PL - Male - Jan
- pl-PL_AP_Female - pl-PL - Female - Maja
- pt-BR_AP_Female - pt-BR - Female - Vitoria
- pt-BR_AP_Male - pt-BR - Male - Ricardo
- pt-PT_AP_Male - pt-PT - Male - Cristiano
- pt-PT_AP_Female - pt-PT - Female - Ines
- ro-RO_AP_Female - ro-RO - Female - Carmen
- sv-SE_AP_Female - sv-SE - Female - Astrid
- tr-TR_AP_Female - tr-TR - Female - Filiz
- ko-KR_AP_Female - ko-KR - Female - Seoyeon
- (mcm1957) Adapter requires admin v7 or newer now
- (mcm1957) Adapter requires jas-controller 5 or newer now
- (bluefox) Added possibility to play directly from states:
sayit.0/tts.userfiles/gong.mp3
- (bluefox) Packages updated
- (bluefox) Corrected playing in vis
- (bluefox) Corrected blockly
- (bluefox) Corrected upload of files
- (bluefox) Packages updated
- (neopholus) Using the pre-calculated duration of the mp3 to wait long enough even for longer announcements
- (bluefox) Breaking changes: A minimal node.js version is 16
- (bluefox) Browser outputs now to vis(1) and vis-2
- (bluefox) Corrected error with System player
- (bluefox) Do not allow for chromecast to cache files.
- (bluefox) Allowed to add cloud App-Key without running cloud adapter
- (bluefox) Added austrian language
- (bluefox) Added norwegian language
- (klein0r) Used sendTo instead of setState in blockly
- (bluefox) Restored cloud engines. Warning: update cloud adapter to at least 4.4.0
- (bluefox) Breaking changes: A minimal node.js version is 14
- (bluefox) Corrected engines with web-link
- (Jey-Cee) Added support for Coqui TTS
- (bluefox) Renamed all configuration attributes
- (bluefox) Adapter was completely rewritten with async/await
- (bluefox) Could be buggy
- (bluefox) Made compatible with future js-controller
- (bluefox) used setForeignBinaryState if possible
- (bluefox) Fixed errors in io-package.json
- (bluefox) corrected the Google engine
- (bluefox) Added new voices: german, korean, brasil, Dutch
- (Apollon77) Prevent crash case (Sentry IOBROKER-SAYIT-Q, IOBROKER-SAYIT-S, IOBROKER-SAYIT-T)
- (withstu) Support for HEOS was added
- (Apollon77) prevent scheduled restart problems
- (Apollon77) make sure initialize errors do not crash adapter (Sentry IOBROKER-SAYIT-N)
- (Apollon77) catch errors in MDNS discovery (Sentry IOBROKER-SAYIT-E)
- (Apollon77) handle errors from process spawn better (Sentry IOBROKER-SAYIT-D)
- (Apollon77) Move the generated mp3 file to an own directory in iobroker-data instead of inside node_modules (Hopefully not breaking)
- (Apollon77) Change the file writing to use Sync methods to make sure they cannot run in parallel
- (Apollon77) Crash case prevented (Sentry IOBROKER-SAYIT-8)
- (Apollon77) Handle edge cases and prevent crashes (Sentry IOBROKER-SAYIT-4, IOBROKER-SAYIT-6)
- (Apollon77) try to get caching working again for Yandex
- (algar42) GUI updated to fill drop-downs correctly. Premium voices added to Yandex.Cloud engine
- (Apollon77) fixed error handling on file copy
- (algar42) tts.ogg state added for ogg file type
- (bluefox) Showed names of SONOS devices
- (Apollon77) Fix Blockly
- (Apollon77) Update dependencies
- (bluefox) Fixed blockly with missing languages
Changed type of top-level object to "meta" in order to comply with js-controller v3
- (foxriver76) removed usage of adapter.getMessage
- (algar42) Output file extension is changed dynamically based on the engine selected
- (bluefox) Web server URL will be updated if web server was updated
- Add Ukrainian Google Language
- (bluefox) Priority for the text was added
- (BuZZy1337) fixed error in Blockly-Block
- (bluefox) Ivona removed
- (bluefox) Error was fixed by upload of file to FTP
- (bluefox) admin3
- (BuZZy1337) Generate separate mp3 files for each instance.
- Fixes Issue#34
- (BuZZy1337) Always upload mp3 files to the state sayit.X.tts.mp3
- (Apollon77) Remove unneeded logging
- (bondrogeen) Admin3 Fixes
- (angelnu) Wait for a Google Home announcement to complete
- (bluefox) Fix cloud .pro
- (bluefox) Fix system commands
- (bluefox) Code refactoring
- (bluefox) Add Google Home as output
- (bluefox) Remove ivona because not more supported
- (bluefox) Catch error if some directory in mp3 folder
- (bluefox) Fix blockly language
- (DarkChaos) Add AWS Polly as source
- (bluefox) Add cloud as a source
- (bluefox) fixed install problem
- (bluefox) add PicoTTS as a source
- (bluefox) show only installed instances in blockly
- (angelnu) changes for new chromecast tts
- (bluefox) small fixed of config dialog
- (AirKing555) Fix Volume change
- (instalator) add mpd
- (bluefox) Fix cache
- (bluefox) Finish sayit
- (bluefox) Fix changing of engine
- (bluefox) Add omxplayer option
- (bluefox) support for blockly
- (bluefox) Make the type of mp3 as file
- (Vegetto) Support for Chromecast devices
- (bluefox) enable play of mp3 files from disk
- (bluefox) fill default settings by first start
- (bluefox) fixed error with sayItWindows
- (bluefox) fixed error with sayItSystem
- (bluefox) fixed error if received mp3 file is too short
- (bluefox) try to implement cache datapoint (you can use
sayit.0.tts.cachetext
to create cache for phrases and use sayit without internet)
- (bluefox) change google requests from http to https
- (bluefox) add new voice Russian-Maxim
- (bluefox) fixed error with mp24ftp
- (bluefox) fixed error by mediaplayer24
- (bluefox) make the volume for announcement configurable
- (bluefox) make the command for "system" configurable
- (bluefox) fixed volume for an announcement
- (bluefox) support for play files from internal filesystem, like
/sayit.0/tts.userfiles/myGong.mp3
- (bluefox) fixed error with volume by sonos
- (bluefox) fixed error in an announcement
- (bluefox) fixed error in an announcement
- (bluefox) enable announcement
- (bluefox) clear cache if engine changed
- (bluefox) fixed small error with log
- (bluefox) add ivona/Amazon voices
- (bluefox) fixed error by buffering of non-generated texts.
- (bluefox) fixed error by buffering of non-generated texts.
- (bluefox) add yandex-russian support
- (bluefox) queue texts
- (bluefox) initial commit
The MIT License (MIT)
Copyright (c) 2014-2024, bluefox dogafox@gmail.com
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.