+ AMAD - Automagic Android Device
+
+ This module integrates Android devices into FHEM and displays several settings using the Android app "Automagic".
+ Automagic is comparable to the "Tasker" app for automating tasks and configuration settings. But Automagic is more user-friendly. The "Automagic Premium" app currently costs EUR 2.90.
+
+ Any information retrievable by Automagic can be displayed in FHEM by this module. Just define your own Automagic-"flow" and send the data to the AMADCommBridge. One even can control several actions on Android devices.
+
+ To be able to make use of all these functions the Automagic app and additional flows need to be installed on the Android device. The flows can be retrieved from the FHEM directory, the app can be bought in Google Play Store.
+
+ How to use AMAD?
+
+
install the "Automagic Premium" app from the Google Play store.
+
install the flowset 74_AMADautomagicFlowset$VERSION.xml from the directory $INSTALLFHEM/FHEM/lib/ on your Android device and activate.
+
+
+ Now you need to define a device in FHEM.
+
+
+ Define
+
+ define <name> AMAD <IP-ADDRESS>
+
+ Example:
+
+ define WandTabletWohnzimmer AMAD 192.168.0.23
+
+
+ With this command two new AMAD devices in a room called AMAD are created. The parameter <IP-ADDRESS< defines the IP address of your Android device. The second device created is the AMADCommBridge which serves as a communication device from each Android device to FHEM.
+ !!!Coming Soon!!! The communication port of each AMAD device may be set by the definition of the "port" attribute. One needs background knowledge of Automagic and HTTP requests as this port will be set in the HTTP request trigger of both flows, therefore the port also needs to be set there.
+
+ The communication port of the AMADCommBridge device can easily be changed within the attribut "port".
+
+
+ AMAD Communication Bridge
+
+ Creating your first AMAD device automatically creates the AMADCommBridge device in the room AMAD. With the help of the AMADCommBridge any Android device communicates initially to FHEM.To make the IP addresse of the FHEM server known to the Android device, the FHEM server IP address needs to be configured in the AMADCommBridge. WITHOUT THIS STEP THE AMADCommBridge WILL NOT WORK PROPERLY.
+ Please us the following command for configuration of the FHEM server IP address in the AMADCommBridge: set AMADCommBridge fhemServerIP <FHEM-IP>.
+ Additionally the expertMode may be configured. By this setting a direct communication with FHEM will be established without the restriction of needing to make use of a notify to execute set commands.
+
+
+ You are finished now! After 15 seconds latest the readings of your AMAD Android device should be updated. Consequently each 15 seconds a status request will be sent. If the state of your AMAD Android device does not change to "active" over a longer period of time one should take a look into the log file for error messages.
+
+
+ Readings
+
+
airplanemode - on/off, state of the aeroplane mode
+
androidVersion - currently installed version of Android
+
automagicState - state of the Automagic App (prerequisite Android >4.3). In case you have Android >4.3 and the reading says "not supported", you need to enable Automagic inside Android / Settings / Sound & notification / Notification access
+
batteryHealth - the health of the battery (1=unknown, 2=good, 3=overheat, 4=dead, 5=over voltage, 6=unspecified failure, 7=cold)
+
batterytemperature - the temperature of the battery
+
bluetooth - on/off, bluetooth state
+
checkActiveTask - state of an app (needs to be defined beforehand). 0=not active or not active in foreground, 1=active in foreground, see note below
+
connectedBTdevices - list of all devices connected via bluetooth
+
connectedBTdevicesMAC - list of MAC addresses of all devices connected via bluetooth
+
currentMusicAlbum - currently playing album of mediaplayer
+
currentMusicApp - currently playing player app (Amazon Music, Google Play Music, Google Play Video, Spotify, YouTube, TuneIn Player, Aldi Life Music)
+
currentMusicArtist - currently playing artist of mediaplayer
+
currentMusicIcon - cover of currently play albumNoch nicht fertig implementiert
+
currentMusicState - state of currently/last used mediaplayer
+
currentMusicTrack - currently playing song title of mediaplayer
+
daydream - on/off, daydream currently active
+
deviceState - state of Android devices. unknown, online, offline.
+
doNotDisturb - state of do not Disturb Mode
+
dockingState - undocked/docked, Android device in docking station
+
flow_SetCommands - active/inactive, state of SetCommands flow
+
flow_informations - active/inactive, state of Informations flow
+
flowsetVersionAtDevice - currently installed version of the flowsets on the Android device
+
incomingCallerName - Callername from last Call
+
incomingCallerNumber - Callernumber from last Call
+
incommingWhatsAppMessageFrom - last WhatsApp message
+
incommingWhatsTelegramMessageFrom - last telegram message
+
intentRadioName - name of the most-recent streamed intent radio
+
intentRadioState - state of intent radio player
+
keyguardSet - 0/1 keyguard set, 0=no 1=yes, does not indicate whether it is currently active
+
lastSetCommandError - last error message of a set command
+
lastSetCommandState - last state of a set command, command send successful/command send unsuccessful
+
lastStatusRequestError - last error message of a statusRequest command
+
lastStatusRequestState - ast state of a statusRequest command, command send successful/command send unsuccessful
+
nextAlarmDay - currently set day of alarm
+
nextAlarmState - alert/done, current state of "Clock" stock-app
+
nextAlarmTime - currently set time of alarm
+
powerLevel - state of battery in %
+
powerPlugged - 0=no/1,2=yes, power supply connected
+
screen - on locked,unlocked/off locked,unlocked, state of display
+
screenBrightness - 0-255, level of screen-brightness
screenOrientationMode - auto/manual, mode for screen orientation
+
state - current state of AMAD device
+
userFlowState - current state of a Flow, established under setUserFlowState Attribut
+
volume - media volume setting
+
volumeNotification - notification volume setting
+
+ Prerequisite for using the reading checkActivTask the package name of the application to be checked needs to be defined in the attribute checkActiveTask. Example: attr Nexus10Wohnzimmer
+ checkActiveTask com.android.chrome für den Chrome Browser.
+
+
+
+
+ Set
+
+
activateVoiceInput - start voice input on Android device
+
bluetooth - on/off, switch bluetooth on/off
+
clearNotificationBar - All/Automagic, deletes all or only Automagic notifications in status bar
+
closeCall - hang up a running call
+
currentFlowsetUpdate - start flowset update on Android device
+
installFlowSource - install a Automagic flow on device, XML file must be stored in /tmp/ with extension xml. Example:set TabletWohnzimmer installFlowSource WlanUebwerwachen.xml
+
doNotDisturb - sets the do not Disturb Mode, always Disturb, never Disturb, alarmClockOnly alarm Clock only, onlyImportant only important Disturbs
+
mediaAmazonMusic - play/stop/next/back , controlling the amazon music media player
+
mediaGoogleMusic - play/stop/next/back , controlling the google play music media player
+
mediaSpotifyMusic - play/stop/next/back , controlling the spotify media player
+
mediaTuneinRadio - play/stop/next/back , controlling the TuneinRadio media player
+
mediaAldiMusic - play/stop/next/back , controlling the Aldi music media player
+
mediaAudible - play/stop/next/back , controlling the Audible media player
+
mediaYouTube - play/stop/next/back , controlling the YouTube media player
+
mediaVlcPlayer - play/stop/next/back , controlling the VLC media player
+
nextAlarmTime - sets the alarm time. Only valid for the next 24 hours.
+
notifySndFile - plays a media-file which by default needs to be stored in the folder "/storage/emulated/0/Notifications/" of the Android device. You may use the attribute setNotifySndFilePath for defining a different folder.
+
openCall - initial a call and hang up after optional time / set DEVICE openCall 0176354 10 call this number and hang up after 10s
+
screenBrightness - 0-255, set screen brighness
+
screenMsg - display message on screen of Android device
+
sendintent - send intent string Example: set $AMADDEVICE sendIntent org.smblott.intentradio.PLAY url http://stream.klassikradio.de/live/mp3-192/stream.klassikradio.de/play.m3u name Klassikradio, first parameter contains the action, second parameter contains the extra. At most two extras can be used.
+
sendSMS - Sends an SMS to a specific phone number. Bsp.: sendSMS Dies ist ein Test|555487263
+
startDaydream - start Daydream
+
statusRequest - Get a new status report of Android device. Not all readings can be updated using a statusRequest as some readings are only updated if the value of the reading changes.
+
timer - set a countdown timer in the "Clock" stock app. Only seconds are allowed as parameter.
+
ttsMsg - send a message which will be played as voice message
+
userFlowState - set Flow/s active or inactive,set Nexus7Wohnzimmer Badezimmer:inactive vorheizen or set Nexus7Wohnzimmer Badezimmer vorheizen,Nachtlicht Steven:inactive
+
vibrate - vibrate Android device
+
volume - set media volume. Works on internal speaker or, if connected, bluetooth speaker or speaker connected via stereo jack
+
volumeNotification - set notifications volume
+
+
+ Set (depending on attribute values)
+
+
changetoBtDevice - switch to another bluetooth device. Attribute setBluetoothDevice needs to be set. See note below!
+
openApp - start an app. attribute setOpenApp
+
openURL - opens a URLS in the standard browser as long as no other browser is set by the attribute setOpenUrlBrowser.Example: attr Tablet setOpenUrlBrowser de.ozerov.fully|de.ozerov.fully.MainActivity, first parameter: package name, second parameter: Class Name
+
screen - on/off/lock/unlock, switch screen on/off or lock/unlock screen. In Automagic "Preferences" the "Device admin functions" need to be enabled, otherwise "Screen off" does not work. attribute setScreenOnForTimer changes the time the display remains switched on!
+
screenFullscreen - on/off, activates/deactivates full screen mode. attribute setFullscreen
+
screenLock - Locks screen with request for PIN. attribute setScreenlockPIN - enter PIN here. Only use numbers, 4-16 numbers required.
system - issue system command (only with rooted Android devices). reboot,shutdown,airplanemodeON (can only be switched ON) attribute root, in Automagic "Preferences" "Root functions" need to be enabled.
+
setAPSSID - set WLAN AccesPoint SSID to prevent WLAN sleeps
+
setNotifySndFilePath - set systempath to notifyfile (default /storage/emulated/0/Notifications/
+
setTtsMsgSpeed - set speaking speed for TTS (Value between 0.5 - 4.0, 0.5 Step) default is 1.0
+
setTtsMsgLang - set speaking language for TTS, de or en (default is de)
+
+ To be able to use "openApp" the corresponding attribute "setOpenApp" needs to contain the app package name.
+
+ To be able to switch between bluetooth devices the attribute "setBluetoothDevice" needs to contain (a list of) bluetooth devices defined as follows: attr <DEVICE> BTdeviceName1|MAC,BTDeviceName2|MAC No spaces are allowed in any BTdeviceName. Defining MAC please make sure to use the character : (colon) after each second digit/character.
+ Example: attr Nexus10Wohnzimmer setBluetoothDevice Logitech_BT_Adapter|AB:12:CD:34:EF:32,Anker_A3565|GH:56:IJ:78:KL:76
+
+
+
+ state
+
+
initialized - shown after initial define.
+
active - device is active.
+
disabled - device is disabled by the attribute "disable".
+ AMAD - Automagic Android Device
+
+ Dieses Modul liefert, in Verbindung mit der Android APP Automagic, diverse Informationen von Android Geräten.
+ Die AndroidAPP Automagic (welche nicht von mir stammt und 2.90 Euro kostet) funktioniert wie Tasker, ist aber bei weitem User freundlicher.
+
+ Mit etwas Einarbeitung können jegliche Informationen welche Automagic bereit stellt in FHEM angezeigt werden. Hierzu bedarf es lediglich eines eigenen Flows welcher seine Daten an die AMADCommBridge sendet. Das Modul gibt auch die Möglichkeit Androidgeräte zu steuern.
+
+ Für all diese Aktionen und Informationen wird auf dem Androidgerät "Automagic" und ein so genannter Flow benötigt. Die App ist über den Google PlayStore zu beziehen. Das benötigte Flowset bekommt man aus dem FHEM Verzeichnis.
+
+ Wie genau verwendet man nun AMAD?
+
+
man installiert die App "Automagic Premium" aus dem PlayStore.
+
dann installiert man das Flowset 74_AMADautomagicFlowset$VERSION.xml aus dem Ordner $INSTALLFHEM/FHEM/lib/ auf dem Androidgerät und aktiviert die Flows.
+
+
+ Es muß noch ein Device in FHEM anlegt werden.
+
+
+ Define
+
+ define <name> AMAD <IP-ADRESSE>
+
+ Beispiel:
+
+ define WandTabletWohnzimmer AMAD 192.168.0.23
+
+
+ Diese Anweisung erstellt zwei neues AMAD-Device im Raum AMAD.Der Parameter <IP-ADRESSE> legt die IP Adresse des Android Gerätes fest.
+ Das zweite Device ist die AMADCommBridge welche als Kommunikationsbrücke vom Androidgerät zu FHEM diehnt. !!!Comming Soon!!! Wer den Port ändern möchte, kann dies über das Attribut "port" tun. Ihr solltet aber wissen was Ihr tut, da dieser Port im HTTP Request Trigger der beiden Flows eingestellt ist. Demzufolge muß der Port dort auch geändert werden. Der Port für die Bridge kann ohne Probleme im Bridge Device mittels dem Attribut "port" verändert werden.
+
+ Der Port für die Bridge kann ohne Probleme im Bridge Device mittels dem Attribut "port" verändert werden.
+
+
+ AMAD Communication Bridge
+
+ Beim ersten anlegen einer AMAD Deviceinstanz wird automatisch ein Gerät Namens AMADCommBridge im Raum AMAD mit angelegt. Dieses Gerät diehnt zur Kommunikation vom Androidgerät zu FHEM ohne das zuvor eine Anfrage von FHEM aus ging. Damit das Androidgerät die IP von FHEM kennt, muss diese sofort nach dem anlegen der Bridge über den set Befehl in ein entsprechendes Reading in die Bridge geschrieben werden. DAS IST SUPER WICHTIG UND FÜR DIE FUNKTION DER BRIDGE NOTWENDIG.
+ Hierfür muß folgender Befehl ausgeführt werden. set AMADCommBridge fhemServerIP <FHEM-IP>.
+ Als zweites Reading kann expertMode gesetzen werden. Mit diesem Reading wird eine unmittelbare Komminikation mit FHEM erreicht ohne die Einschränkung über ein
+ Notify gehen zu müssen und nur reine set Befehle ausführen zu können.
+
+ NUN bitte die Flows AKTIVIEREN!!!
+
+ Fertig! Nach anlegen der Geräteinstanz und dem eintragen der fhemServerIP in der CommBridge sollten nach spätestens 15 Sekunden bereits die ersten Readings reinkommen. Nun wird alle 15 Sekunden probiert einen Status Request erfolgreich ab zu schließen. Wenn der Status sich über einen längeren Zeitraum nicht auf "active" ändert, sollte man im Log nach eventuellen Fehlern suchen.
+
automagicState - Statusmeldungen von der AutomagicApp (Voraussetzung Android >4.3). Ist Android größer 4.3 vorhanden und im Reading steht "wird nicht unterstützt", muß in den Androideinstellungen unter Ton und Benachrichtigungen -> Benachrichtigungszugriff ein Haken für Automagic gesetzt werden
checkActiveTask - Zustand einer zuvor definierten APP. 0=nicht aktiv oder nicht aktiv im Vordergrund, 1=aktiv im Vordergrund, siehe Hinweis unten
+
connectedBTdevices - eine Liste der verbundenen Gerät
+
connectedBTdevicesMAC - eine Liste der MAC Adressen aller verbundender BT Geräte
+
currentMusicAlbum - aktuell abgespieltes Musikalbum des verwendeten Mediaplayers
+
currentMusicApp - aktuell verwendeter Mediaplayer (Amazon Music, Google Play Music, Google Play Video, Spotify, YouTube, TuneIn Player, Aldi Life Music)
+
currentMusicArtist - aktuell abgespielter Musikinterpret des verwendeten Mediaplayers
+
currentMusicIcon - Cover vom aktuell abgespielten Album Noch nicht fertig implementiert
+
currentMusicState - Status des aktuellen/zuletzt verwendeten Mediaplayers
+
currentMusicTrack - aktuell abgespielter Musiktitel des verwendeten Mediaplayers
+
daydream - on/off, Daydream gestartet oder nicht
+
deviceState - Status des Androidgerätes. unknown, online, offline.
+
doNotDisturb - aktueller Status des nicht stören Modus
+
dockingState - undocked/docked Status ob sich das Gerät in einer Dockinstation befindet.
+
flow_SetCommands - active/inactive, Status des SetCommands Flow
+
flow_informations - active/inactive, Status des Informations Flow
+
flowsetVersionAtDevice - aktuell installierte Flowsetversion auf dem Device
+
incomingCallerName - Anrufername des eingehenden Anrufes
+
incomingCallerNumber - Anrufernummer des eingehenden Anrufes
+
incommingWhatsAppMessageFrom - letzte WhatsApp Nachricht
+
incommingWhatsTelegramMessageFrom - letzte Telegram Nachricht
+
intentRadioName - zuletzt gesrreamter Intent Radio Name
+
intentRadioState - Status des IntentRadio Players
+
keyguardSet - 0/1 Displaysperre gesetzt 0=nein 1=ja, bedeutet nicht das sie gerade aktiv ist
+
lastSetCommandError - letzte Fehlermeldung vom set Befehl
+
lastSetCommandState - letzter Status vom set Befehl, Befehl erfolgreich/nicht erfolgreich gesendet
+
lastStatusRequestError - letzte Fehlermeldung vom statusRequest Befehl
+
lastStatusRequestState - letzter Status vom statusRequest Befehl, Befehl erfolgreich/nicht erfolgreich gesendet
+
nextAlarmDay - aktiver Alarmtag
+
nextAlarmState - aktueller Status des "Androidinternen" Weckers
screenOrientationMode - auto/manual, Modus für die Ausrichtung (Automatisch, Manuell)
+
state - aktueller Status
+
userFlowState - aktueller Status eines Flows, festgelegt unter dem setUserFlowState Attribut
+
volume - Media Lautstärkewert
+
volumeNotification - Benachrichtigungs Lautstärke
+
+ Beim Reading checkActivTask muß zuvor der Packagename der zu prüfenden App als Attribut checkActiveTask angegeben werden. Beispiel: attr Nexus10Wohnzimmer
+ checkActiveTask com.android.chrome für den Chrome Browser.
+
+
+
+
+ Set
+
+
activateVoiceInput - aktiviert die Spracheingabe
+
bluetooth - on/off, aktiviert/deaktiviert Bluetooth
+
clearNotificationBar - All,Automagic, löscht alle Meldungen oder nur die Automagic Meldungen in der Statusleiste
+
closeCall - beendet einen laufenden Anruf
+
currentFlowsetUpdate - fürt ein Flowsetupdate auf dem Device durch
+
doNotDisturb - schaltet den nicht stören Modus, always immer stören, never niemals stören, alarmClockOnly nur Wecker darf stören, onlyImportant nur wichtige Störungen
+
installFlowSource - installiert einen Flow auf dem Device, das XML File muss unter /tmp/ liegen und die Endung xml haben. Bsp:set TabletWohnzimmer installFlowSource WlanUebwerwachen.xml
+
mediaAmazonMusic - play, stop, next, back ,steuert den Amazon Musik Mediaplayer
+
mediaGoogleMusic - play, stop, next, back ,steuert den Google Play Musik Mediaplayer
+
mediaSpotifyMusic - play, stop, next, back ,steuert den Spotify Mediaplayer
+
mediaTuneinRadio - play, stop, next, back ,steuert den TuneIn Radio Mediaplayer
+
mediaAldiMusic - play, stop, next, back ,steuert den Aldi Musik Mediaplayer
+
mediaAudible - play, stop, next, back ,steuert den Audible Mediaplayer
+
mediaYouTube - play, stop, next, back ,steuert den YouTube Mediaplayer
+
mediaVlcPlayer - play, stop, next, back ,steuert den VLC Mediaplayer
+
nextAlarmTime - setzt die Alarmzeit. gilt aber nur innerhalb der nächsten 24Std.
+
openCall - ruft eine Nummer an und legt optional nach X Sekunden auf / set DEVICE openCall 01736458 10 / ruft die Nummer an und beendet den Anruf nach 10s
+
screenBrightness - setzt die Bildschirmhelligkeit, von 0-255.
+
screenMsg - versendet eine Bildschirmnachricht
+
sendintent - sendet einen Intentstring Bsp: set $AMADDEVICE sendIntent org.smblott.intentradio.PLAY url http://stream.klassikradio.de/live/mp3-192/stream.klassikradio.de/play.m3u name Klassikradio, der erste Befehl ist die Aktion und der zweite das Extra. Es können immer zwei Extras mitgegeben werden.
+
sendSMS - sendet eine SMS an eine bestimmte Telefonnummer. Bsp.: sendSMS Dies ist ein Test|555487263
+
startDaydream - startet den Daydream
+
statusRequest - Fordert einen neuen Statusreport beim Device an. Es können nicht von allen Readings per statusRequest die Daten geholt werden. Einige wenige geben nur bei Statusänderung ihren Status wieder.
+
timer - setzt einen Timer innerhalb der als Standard definierten ClockAPP auf dem Device. Es können nur Sekunden angegeben werden.
+
ttsMsg - versendet eine Nachricht welche als Sprachnachricht ausgegeben wird
+
userFlowState - aktiviert oder deaktiviert einen oder mehrere Flows,set Nexus7Wohnzimmer Badezimmer vorheizen:inactive oder set Nexus7Wohnzimmer Badezimmer vorheizen,Nachtlicht Steven:inactive
+
vibrate - lässt das Androidgerät vibrieren
+
volume - setzt die Medialautstärke. Entweder die internen Lautsprecher oder sofern angeschlossen die Bluetoothlautsprecher und per Klinkenstecker angeschlossene Lautsprecher, + oder - vor dem Wert reduziert die aktuelle Lautstärke um den Wert
+
volumeNotification - setzt die Benachrichtigungslautstärke.
+
+
+ Set abhängig von gesetzten Attributen
+
+
changetoBtDevice - wechselt zu einem anderen Bluetooth Gerät. Attribut setBluetoothDevice muß gesetzt sein. Siehe Hinweis unten!
+
notifySndFile - spielt die angegebene Mediadatei auf dem Androidgerät ab. Die aufzurufende Mediadatei sollte sich im Ordner /storage/emulated/0/Notifications/ befinden. Ist dies nicht der Fall kann man über das Attribut setNotifySndFilePath einen Pfad vorgeben.
+
openApp - öffnet eine ausgewählte App. Attribut setOpenApp
+
openURL - öffnet eine URL im Standardbrowser, sofern kein anderer Browser über das Attribut setOpenUrlBrowser ausgewählt wurde. Bsp: attr Tablet setOpenUrlBrowser de.ozerov.fully|de.ozerov.fully.MainActivity, das erste ist der Package Name und das zweite der Class Name
+
setAPSSID - setzt die AccessPoint SSID um ein WLAN sleep zu verhindern
+
screen - on/off/lock/unlock schaltet den Bildschirm ein/aus oder sperrt/entsperrt ihn, in den Automagic Einstellungen muss "Admin Funktion" gesetzt werden sonst funktioniert "Screen off" nicht. Attribut setScreenOnForTimer ändert die Zeit wie lange das Display an bleiben soll!
+
screenFullscreen - on/off, (aktiviert/deaktiviert) den Vollbildmodus. Attribut setFullscreen
+
screenLock - Sperrt den Bildschirm mit Pinabfrage. Attribut setScreenlockPIN - hier die Pin dafür eingeben. Erlaubt sind nur Zahlen. Es müßen mindestens 4, bis max 16 Zeichen verwendet werden.
+
screenOrientation - Auto,Landscape,Portait, aktiviert die Bildschirmausrichtung (Automatisch,Horizontal,Vertikal). Attribut setScreenOrientation
+
system - setzt Systembefehle ab (nur bei gerootetet Geräen). reboot,shutdown,airplanemodeON (kann nur aktiviert werden) Attribut root, in den Automagic Einstellungen muss "Root Funktion" gesetzt werden
+
setNotifySndFilePath - setzt den korrekten Systempfad zur Notifydatei (default ist /storage/emulated/0/Notifications/
+
setTtsMsgSpeed - setzt die Sprachgeschwindigkeit bei der Sprachausgabe(Werte zwischen 0.5 bis 4.0 in 0.5er Schritten) default ist 1.0
+
setTtsMsgSpeed - setzt die Sprache bei der Sprachausgabe, de oder en (default ist de)
+
+ Um openApp verwenden zu können, muss als Attribut der Package Name der App angegeben werden.
+
+ Um zwischen Bluetoothgeräten wechseln zu können, muß das Attribut setBluetoothDevice mit folgender Syntax gesetzt werden. attr <DEVICE> BTdeviceName1|MAC,BTDeviceName2|MAC Es muss
+ zwingend darauf geachtet werden das beim BTdeviceName kein Leerzeichen vorhanden ist. Am besten zusammen oder mit Unterstrich. Achtet bei der MAC darauf das Ihr wirklich nach jeder zweiten Zahl auch
+ einen : drin habt
+ Beispiel: attr Nexus10Wohnzimmer setBluetoothDevice Logitech_BT_Adapter|AB:12:CD:34:EF:32,Anker_A3565|GH:56:IJ:78:KL:76
+
+
+
+ state
+
+
initialized - Ist der Status kurz nach einem define.
+
active - die Geräteinstanz ist im aktiven Status.
+
disabled - die Geräteinstanz wurde über das Attribut disable deaktiviert
- AMAD - Automagic Android Device
-
- This module integrates Android devices into FHEM and displays several settings using the Android app "Automagic".
- Automagic is comparable to the "Tasker" app for automating tasks and configuration settings. But Automagic is more user-friendly. The "Automagic Premium" app currently costs EUR 2.90.
-
- Any information retrievable by Automagic can be displayed in FHEM by this module. Just define your own Automagic-"flow" and send the data to the AMADCommBridge. One even can control several actions on Android devices.
-
- To be able to make use of all these functions the Automagic app and additional flows need to be installed on the Android device. The flows can be retrieved from the FHEM directory, the app can be bought in Google Play Store.
-
- How to use AMAD?
-
-
install the "Automagic Premium" app from the Google Play store.
-
install the flowset 74_AMADautomagicFlowset$VERSION.xml from the directory $INSTALLFHEM/FHEM/lib/ on your Android device and activate.
-
-
- Now you need to define a device in FHEM.
-
-
- Define
-
- define <name> AMAD <IP-ADDRESS>
-
- Example:
-
- define WandTabletWohnzimmer AMAD 192.168.0.23
-
-
- With this command two new AMAD devices in a room called AMAD are created. The parameter <IP-ADDRESS< defines the IP address of your Android device. The second device created is the AMADCommBridge which serves as a communication device from each Android device to FHEM.
- !!!Coming Soon!!! The communication port of each AMAD device may be set by the definition of the "port" attribute. One needs background knowledge of Automagic and HTTP requests as this port will be set in the HTTP request trigger of both flows, therefore the port also needs to be set there.
-
- The communication port of the AMADCommBridge device can easily be changed within the attribut "port".
-
-
- AMAD Communication Bridge
-
- Creating your first AMAD device automatically creates the AMADCommBridge device in the room AMAD. With the help of the AMADCommBridge any Android device communicates initially to FHEM.To make the IP addresse of the FHEM server known to the Android device, the FHEM server IP address needs to be configured in the AMADCommBridge. WITHOUT THIS STEP THE AMADCommBridge WILL NOT WORK PROPERLY.
- Please us the following command for configuration of the FHEM server IP address in the AMADCommBridge: set AMADCommBridge fhemServerIP <FHEM-IP>.
- Additionally the expertMode may be configured. By this setting a direct communication with FHEM will be established without the restriction of needing to make use of a notify to execute set commands.
-
-
- You are finished now! After 15 seconds latest the readings of your AMAD Android device should be updated. Consequently each 15 seconds a status request will be sent. If the state of your AMAD Android device does not change to "active" over a longer period of time one should take a look into the log file for error messages.
-
-
- Readings
-
-
airplanemode - on/off, state of the aeroplane mode
-
androidVersion - currently installed version of Android
-
automagicState - state of the Automagic App (prerequisite Android >4.3). In case you have Android >4.3 and the reading says "not supported", you need to enable Automagic inside Android / Settings / Sound & notification / Notification access
-
batteryHealth - the health of the battery (1=unknown, 2=good, 3=overheat, 4=dead, 5=over voltage, 6=unspecified failure, 7=cold)
-
batterytemperature - the temperature of the battery
-
bluetooth - on/off, bluetooth state
-
checkActiveTask - state of an app (needs to be defined beforehand). 0=not active or not active in foreground, 1=active in foreground, see note below
-
connectedBTdevices - list of all devices connected via bluetooth
-
connectedBTdevicesMAC - list of MAC addresses of all devices connected via bluetooth
-
currentMusicAlbum - currently playing album of mediaplayer
-
currentMusicApp - currently playing player app (Amazon Music, Google Play Music, Google Play Video, Spotify, YouTube, TuneIn Player, Aldi Life Music)
-
currentMusicArtist - currently playing artist of mediaplayer
-
currentMusicIcon - cover of currently play albumNoch nicht fertig implementiert
-
currentMusicState - state of currently/last used mediaplayer
-
currentMusicTrack - currently playing song title of mediaplayer
-
daydream - on/off, daydream currently active
-
deviceState - state of Android devices. unknown, online, offline.
-
doNotDisturb - state of do not Disturb Mode
-
dockingState - undocked/docked, Android device in docking station
-
flow_SetCommands - active/inactive, state of SetCommands flow
-
flow_informations - active/inactive, state of Informations flow
-
flowsetVersionAtDevice - currently installed version of the flowsets on the Android device
-
incomingCallerName - Callername from last Call
-
incomingCallerNumber - Callernumber from last Call
-
incommingWhatsAppMessageFrom - last WhatsApp message
-
incommingWhatsTelegramMessageFrom - last telegram message
-
intentRadioName - name of the most-recent streamed intent radio
-
intentRadioState - state of intent radio player
-
keyguardSet - 0/1 keyguard set, 0=no 1=yes, does not indicate whether it is currently active
-
lastSetCommandError - last error message of a set command
-
lastSetCommandState - last state of a set command, command send successful/command send unsuccessful
-
lastStatusRequestError - last error message of a statusRequest command
-
lastStatusRequestState - ast state of a statusRequest command, command send successful/command send unsuccessful
-
nextAlarmDay - currently set day of alarm
-
nextAlarmState - alert/done, current state of "Clock" stock-app
-
nextAlarmTime - currently set time of alarm
-
powerLevel - state of battery in %
-
powerPlugged - 0=no/1,2=yes, power supply connected
-
screen - on locked,unlocked/off locked,unlocked, state of display
-
screenBrightness - 0-255, level of screen-brightness
screenOrientationMode - auto/manual, mode for screen orientation
-
state - current state of AMAD device
-
userFlowState - current state of a Flow, established under setUserFlowState Attribut
-
volume - media volume setting
-
volumeNotification - notification volume setting
-
- Prerequisite for using the reading checkActivTask the package name of the application to be checked needs to be defined in the attribute checkActiveTask. Example: attr Nexus10Wohnzimmer
- checkActiveTask com.android.chrome für den Chrome Browser.
-
-
-
-
- Set
-
-
activateVoiceInput - start voice input on Android device
-
bluetooth - on/off, switch bluetooth on/off
-
clearNotificationBar - All/Automagic, deletes all or only Automagic notifications in status bar
-
closeCall - hang up a running call
-
currentFlowsetUpdate - start flowset update on Android device
-
installFlowSource - install a Automagic flow on device, XML file must be stored in /tmp/ with extension xml. Example:set TabletWohnzimmer installFlowSource WlanUebwerwachen.xml
-
doNotDisturb - sets the do not Disturb Mode, always Disturb, never Disturb, alarmClockOnly alarm Clock only, onlyImportant only important Disturbs
-
mediaAmazonMusic - play/stop/next/back , controlling the amazon music media player
-
mediaGoogleMusic - play/stop/next/back , controlling the google play music media player
-
mediaSpotifyMusic - play/stop/next/back , controlling the spotify media player
-
mediaTuneinRadio - play/stop/next/back , controlling the TuneinRadio media player
-
mediaAldiMusic - play/stop/next/back , controlling the Aldi music media player
-
mediaAudible - play/stop/next/back , controlling the Audible media player
-
mediaYouTube - play/stop/next/back , controlling the YouTube media player
-
mediaVlcPlayer - play/stop/next/back , controlling the VLC media player
-
nextAlarmTime - sets the alarm time. Only valid for the next 24 hours.
-
notifySndFile - plays a media-file which by default needs to be stored in the folder "/storage/emulated/0/Notifications/" of the Android device. You may use the attribute setNotifySndFilePath for defining a different folder.
-
openCall - initial a call and hang up after optional time / set DEVICE openCall 0176354 10 call this number and hang up after 10s
-
screenBrightness - 0-255, set screen brighness
-
screenMsg - display message on screen of Android device
-
sendintent - send intent string Example: set $AMADDEVICE sendIntent org.smblott.intentradio.PLAY url http://stream.klassikradio.de/live/mp3-192/stream.klassikradio.de/play.m3u name Klassikradio, first parameter contains the action, second parameter contains the extra. At most two extras can be used.
-
sendSMS - Sends an SMS to a specific phone number. Bsp.: sendSMS Dies ist ein Test|555487263
-
startDaydream - start Daydream
-
statusRequest - Get a new status report of Android device. Not all readings can be updated using a statusRequest as some readings are only updated if the value of the reading changes.
-
timer - set a countdown timer in the "Clock" stock app. Only seconds are allowed as parameter.
-
ttsMsg - send a message which will be played as voice message
-
userFlowState - set Flow/s active or inactive,set Nexus7Wohnzimmer Badezimmer:inactive vorheizen or set Nexus7Wohnzimmer Badezimmer vorheizen,Nachtlicht Steven:inactive
-
vibrate - vibrate Android device
-
volume - set media volume. Works on internal speaker or, if connected, bluetooth speaker or speaker connected via stereo jack
-
volumeNotification - set notifications volume
-
-
- Set (depending on attribute values)
-
-
changetoBtDevice - switch to another bluetooth device. Attribute setBluetoothDevice needs to be set. See note below!
-
openApp - start an app. attribute setOpenApp
-
openURL - opens a URLS in the standard browser as long as no other browser is set by the attribute setOpenUrlBrowser.Example: attr Tablet setOpenUrlBrowser de.ozerov.fully|de.ozerov.fully.MainActivity, first parameter: package name, second parameter: Class Name
-
screen - on/off/lock/unlock, switch screen on/off or lock/unlock screen. In Automagic "Preferences" the "Device admin functions" need to be enabled, otherwise "Screen off" does not work. attribute setScreenOnForTimer changes the time the display remains switched on!
-
screenFullscreen - on/off, activates/deactivates full screen mode. attribute setFullscreen
-
screenLock - Locks screen with request for PIN. attribute setScreenlockPIN - enter PIN here. Only use numbers, 4-16 numbers required.
system - issue system command (only with rooted Android devices). reboot,shutdown,airplanemodeON (can only be switched ON) attribute root, in Automagic "Preferences" "Root functions" need to be enabled.
-
setAPSSID - set WLAN AccesPoint SSID to prevent WLAN sleeps
-
setNotifySndFilePath - set systempath to notifyfile (default /storage/emulated/0/Notifications/
-
setTtsMsgSpeed - set speaking speed for TTS (Value between 0.5 - 4.0, 0.5 Step) default is 1.0
-
setTtsMsgLang - set speaking language for TTS, de or en (default is de)
-
- To be able to use "openApp" the corresponding attribute "setOpenApp" needs to contain the app package name.
-
- To be able to switch between bluetooth devices the attribute "setBluetoothDevice" needs to contain (a list of) bluetooth devices defined as follows: attr <DEVICE> BTdeviceName1|MAC,BTDeviceName2|MAC No spaces are allowed in any BTdeviceName. Defining MAC please make sure to use the character : (colon) after each second digit/character.
- Example: attr Nexus10Wohnzimmer setBluetoothDevice Logitech_BT_Adapter|AB:12:CD:34:EF:32,Anker_A3565|GH:56:IJ:78:KL:76
-
-
-
- state
-
-
initialized - shown after initial define.
-
active - device is active.
-
disabled - device is disabled by the attribute "disable".
- AMAD - Automagic Android Device
-
- Dieses Modul liefert, in Verbindung mit der Android APP Automagic, diverse Informationen von Android Geräten.
- Die AndroidAPP Automagic (welche nicht von mir stammt und 2.90 Euro kostet) funktioniert wie Tasker, ist aber bei weitem User freundlicher.
-
- Mit etwas Einarbeitung können jegliche Informationen welche Automagic bereit stellt in FHEM angezeigt werden. Hierzu bedarf es lediglich eines eigenen Flows welcher seine Daten an die AMADCommBridge sendet. Das Modul gibt auch die Möglichkeit Androidgeräte zu steuern.
-
- Für all diese Aktionen und Informationen wird auf dem Androidgerät "Automagic" und ein so genannter Flow benötigt. Die App ist über den Google PlayStore zu beziehen. Das benötigte Flowset bekommt man aus dem FHEM Verzeichnis.
-
- Wie genau verwendet man nun AMAD?
-
-
man installiert die App "Automagic Premium" aus dem PlayStore.
-
dann installiert man das Flowset 74_AMADautomagicFlowset$VERSION.xml aus dem Ordner $INSTALLFHEM/FHEM/lib/ auf dem Androidgerät und aktiviert die Flows.
-
-
- Es muß noch ein Device in FHEM anlegt werden.
-
-
- Define
-
- define <name> AMAD <IP-ADRESSE>
-
- Beispiel:
-
- define WandTabletWohnzimmer AMAD 192.168.0.23
-
-
- Diese Anweisung erstellt zwei neues AMAD-Device im Raum AMAD.Der Parameter <IP-ADRESSE> legt die IP Adresse des Android Gerätes fest.
- Das zweite Device ist die AMADCommBridge welche als Kommunikationsbrücke vom Androidgerät zu FHEM diehnt. !!!Comming Soon!!! Wer den Port ändern möchte, kann dies über das Attribut "port" tun. Ihr solltet aber wissen was Ihr tut, da dieser Port im HTTP Request Trigger der beiden Flows eingestellt ist. Demzufolge muß der Port dort auch geändert werden. Der Port für die Bridge kann ohne Probleme im Bridge Device mittels dem Attribut "port" verändert werden.
-
- Der Port für die Bridge kann ohne Probleme im Bridge Device mittels dem Attribut "port" verändert werden.
-
-
- AMAD Communication Bridge
-
- Beim ersten anlegen einer AMAD Deviceinstanz wird automatisch ein Gerät Namens AMADCommBridge im Raum AMAD mit angelegt. Dieses Gerät diehnt zur Kommunikation vom Androidgerät zu FHEM ohne das zuvor eine Anfrage von FHEM aus ging. Damit das Androidgerät die IP von FHEM kennt, muss diese sofort nach dem anlegen der Bridge über den set Befehl in ein entsprechendes Reading in die Bridge geschrieben werden. DAS IST SUPER WICHTIG UND FÜR DIE FUNKTION DER BRIDGE NOTWENDIG.
- Hierfür muß folgender Befehl ausgeführt werden. set AMADCommBridge fhemServerIP <FHEM-IP>.
- Als zweites Reading kann expertMode gesetzen werden. Mit diesem Reading wird eine unmittelbare Komminikation mit FHEM erreicht ohne die Einschränkung über ein
- Notify gehen zu müssen und nur reine set Befehle ausführen zu können.
-
- NUN bitte die Flows AKTIVIEREN!!!
-
- Fertig! Nach anlegen der Geräteinstanz und dem eintragen der fhemServerIP in der CommBridge sollten nach spätestens 15 Sekunden bereits die ersten Readings reinkommen. Nun wird alle 15 Sekunden probiert einen Status Request erfolgreich ab zu schließen. Wenn der Status sich über einen längeren Zeitraum nicht auf "active" ändert, sollte man im Log nach eventuellen Fehlern suchen.
-
automagicState - Statusmeldungen von der AutomagicApp (Voraussetzung Android >4.3). Ist Android größer 4.3 vorhanden und im Reading steht "wird nicht unterstützt", muß in den Androideinstellungen unter Ton und Benachrichtigungen -> Benachrichtigungszugriff ein Haken für Automagic gesetzt werden
checkActiveTask - Zustand einer zuvor definierten APP. 0=nicht aktiv oder nicht aktiv im Vordergrund, 1=aktiv im Vordergrund, siehe Hinweis unten
-
connectedBTdevices - eine Liste der verbundenen Gerät
-
connectedBTdevicesMAC - eine Liste der MAC Adressen aller verbundender BT Geräte
-
currentMusicAlbum - aktuell abgespieltes Musikalbum des verwendeten Mediaplayers
-
currentMusicApp - aktuell verwendeter Mediaplayer (Amazon Music, Google Play Music, Google Play Video, Spotify, YouTube, TuneIn Player, Aldi Life Music)
-
currentMusicArtist - aktuell abgespielter Musikinterpret des verwendeten Mediaplayers
-
currentMusicIcon - Cover vom aktuell abgespielten Album Noch nicht fertig implementiert
-
currentMusicState - Status des aktuellen/zuletzt verwendeten Mediaplayers
-
currentMusicTrack - aktuell abgespielter Musiktitel des verwendeten Mediaplayers
-
daydream - on/off, Daydream gestartet oder nicht
-
deviceState - Status des Androidgerätes. unknown, online, offline.
-
doNotDisturb - aktueller Status des nicht stören Modus
-
dockingState - undocked/docked Status ob sich das Gerät in einer Dockinstation befindet.
-
flow_SetCommands - active/inactive, Status des SetCommands Flow
-
flow_informations - active/inactive, Status des Informations Flow
-
flowsetVersionAtDevice - aktuell installierte Flowsetversion auf dem Device
-
incomingCallerName - Anrufername des eingehenden Anrufes
-
incomingCallerNumber - Anrufernummer des eingehenden Anrufes
-
incommingWhatsAppMessageFrom - letzte WhatsApp Nachricht
-
incommingWhatsTelegramMessageFrom - letzte Telegram Nachricht
-
intentRadioName - zuletzt gesrreamter Intent Radio Name
-
intentRadioState - Status des IntentRadio Players
-
keyguardSet - 0/1 Displaysperre gesetzt 0=nein 1=ja, bedeutet nicht das sie gerade aktiv ist
-
lastSetCommandError - letzte Fehlermeldung vom set Befehl
-
lastSetCommandState - letzter Status vom set Befehl, Befehl erfolgreich/nicht erfolgreich gesendet
-
lastStatusRequestError - letzte Fehlermeldung vom statusRequest Befehl
-
lastStatusRequestState - letzter Status vom statusRequest Befehl, Befehl erfolgreich/nicht erfolgreich gesendet
-
nextAlarmDay - aktiver Alarmtag
-
nextAlarmState - aktueller Status des "Androidinternen" Weckers
screenOrientationMode - auto/manual, Modus für die Ausrichtung (Automatisch, Manuell)
-
state - aktueller Status
-
userFlowState - aktueller Status eines Flows, festgelegt unter dem setUserFlowState Attribut
-
volume - Media Lautstärkewert
-
volumeNotification - Benachrichtigungs Lautstärke
-
- Beim Reading checkActivTask muß zuvor der Packagename der zu prüfenden App als Attribut checkActiveTask angegeben werden. Beispiel: attr Nexus10Wohnzimmer
- checkActiveTask com.android.chrome für den Chrome Browser.
-
-
-
-
- Set
-
-
activateVoiceInput - aktiviert die Spracheingabe
-
bluetooth - on/off, aktiviert/deaktiviert Bluetooth
-
clearNotificationBar - All,Automagic, löscht alle Meldungen oder nur die Automagic Meldungen in der Statusleiste
-
closeCall - beendet einen laufenden Anruf
-
currentFlowsetUpdate - fürt ein Flowsetupdate auf dem Device durch
-
doNotDisturb - schaltet den nicht stören Modus, always immer stören, never niemals stören, alarmClockOnly nur Wecker darf stören, onlyImportant nur wichtige Störungen
-
installFlowSource - installiert einen Flow auf dem Device, das XML File muss unter /tmp/ liegen und die Endung xml haben. Bsp:set TabletWohnzimmer installFlowSource WlanUebwerwachen.xml
-
mediaAmazonMusic - play, stop, next, back ,steuert den Amazon Musik Mediaplayer
-
mediaGoogleMusic - play, stop, next, back ,steuert den Google Play Musik Mediaplayer
-
mediaSpotifyMusic - play, stop, next, back ,steuert den Spotify Mediaplayer
-
mediaTuneinRadio - play, stop, next, back ,steuert den TuneIn Radio Mediaplayer
-
mediaAldiMusic - play, stop, next, back ,steuert den Aldi Musik Mediaplayer
-
mediaAudible - play, stop, next, back ,steuert den Audible Mediaplayer
-
mediaYouTube - play, stop, next, back ,steuert den YouTube Mediaplayer
-
mediaVlcPlayer - play, stop, next, back ,steuert den VLC Mediaplayer
-
nextAlarmTime - setzt die Alarmzeit. gilt aber nur innerhalb der nächsten 24Std.
-
openCall - ruft eine Nummer an und legt optional nach X Sekunden auf / set DEVICE openCall 01736458 10 / ruft die Nummer an und beendet den Anruf nach 10s
-
screenBrightness - setzt die Bildschirmhelligkeit, von 0-255.
-
screenMsg - versendet eine Bildschirmnachricht
-
sendintent - sendet einen Intentstring Bsp: set $AMADDEVICE sendIntent org.smblott.intentradio.PLAY url http://stream.klassikradio.de/live/mp3-192/stream.klassikradio.de/play.m3u name Klassikradio, der erste Befehl ist die Aktion und der zweite das Extra. Es können immer zwei Extras mitgegeben werden.
-
sendSMS - sendet eine SMS an eine bestimmte Telefonnummer. Bsp.: sendSMS Dies ist ein Test|555487263
-
startDaydream - startet den Daydream
-
statusRequest - Fordert einen neuen Statusreport beim Device an. Es können nicht von allen Readings per statusRequest die Daten geholt werden. Einige wenige geben nur bei Statusänderung ihren Status wieder.
-
timer - setzt einen Timer innerhalb der als Standard definierten ClockAPP auf dem Device. Es können nur Sekunden angegeben werden.
-
ttsMsg - versendet eine Nachricht welche als Sprachnachricht ausgegeben wird
-
userFlowState - aktiviert oder deaktiviert einen oder mehrere Flows,set Nexus7Wohnzimmer Badezimmer vorheizen:inactive oder set Nexus7Wohnzimmer Badezimmer vorheizen,Nachtlicht Steven:inactive
-
vibrate - lässt das Androidgerät vibrieren
-
volume - setzt die Medialautstärke. Entweder die internen Lautsprecher oder sofern angeschlossen die Bluetoothlautsprecher und per Klinkenstecker angeschlossene Lautsprecher, + oder - vor dem Wert reduziert die aktuelle Lautstärke um den Wert
-
volumeNotification - setzt die Benachrichtigungslautstärke.
-
-
- Set abhängig von gesetzten Attributen
-
-
changetoBtDevice - wechselt zu einem anderen Bluetooth Gerät. Attribut setBluetoothDevice muß gesetzt sein. Siehe Hinweis unten!
-
notifySndFile - spielt die angegebene Mediadatei auf dem Androidgerät ab. Die aufzurufende Mediadatei sollte sich im Ordner /storage/emulated/0/Notifications/ befinden. Ist dies nicht der Fall kann man über das Attribut setNotifySndFilePath einen Pfad vorgeben.
-
openApp - öffnet eine ausgewählte App. Attribut setOpenApp
-
openURL - öffnet eine URL im Standardbrowser, sofern kein anderer Browser über das Attribut setOpenUrlBrowser ausgewählt wurde. Bsp: attr Tablet setOpenUrlBrowser de.ozerov.fully|de.ozerov.fully.MainActivity, das erste ist der Package Name und das zweite der Class Name
-
setAPSSID - setzt die AccessPoint SSID um ein WLAN sleep zu verhindern
-
screen - on/off/lock/unlock schaltet den Bildschirm ein/aus oder sperrt/entsperrt ihn, in den Automagic Einstellungen muss "Admin Funktion" gesetzt werden sonst funktioniert "Screen off" nicht. Attribut setScreenOnForTimer ändert die Zeit wie lange das Display an bleiben soll!
-
screenFullscreen - on/off, (aktiviert/deaktiviert) den Vollbildmodus. Attribut setFullscreen
-
screenLock - Sperrt den Bildschirm mit Pinabfrage. Attribut setScreenlockPIN - hier die Pin dafür eingeben. Erlaubt sind nur Zahlen. Es müßen mindestens 4, bis max 16 Zeichen verwendet werden.
-
screenOrientation - Auto,Landscape,Portait, aktiviert die Bildschirmausrichtung (Automatisch,Horizontal,Vertikal). Attribut setScreenOrientation
-
system - setzt Systembefehle ab (nur bei gerootetet Geräen). reboot,shutdown,airplanemodeON (kann nur aktiviert werden) Attribut root, in den Automagic Einstellungen muss "Root Funktion" gesetzt werden
-
setNotifySndFilePath - setzt den korrekten Systempfad zur Notifydatei (default ist /storage/emulated/0/Notifications/
-
setTtsMsgSpeed - setzt die Sprachgeschwindigkeit bei der Sprachausgabe(Werte zwischen 0.5 bis 4.0 in 0.5er Schritten) default ist 1.0
-
setTtsMsgSpeed - setzt die Sprache bei der Sprachausgabe, de oder en (default ist de)
-
- Um openApp verwenden zu können, muss als Attribut der Package Name der App angegeben werden.
-
- Um zwischen Bluetoothgeräten wechseln zu können, muß das Attribut setBluetoothDevice mit folgender Syntax gesetzt werden. attr <DEVICE> BTdeviceName1|MAC,BTDeviceName2|MAC Es muss
- zwingend darauf geachtet werden das beim BTdeviceName kein Leerzeichen vorhanden ist. Am besten zusammen oder mit Unterstrich. Achtet bei der MAC darauf das Ihr wirklich nach jeder zweiten Zahl auch
- einen : drin habt
- Beispiel: attr Nexus10Wohnzimmer setBluetoothDevice Logitech_BT_Adapter|AB:12:CD:34:EF:32,Anker_A3565|GH:56:IJ:78:KL:76
-
-
-
- state
-
-
initialized - Ist der Status kurz nach einem define.
-
active - die Geräteinstanz ist im aktiven Status.
-
disabled - die Geräteinstanz wurde über das Attribut disable deaktiviert
- AMAD - Automagic Android Device
-
- Dieses Modul liefert, in Verbindung mit der Android APP Automagic, diverse Informationen von Android Geräten.
- Die AndroidAPP Automagic (welche nicht von mir stammt und 2.90 Euro kostet) funktioniert wie Tasker, ist aber bei weitem User freundlicher.
-
- Mit etwas Einarbeitung können jegliche Informationen welche Automagic bereit stellt in FHEM angezeigt werden. Hierzu bedarf es lediglich eines eigenen Flows welcher seine Daten an die AMADCommBridge sendet. Das Modul gibt auch die Möglichkeit Androidgeräte zu steuern.
-
- Für all diese Aktionen und Informationen wird auf dem Androidgerät "Automagic" und ein so genannter Flow benötigt. Die App ist über den Google PlayStore zu beziehen. Das benötigte Flowset bekommt man aus dem FHEM Verzeichnis.
-
- Wie genau verwendet man nun AMAD?
-
-
man installiert die App "Automagic Premium" aus dem PlayStore oder die Testversion von hier
-
dann installiert man das Flowset 74_AMADautomagicFlowset$VERSION.xml aus dem Ordner $INSTALLFHEM/FHEM/lib/ auf dem Androidgerät und aktiviert die Flows.
-
-
- Es muß noch ein Device in FHEM anlegt werden.
-
-
- Diese Anweisung erstellt zwei neues AMAD-Device im Raum AMAD.Der Parameter <IP-ADRESSE> legt die IP Adresse des Android Gerätes fest und der Parameter WLANAP-SSID die SSID Deines WLAN's. Es können mehrere SSID's mit angegeben werden, welche dann durch Komma getrennt sein müssen. Haben die SSID's Leerzeichen im Namen werde die Leerzeichen durch 2 @ aufgefüllt. Gibt es Androidgeräte welche nicht über WLAN sondern USB-Ethernet angeschlossen sind, ist die WLANAP-SSID mit "usb-ethernet" zu benennen
- Das zweite Device ist die AMADCommBridge welche als Kommunikationsbrücke vom Androidgerät zu FHEM diehnt. !!!Comming Soon!!! Wer den Port ändern möchte, kann dies über das Attribut "port" tun. Ihr solltet aber wissen was Ihr tut, da dieser Port im HTTP Request Trigger der beiden Flows eingestellt ist. Demzufolge muß der Port dort auch geändert werden. Der Port für die Bridge kann ohne Probleme im Bridge Device mittels dem Attribut "port" verändert werden.
-
- Der Port für die Bridge kann ohne Probleme im Bridge Device mittels dem Attribut "port" verändert werden.
-
-
- AMAD Communication Bridge
-
- Beim ersten anlegen einer AMAD Deviceinstanz wird automatisch ein Gerät Namens AMADCommBridge im Raum AMAD mit angelegt. Dieses Gerät diehnt zur Kommunikation vom Androidgerät zu FHEM ohne das zuvor eine Anfrage von FHEM aus ging. Damit das Androidgerät die IP von FHEM kennt, muss diese sofort nach dem anlegen der Bridge über den set Befehl in ein entsprechendes Reading in die Bridge geschrieben werden. DAS IST SUPER WICHTIG UND FÜR DIE FUNKTION DER BRIDGE NOTWENDIG.
- Hierfür muß folgender Befehl ausgeführt werden. set AMADCommBridge fhemServerIP <FHEM-IP>.
- Als zweites Reading kann expertMode gesetzen werden. Mit diesem Reading wird eine unmittelbare Komminikation mit FHEM erreicht ohne die Einschränkung über ein
- Notify gehen zu müssen und nur reine set Befehle ausführen zu können.
-
- NUN bitte die Flows AKTIVIEREN!!!
-
- Fertig! Nach anlegen der Geräteinstanz und dem eintragen der fhemServerIP in der CommBridge sollten nach spätestens 15 Sekunden bereits die ersten Readings reinkommen. Nun wird alle 15 Sekunden probiert einen Status Request erfolgreich ab zu schließen. Wenn der Status sich über einen längeren Zeitraum nicht auf "active" ändert, sollte man im Log nach eventuellen Fehlern suchen.
-
automagicState - Statusmeldungen von der AutomagicApp (Voraussetzung Android >4.3). Ist Android größer 4.3 vorhanden und im Reading steht "wird nicht unterstützt", muß in den Androideinstellungen unter Ton und Benachrichtigungen -> Benachrichtigungszugriff ein Haken für Automagic gesetzt werden
-
bluetooth - on/off, Bluetooth Status an oder aus
-
checkActiveTask - Zustand einer zuvor definierten APP. 0=nicht aktiv oder nicht aktiv im Vordergrund, 1=aktiv im Vordergrund, siehe Hinweis unten
-
connectedBTdevices - eine Liste der verbundenen Gerät
-
connectedBTdevicesMAC - eine Liste der MAC Adressen aller verbundender BT Geräte
-
currentMusicAlbum - aktuell abgespieltes Musikalbum des verwendeten Mediaplayers
screenOrientationMode - auto/manual, Modus für die Ausrichtung (Automatisch, Manuell)
-
state - aktueller Status
-
volume - Media Lautstärkewert
-
volumeNotification - Benachrichtigungs Lautstärke
-
- Beim Reading checkActivTask muß zuvor der Packagename der zu prüfenden App als Attribut checkActiveTask angegeben werden. Beispiel: attr Nexus10Wohnzimmer
- checkActiveTask com.android.chrome für den Chrome Browser.
-
-
-
-
- Set
-
-
activateVoiceInput - aktiviert die Spracheingabe
-
amazonMusic - play, stop, next, back ,steuert den Amazon Musik Mediaplayer
-
bluetooth - on/off, aktiviert/deaktiviert Bluetooth
-
clearNotificationBar - All,Automagic, löscht alle Meldungen oder nur die Automagic Meldungen in der Statusleiste
-
currentFlowsetUpdate - fürt ein Flowsetupdate auf dem Device durch
-
googleMusic - play, stop, next, back ,steuert den Google Play Musik Mediaplayer
-
installFlowSource - installiert einen Flow auf dem Device, das XML File muss unter /tmp/ liegen und die Endung xml haben. Bsp:set TabletWohnzimmer installFlowSource WlanUebwerwachen.xml
-
nextAlarmTime - setzt die Alarmzeit. gilt aber nur innerhalb der nächsten 24Std.
-
screenBrightness - setzt die Bildschirmhelligkeit, von 0-255.
-
screenMsg - versendet eine Bildschirmnachricht
-
sendintent - sendet einen Intentstring Bsp: set $AMADDEVICE sendIntent org.smblott.intentradio.PLAY url http://stream.klassikradio.de/live/mp3-192/stream.klassikradio.de/play.m3u name Klassikradio, der erste Befehl ist die Aktion und der zweite das Extra. Es können immer zwei Extras mitgegeben werden.
-
spotifyMusic - play, stop, next, back ,steuert den Spotify Mediaplayer
-
statusRequest - Fordert einen neuen Statusreport beim Device an. Es können nicht von allen Readings per statusRequest die Daten geholt werden. Einige wenige geben nur bei Statusänderung ihren Status wieder.
-
timer - setzt einen Timer innerhalb der als Standard definierten ClockAPP auf dem Device. Es können nur Sekunden angegeben werden.
-
ttsMsg - versendet eine Nachricht welche als Sprachnachricht ausgegeben wird
-
vibrate - lässt das Androidgerät vibrieren
-
volume - setzt die Medialautstärke. Entweder die internen Lautsprecher oder sofern angeschlossen die Bluetoothlautsprecher und per Klinkenstecker angeschlossene Lautsprecher
-
volumeNotification - setzt die Benachrichtigungslautstärke.
-
-
- Set abhängig von gesetzten Attributen
-
-
changetoBtDevice - wechselt zu einem anderen Bluetooth Gerät. Attribut setBluetoothDevice muß gesetzt sein. Siehe Hinweis unten!
-
notifySndFile - spielt die angegebene Mediadatei auf dem Androidgerät ab. Die aufzurufende Mediadatei sollte sich im Ordner /storage/emulated/0/Notifications/ befinden. Ist dies nicht der Fall kann man über das Attribut setNotifySndFilePath einen Pfad vorgeben.
-
openApp - öffnet eine ausgewählte App. Attribut setOpenApp
-
openURL - öffnet eine URL im Standardbrowser, sofern kein anderer Browser über das Attribut setOpenUrlBrowser ausgewählt wurde. Bsp: attr Tablet setOpenUrlBrowser de.ozerov.fully|de.ozerov.fully.MainActivity, das erste ist der Package Name und das zweite der Class Name
-
screen - on/off/lock/unlock schaltet den Bildschirm ein/aus oder sperrt/entsperrt ihn, in den Automagic Einstellungen muss "Admin Funktion" gesetzt werden sonst funktioniert "Screen off" nicht. Attribut setScreenOnForTimer ändert die Zeit wie lange das Display an bleiben soll!
-
screenFullscreen - on/off, (aktiviert/deaktiviert) den Vollbildmodus. Attribut setFullscreen
-
screenLock - Sperrt den Bildschirm mit Pinabfrage. Attribut setScreenlockPIN - hier die Pin dafür eingeben. Erlaubt sind nur Zahlen. Es müßen mindestens 4, bis max 16 Zeichen verwendet werden.
-
screenOrientation - Auto,Landscape,Portait, aktiviert die Bildschirmausrichtung (Automatisch,Horizontal,Vertikal). Attribut setScreenOrientation
-
system - setzt Systembefehle ab (nur bei gerootetet Geräen). reboot,shutdown,airplanemodeON (kann nur aktiviert werden) Attribut root, in den Automagic Einstellungen muss "Root Funktion" gesetzt werden
-
setNotifySndFilePath - setzt den korrekten Systempfad zur Notifydatei (default ist /storage/emulated/0/Notifications/
-
setTtsMsgSpeed - setzt die Sprachgeschwindigkeit bei der Sprachausgabe(Werte zwischen 0.5 bis 4.0 in 0.5er Schritten) default ist 1.0
-
- Um openApp verwenden zu können, muss als Attribut der Package Name der App angegeben werden.
-
- Um zwischen Bluetoothgeräten wechseln zu können, muß das Attribut setBluetoothDevice mit folgender Syntax gesetzt werden. attr <DEVICE> BTdeviceName1|MAC,BTDeviceName2|MAC Es muss
- zwingend darauf geachtet werden das beim BTdeviceName kein Leerzeichen vorhanden ist. Am besten zusammen oder mit Unterstrich. Achtet bei der MAC darauf das Ihr wirklich nach jeder zweiten Zahl auch
- einen : drin habt
- Beispiel: attr Nexus10Wohnzimmer setBluetoothDevice Logitech_BT_Adapter|AB:12:CD:34:EF:32,Anker_A3565|GH:56:IJ:78:KL:76
-
-
-
- state
-
-
initialized - Ist der Status kurz nach einem define.
-
active - die Geräteinstanz ist im aktiven Status.
-
disabled - die Geräteinstanz wurde über das Attribut disable deaktiviert
+ AMADDevice - Automagic Android Device
+
+ This module integrates Android devices into FHEM and displays several settings using the Android app "Automagic".
+ Automagic is comparable to the "Tasker" app for automating tasks and configuration settings. But Automagic is more user-friendly. The "Automagic Premium" app currently costs EUR 2.90.
+
+ Any information retrievable by Automagic can be displayed in FHEM by this module. Just define your own Automagic-"flow" and send the data to the AMADDeviceCommBridge. One even can control several actions on Android devices.
+
+ To be able to make use of all these functions the Automagic app and additional flows need to be installed on the Android device. The flows can be retrieved from the FHEM directory, the app can be bought in Google Play Store.
+
+ How to use AMADDevice?
+
+
install the "Automagic Premium" app from the Google Play store.
+
install the flowset 74_AMADDeviceautomagicFlowset$VERSION.xml from the directory $INSTALLFHEM/FHEM/lib/ on your Android device and activate.
+
+ With this command two new AMADDevice devices in a room called AMADDevice are created. The parameter <IP-ADDRESS< defines the IP address of your Android device. The second device created is the AMADDeviceCommBridge which serves as a communication device from each Android device to FHEM.
+ !!!Coming Soon!!! The communication port of each AMADDevice device may be set by the definition of the "port" attribute. One needs background knowledge of Automagic and HTTP requests as this port will be set in the HTTP request trigger of both flows, therefore the port also needs to be set there.
+
+ The communication port of the AMADDeviceCommBridge device can easily be changed within the attribut "port".
+
+
+ AMADDevice Communication Bridge
+
+ Creating your first AMADDevice device automatically creates the AMADDeviceCommBridge device in the room AMADDevice. With the help of the AMADDeviceCommBridge any Android device communicates initially to FHEM.To make the IP addresse of the FHEM server known to the Android device, the FHEM server IP address needs to be configured in the AMADDeviceCommBridge. WITHOUT THIS STEP THE AMADDeviceCommBridge WILL NOT WORK PROPERLY.
+ Please us the following command for configuration of the FHEM server IP address in the AMADDeviceCommBridge: set AMADDeviceCommBridge fhemServerIP <FHEM-IP>.
+ Additionally the expertMode may be configured. By this setting a direct communication with FHEM will be established without the restriction of needing to make use of a notify to execute set commands.
+
+
+ You are finished now! After 15 seconds latest the readings of your AMADDevice Android device should be updated. Consequently each 15 seconds a status request will be sent. If the state of your AMADDevice Android device does not change to "active" over a longer period of time one should take a look into the log file for error messages.
+
+
+ Readings
+
+
airplanemode - on/off, state of the aeroplane mode
+
androidVersion - currently installed version of Android
+
automagicState - state of the Automagic App (prerequisite Android >4.3). In case you have Android >4.3 and the reading says "not supported", you need to enable Automagic inside Android / Settings / Sound & notification / Notification access
+
batteryHealth - the health of the battery (1=unknown, 2=good, 3=overheat, 4=dead, 5=over voltage, 6=unspecified failure, 7=cold)
+
batterytemperature - the temperature of the battery
+
bluetooth - on/off, bluetooth state
+
checkActiveTask - state of an app (needs to be defined beforehand). 0=not active or not active in foreground, 1=active in foreground, see note below
+
connectedBTdevices - list of all devices connected via bluetooth
+
connectedBTdevicesMAC - list of MAC addresses of all devices connected via bluetooth
+
currentMusicAlbum - currently playing album of mediaplayer
+
currentMusicApp - currently playing player app (Amazon Music, Google Play Music, Google Play Video, Spotify, YouTube, TuneIn Player, Aldi Life Music)
+
currentMusicArtist - currently playing artist of mediaplayer
+
currentMusicIcon - cover of currently play albumNoch nicht fertig implementiert
+
currentMusicState - state of currently/last used mediaplayer
+
currentMusicTrack - currently playing song title of mediaplayer
+
daydream - on/off, daydream currently active
+
deviceState - state of Android devices. unknown, online, offline.
+
doNotDisturb - state of do not Disturb Mode
+
dockingState - undocked/docked, Android device in docking station
+
flow_SetCommands - active/inactive, state of SetCommands flow
+
flow_informations - active/inactive, state of Informations flow
+
flowsetVersionAtDevice - currently installed version of the flowsets on the Android device
+
incomingCallerName - Callername from last Call
+
incomingCallerNumber - Callernumber from last Call
+
incommingWhatsAppMessageFrom - last WhatsApp message
+
incommingWhatsTelegramMessageFrom - last telegram message
+
intentRadioName - name of the most-recent streamed intent radio
+
intentRadioState - state of intent radio player
+
keyguardSet - 0/1 keyguard set, 0=no 1=yes, does not indicate whether it is currently active
+
lastSetCommandError - last error message of a set command
+
lastSetCommandState - last state of a set command, command send successful/command send unsuccessful
+
lastStatusRequestError - last error message of a statusRequest command
+
lastStatusRequestState - ast state of a statusRequest command, command send successful/command send unsuccessful
+
nextAlarmDay - currently set day of alarm
+
nextAlarmState - alert/done, current state of "Clock" stock-app
+
nextAlarmTime - currently set time of alarm
+
powerLevel - state of battery in %
+
powerPlugged - 0=no/1,2=yes, power supply connected
+
screen - on locked,unlocked/off locked,unlocked, state of display
+
screenBrightness - 0-255, level of screen-brightness
screenOrientationMode - auto/manual, mode for screen orientation
+
state - current state of AMADDevice device
+
userFlowState - current state of a Flow, established under setUserFlowState Attribut
+
volume - media volume setting
+
volumeNotification - notification volume setting
+
+ Prerequisite for using the reading checkActivTask the package name of the application to be checked needs to be defined in the attribute checkActiveTask. Example: attr Nexus10Wohnzimmer
+ checkActiveTask com.android.chrome für den Chrome Browser.
+
+
+
+
+ Set
+
+
activateVoiceInput - start voice input on Android device
+
bluetooth - on/off, switch bluetooth on/off
+
clearNotificationBar - All/Automagic, deletes all or only Automagic notifications in status bar
+
closeCall - hang up a running call
+
currentFlowsetUpdate - start flowset update on Android device
+
installFlowSource - install a Automagic flow on device, XML file must be stored in /tmp/ with extension xml. Example:set TabletWohnzimmer installFlowSource WlanUebwerwachen.xml
+
doNotDisturb - sets the do not Disturb Mode, always Disturb, never Disturb, alarmClockOnly alarm Clock only, onlyImportant only important Disturbs
+
mediaAmazonMusic - play/stop/next/back , controlling the amazon music media player
+
mediaGoogleMusic - play/stop/next/back , controlling the google play music media player
+
mediaSpotifyMusic - play/stop/next/back , controlling the spotify media player
+
mediaTuneinRadio - play/stop/next/back , controlling the TuneinRadio media player
+
mediaAldiMusic - play/stop/next/back , controlling the Aldi music media player
+
mediaAudible - play/stop/next/back , controlling the Audible media player
+
mediaYouTube - play/stop/next/back , controlling the YouTube media player
+
mediaVlcPlayer - play/stop/next/back , controlling the VLC media player
+
nextAlarmTime - sets the alarm time. Only valid for the next 24 hours.
+
notifySndFile - plays a media-file which by default needs to be stored in the folder "/storage/emulated/0/Notifications/" of the Android device. You may use the attribute setNotifySndFilePath for defining a different folder.
+
openCall - initial a call and hang up after optional time / set DEVICE openCall 0176354 10 call this number and hang up after 10s
+
screenBrightness - 0-255, set screen brighness
+
screenMsg - display message on screen of Android device
+
sendintent - send intent string Example: set $AMADDeviceDEVICE sendIntent org.smblott.intentradio.PLAY url http://stream.klassikradio.de/live/mp3-192/stream.klassikradio.de/play.m3u name Klassikradio, first parameter contains the action, second parameter contains the extra. At most two extras can be used.
+
sendSMS - Sends an SMS to a specific phone number. Bsp.: sendSMS Dies ist ein Test|555487263
+
startDaydream - start Daydream
+
statusRequest - Get a new status report of Android device. Not all readings can be updated using a statusRequest as some readings are only updated if the value of the reading changes.
+
timer - set a countdown timer in the "Clock" stock app. Only seconds are allowed as parameter.
+
ttsMsg - send a message which will be played as voice message
+
userFlowState - set Flow/s active or inactive,set Nexus7Wohnzimmer Badezimmer:inactive vorheizen or set Nexus7Wohnzimmer Badezimmer vorheizen,Nachtlicht Steven:inactive
+
vibrate - vibrate Android device
+
volume - set media volume. Works on internal speaker or, if connected, bluetooth speaker or speaker connected via stereo jack
+
volumeNotification - set notifications volume
+
+
+ Set (depending on attribute values)
+
+
changetoBtDevice - switch to another bluetooth device. Attribute setBluetoothDevice needs to be set. See note below!
+
openApp - start an app. attribute setOpenApp
+
openURL - opens a URLS in the standard browser as long as no other browser is set by the attribute setOpenUrlBrowser.Example: attr Tablet setOpenUrlBrowser de.ozerov.fully|de.ozerov.fully.MainActivity, first parameter: package name, second parameter: Class Name
+
screen - on/off/lock/unlock, switch screen on/off or lock/unlock screen. In Automagic "Preferences" the "Device admin functions" need to be enabled, otherwise "Screen off" does not work. attribute setScreenOnForTimer changes the time the display remains switched on!
+
screenFullscreen - on/off, activates/deactivates full screen mode. attribute setFullscreen
+
screenLock - Locks screen with request for PIN. attribute setScreenlockPIN - enter PIN here. Only use numbers, 4-16 numbers required.
system - issue system command (only with rooted Android devices). reboot,shutdown,airplanemodeON (can only be switched ON) attribute root, in Automagic "Preferences" "Root functions" need to be enabled.
+
setAPSSID - set WLAN AccesPoint SSID to prevent WLAN sleeps
+
setNotifySndFilePath - set systempath to notifyfile (default /storage/emulated/0/Notifications/
+
setTtsMsgSpeed - set speaking speed for TTS (Value between 0.5 - 4.0, 0.5 Step) default is 1.0
+
setTtsMsgLang - set speaking language for TTS, de or en (default is de)
+
+ To be able to use "openApp" the corresponding attribute "setOpenApp" needs to contain the app package name.
+
+ To be able to switch between bluetooth devices the attribute "setBluetoothDevice" needs to contain (a list of) bluetooth devices defined as follows: attr <DEVICE> BTdeviceName1|MAC,BTDeviceName2|MAC No spaces are allowed in any BTdeviceName. Defining MAC please make sure to use the character : (colon) after each second digit/character.
+ Example: attr Nexus10Wohnzimmer setBluetoothDevice Logitech_BT_Adapter|AB:12:CD:34:EF:32,Anker_A3565|GH:56:IJ:78:KL:76
+
+
+
+ state
+
+
initialized - shown after initial define.
+
active - device is active.
+
disabled - device is disabled by the attribute "disable".
+ AMADDevice - Automagic Android Device
+
+ Dieses Modul liefert, in Verbindung mit der Android APP Automagic, diverse Informationen von Android Geräten.
+ Die AndroidAPP Automagic (welche nicht von mir stammt und 2.90 Euro kostet) funktioniert wie Tasker, ist aber bei weitem User freundlicher.
+
+ Mit etwas Einarbeitung können jegliche Informationen welche Automagic bereit stellt in FHEM angezeigt werden. Hierzu bedarf es lediglich eines eigenen Flows welcher seine Daten an die AMADDeviceCommBridge sendet. Das Modul gibt auch die Möglichkeit Androidgeräte zu steuern.
+
+ Für all diese Aktionen und Informationen wird auf dem Androidgerät "Automagic" und ein so genannter Flow benötigt. Die App ist über den Google PlayStore zu beziehen. Das benötigte Flowset bekommt man aus dem FHEM Verzeichnis.
+
+ Wie genau verwendet man nun AMADDevice?
+
+
man installiert die App "Automagic Premium" aus dem PlayStore.
+
dann installiert man das Flowset 74_AMADDeviceautomagicFlowset$VERSION.xml aus dem Ordner $INSTALLFHEM/FHEM/lib/ auf dem Androidgerät und aktiviert die Flows.
+
+
+ Es muß noch ein Device in FHEM anlegt werden.
+
+
+ Diese Anweisung erstellt zwei neues AMADDevice-Device im Raum AMADDevice.Der Parameter <IP-ADRESSE> legt die IP Adresse des Android Gerätes fest.
+ Das zweite Device ist die AMADDeviceCommBridge welche als Kommunikationsbrücke vom Androidgerät zu FHEM diehnt. !!!Comming Soon!!! Wer den Port ändern möchte, kann dies über das Attribut "port" tun. Ihr solltet aber wissen was Ihr tut, da dieser Port im HTTP Request Trigger der beiden Flows eingestellt ist. Demzufolge muß der Port dort auch geändert werden. Der Port für die Bridge kann ohne Probleme im Bridge Device mittels dem Attribut "port" verändert werden.
+
+ Der Port für die Bridge kann ohne Probleme im Bridge Device mittels dem Attribut "port" verändert werden.
+
+
+ AMADDevice Communication Bridge
+
+ Beim ersten anlegen einer AMADDevice Deviceinstanz wird automatisch ein Gerät Namens AMADDeviceCommBridge im Raum AMADDevice mit angelegt. Dieses Gerät diehnt zur Kommunikation vom Androidgerät zu FHEM ohne das zuvor eine Anfrage von FHEM aus ging. Damit das Androidgerät die IP von FHEM kennt, muss diese sofort nach dem anlegen der Bridge über den set Befehl in ein entsprechendes Reading in die Bridge geschrieben werden. DAS IST SUPER WICHTIG UND FÜR DIE FUNKTION DER BRIDGE NOTWENDIG.
+ Hierfür muß folgender Befehl ausgeführt werden. set AMADDeviceCommBridge fhemServerIP <FHEM-IP>.
+ Als zweites Reading kann expertMode gesetzen werden. Mit diesem Reading wird eine unmittelbare Komminikation mit FHEM erreicht ohne die Einschränkung über ein
+ Notify gehen zu müssen und nur reine set Befehle ausführen zu können.
+
+ NUN bitte die Flows AKTIVIEREN!!!
+
+ Fertig! Nach anlegen der Geräteinstanz und dem eintragen der fhemServerIP in der CommBridge sollten nach spätestens 15 Sekunden bereits die ersten Readings reinkommen. Nun wird alle 15 Sekunden probiert einen Status Request erfolgreich ab zu schließen. Wenn der Status sich über einen längeren Zeitraum nicht auf "active" ändert, sollte man im Log nach eventuellen Fehlern suchen.
+
automagicState - Statusmeldungen von der AutomagicApp (Voraussetzung Android >4.3). Ist Android größer 4.3 vorhanden und im Reading steht "wird nicht unterstützt", muß in den Androideinstellungen unter Ton und Benachrichtigungen -> Benachrichtigungszugriff ein Haken für Automagic gesetzt werden
checkActiveTask - Zustand einer zuvor definierten APP. 0=nicht aktiv oder nicht aktiv im Vordergrund, 1=aktiv im Vordergrund, siehe Hinweis unten
+
connectedBTdevices - eine Liste der verbundenen Gerät
+
connectedBTdevicesMAC - eine Liste der MAC Adressen aller verbundender BT Geräte
+
currentMusicAlbum - aktuell abgespieltes Musikalbum des verwendeten Mediaplayers
+
currentMusicApp - aktuell verwendeter Mediaplayer (Amazon Music, Google Play Music, Google Play Video, Spotify, YouTube, TuneIn Player, Aldi Life Music)
+
currentMusicArtist - aktuell abgespielter Musikinterpret des verwendeten Mediaplayers
+
currentMusicIcon - Cover vom aktuell abgespielten Album Noch nicht fertig implementiert
+
currentMusicState - Status des aktuellen/zuletzt verwendeten Mediaplayers
+
currentMusicTrack - aktuell abgespielter Musiktitel des verwendeten Mediaplayers
+
daydream - on/off, Daydream gestartet oder nicht
+
deviceState - Status des Androidgerätes. unknown, online, offline.
+
doNotDisturb - aktueller Status des nicht stören Modus
+
dockingState - undocked/docked Status ob sich das Gerät in einer Dockinstation befindet.
+
flow_SetCommands - active/inactive, Status des SetCommands Flow
+
flow_informations - active/inactive, Status des Informations Flow
+
flowsetVersionAtDevice - aktuell installierte Flowsetversion auf dem Device
+
incomingCallerName - Anrufername des eingehenden Anrufes
+
incomingCallerNumber - Anrufernummer des eingehenden Anrufes
+
incommingWhatsAppMessageFrom - letzte WhatsApp Nachricht
+
incommingWhatsTelegramMessageFrom - letzte Telegram Nachricht
+
intentRadioName - zuletzt gesrreamter Intent Radio Name
+
intentRadioState - Status des IntentRadio Players
+
keyguardSet - 0/1 Displaysperre gesetzt 0=nein 1=ja, bedeutet nicht das sie gerade aktiv ist
+
lastSetCommandError - letzte Fehlermeldung vom set Befehl
+
lastSetCommandState - letzter Status vom set Befehl, Befehl erfolgreich/nicht erfolgreich gesendet
+
lastStatusRequestError - letzte Fehlermeldung vom statusRequest Befehl
+
lastStatusRequestState - letzter Status vom statusRequest Befehl, Befehl erfolgreich/nicht erfolgreich gesendet
+
nextAlarmDay - aktiver Alarmtag
+
nextAlarmState - aktueller Status des "Androidinternen" Weckers
screenOrientationMode - auto/manual, Modus für die Ausrichtung (Automatisch, Manuell)
+
state - aktueller Status
+
userFlowState - aktueller Status eines Flows, festgelegt unter dem setUserFlowState Attribut
+
volume - Media Lautstärkewert
+
volumeNotification - Benachrichtigungs Lautstärke
+
+ Beim Reading checkActivTask muß zuvor der Packagename der zu prüfenden App als Attribut checkActiveTask angegeben werden. Beispiel: attr Nexus10Wohnzimmer
+ checkActiveTask com.android.chrome für den Chrome Browser.
+
+
+
+
+ Set
+
+
activateVoiceInput - aktiviert die Spracheingabe
+
bluetooth - on/off, aktiviert/deaktiviert Bluetooth
+
clearNotificationBar - All,Automagic, löscht alle Meldungen oder nur die Automagic Meldungen in der Statusleiste
+
closeCall - beendet einen laufenden Anruf
+
currentFlowsetUpdate - fürt ein Flowsetupdate auf dem Device durch
+
doNotDisturb - schaltet den nicht stören Modus, always immer stören, never niemals stören, alarmClockOnly nur Wecker darf stören, onlyImportant nur wichtige Störungen
+
installFlowSource - installiert einen Flow auf dem Device, das XML File muss unter /tmp/ liegen und die Endung xml haben. Bsp:set TabletWohnzimmer installFlowSource WlanUebwerwachen.xml
+
mediaAmazonMusic - play, stop, next, back ,steuert den Amazon Musik Mediaplayer
+
mediaGoogleMusic - play, stop, next, back ,steuert den Google Play Musik Mediaplayer
+
mediaSpotifyMusic - play, stop, next, back ,steuert den Spotify Mediaplayer
+
mediaTuneinRadio - play, stop, next, back ,steuert den TuneIn Radio Mediaplayer
+
mediaAldiMusic - play, stop, next, back ,steuert den Aldi Musik Mediaplayer
+
mediaAudible - play, stop, next, back ,steuert den Audible Mediaplayer
+
mediaYouTube - play, stop, next, back ,steuert den YouTube Mediaplayer
+
mediaVlcPlayer - play, stop, next, back ,steuert den VLC Mediaplayer
+
nextAlarmTime - setzt die Alarmzeit. gilt aber nur innerhalb der nächsten 24Std.
+
openCall - ruft eine Nummer an und legt optional nach X Sekunden auf / set DEVICE openCall 01736458 10 / ruft die Nummer an und beendet den Anruf nach 10s
+
screenBrightness - setzt die Bildschirmhelligkeit, von 0-255.
+
screenMsg - versendet eine Bildschirmnachricht
+
sendintent - sendet einen Intentstring Bsp: set $AMADDeviceDEVICE sendIntent org.smblott.intentradio.PLAY url http://stream.klassikradio.de/live/mp3-192/stream.klassikradio.de/play.m3u name Klassikradio, der erste Befehl ist die Aktion und der zweite das Extra. Es können immer zwei Extras mitgegeben werden.
+
sendSMS - sendet eine SMS an eine bestimmte Telefonnummer. Bsp.: sendSMS Dies ist ein Test|555487263
+
startDaydream - startet den Daydream
+
statusRequest - Fordert einen neuen Statusreport beim Device an. Es können nicht von allen Readings per statusRequest die Daten geholt werden. Einige wenige geben nur bei Statusänderung ihren Status wieder.
+
timer - setzt einen Timer innerhalb der als Standard definierten ClockAPP auf dem Device. Es können nur Sekunden angegeben werden.
+
ttsMsg - versendet eine Nachricht welche als Sprachnachricht ausgegeben wird
+
userFlowState - aktiviert oder deaktiviert einen oder mehrere Flows,set Nexus7Wohnzimmer Badezimmer vorheizen:inactive oder set Nexus7Wohnzimmer Badezimmer vorheizen,Nachtlicht Steven:inactive
+
vibrate - lässt das Androidgerät vibrieren
+
volume - setzt die Medialautstärke. Entweder die internen Lautsprecher oder sofern angeschlossen die Bluetoothlautsprecher und per Klinkenstecker angeschlossene Lautsprecher, + oder - vor dem Wert reduziert die aktuelle Lautstärke um den Wert
+
volumeNotification - setzt die Benachrichtigungslautstärke.
+
+
+ Set abhängig von gesetzten Attributen
+
+
changetoBtDevice - wechselt zu einem anderen Bluetooth Gerät. Attribut setBluetoothDevice muß gesetzt sein. Siehe Hinweis unten!
+
notifySndFile - spielt die angegebene Mediadatei auf dem Androidgerät ab. Die aufzurufende Mediadatei sollte sich im Ordner /storage/emulated/0/Notifications/ befinden. Ist dies nicht der Fall kann man über das Attribut setNotifySndFilePath einen Pfad vorgeben.
+
openApp - öffnet eine ausgewählte App. Attribut setOpenApp
+
openURL - öffnet eine URL im Standardbrowser, sofern kein anderer Browser über das Attribut setOpenUrlBrowser ausgewählt wurde. Bsp: attr Tablet setOpenUrlBrowser de.ozerov.fully|de.ozerov.fully.MainActivity, das erste ist der Package Name und das zweite der Class Name
+
setAPSSID - setzt die AccessPoint SSID um ein WLAN sleep zu verhindern
+
screen - on/off/lock/unlock schaltet den Bildschirm ein/aus oder sperrt/entsperrt ihn, in den Automagic Einstellungen muss "Admin Funktion" gesetzt werden sonst funktioniert "Screen off" nicht. Attribut setScreenOnForTimer ändert die Zeit wie lange das Display an bleiben soll!
+
screenFullscreen - on/off, (aktiviert/deaktiviert) den Vollbildmodus. Attribut setFullscreen
+
screenLock - Sperrt den Bildschirm mit Pinabfrage. Attribut setScreenlockPIN - hier die Pin dafür eingeben. Erlaubt sind nur Zahlen. Es müßen mindestens 4, bis max 16 Zeichen verwendet werden.
+
screenOrientation - Auto,Landscape,Portait, aktiviert die Bildschirmausrichtung (Automatisch,Horizontal,Vertikal). Attribut setScreenOrientation
+
system - setzt Systembefehle ab (nur bei gerootetet Geräen). reboot,shutdown,airplanemodeON (kann nur aktiviert werden) Attribut root, in den Automagic Einstellungen muss "Root Funktion" gesetzt werden
+
setNotifySndFilePath - setzt den korrekten Systempfad zur Notifydatei (default ist /storage/emulated/0/Notifications/
+
setTtsMsgSpeed - setzt die Sprachgeschwindigkeit bei der Sprachausgabe(Werte zwischen 0.5 bis 4.0 in 0.5er Schritten) default ist 1.0
+
setTtsMsgSpeed - setzt die Sprache bei der Sprachausgabe, de oder en (default ist de)
+
+ Um openApp verwenden zu können, muss als Attribut der Package Name der App angegeben werden.
+
+ Um zwischen Bluetoothgeräten wechseln zu können, muß das Attribut setBluetoothDevice mit folgender Syntax gesetzt werden. attr <DEVICE> BTdeviceName1|MAC,BTDeviceName2|MAC Es muss
+ zwingend darauf geachtet werden das beim BTdeviceName kein Leerzeichen vorhanden ist. Am besten zusammen oder mit Unterstrich. Achtet bei der MAC darauf das Ihr wirklich nach jeder zweiten Zahl auch
+ einen : drin habt
+ Beispiel: attr Nexus10Wohnzimmer setBluetoothDevice Logitech_BT_Adapter|AB:12:CD:34:EF:32,Anker_A3565|GH:56:IJ:78:KL:76
+
+
+
+ state
+
+
initialized - Ist der Status kurz nach einem define.
+
active - die Geräteinstanz ist im aktiven Status.
+
disabled - die Geräteinstanz wurde über das Attribut disable deaktiviert
trueNummer anrufen: {param_callnumber}
+ {param_callnumber}true
@@ -2459,7 +2474,7 @@ else
true
- Script: if(package_name == "com.google.android.music") { musicapp = "Google Musik" } if(package_name == "com.amazon.mp3") { musicapp = "Amazon Musik" } if(package_name == "com.google.android.videos") { musicapp = "Google Video" } if(package_name == "com.spotify.music") { musicapp = "Spotify Musik" } if(package_name == "com.google.android.youtube") { musicapp = "YouTube" } if(package_name == "tunein.player") { musicapp = "TuneIn Player" } if(package_name == "com.rhapsody.alditalk") { musicapp = "Aldi Life Musik" } if(package_name == "org.videolan.vlc") { musicapp = "VLC Player" }
+ Script: if(package_name == "com.google.android.music") { musicapp = "Google Musik" } if(package_name == "com.amazon.mp3") { musicapp = "Amazon Musik" } if(package_name == "com.google.android.videos") { musicapp = "Google Video" } if(package_name == "com.spotify.music") { musicapp = "Spotify Musik" } if(package_name == "com.google.android.youtube") { musicapp = "YouTube" } if(package_name == "tunein.player") { musicapp = "TuneIn Player" } if(package_name == "com.rhapsody.alditalk") { musicapp = "Aldi Life Musik" } if(package_name == "org.videolan.vlc") { musicapp = "VLC Player" } if(package_name == "com.sec.android.app.music") { musicapp = "Samsung Music Player" }
@@ -2797,7 +2816,7 @@ fhemcmd = "setreading";
falseScript: Set FHEMDATA JSON
-
@@ -3201,6 +3226,7 @@ if(param_mplayer == "mediaAudible")
trueSMS senden an: an {param_smsnumber} '{param_smsmessage}' (10 in 12h)
+ {param_smsnumber}{param_smsmessage}true
@@ -3219,6 +3245,7 @@ if(param_mplayer == "mediaAudible")
Lautlos{param_notifypath}{param_notifyfile}NOTIFICATION
+ falsetruetrue
@@ -3450,94 +3477,95 @@ Soll der Assistent gelöscht werden?
First Run Assistant
- AMADNG Info/Control Flowset v3.9.75
+ AMADNG Info/Control Flowset v3.9.76falsePARALLEL
- AMAD Voice Control
- Flows löschen: First Run Assistant
- AMAD Voice Control
- AMAD Voice Control
- Flows löschen: First Run Assistant
- Sprachausgabe: In Ordnung. Der Einrichtungs Assistent bleibt erhalten. Auf Wiedersehen.
- Abfrage
- Script: amadcmd = "firstrun"
- Script: amaddevice_ip = {value}
- Eingabedialog: Android Device IP Adresse Einzeiliger Text Bitte gebe die IP Adresse Deines Androidgerätes an. NUR IP kein FQDN!!!
- Script: global_fhemip = {value}
- Eingabedialog: FHEM Server IP Einzeiliger Text Bitte gebe die IP Adresse oder den FQDN Deines FHEM Servers an.
- Script: global_fhemdevice = {value}
- Eingabedialog: FHEM Devicename Einzeiliger Text Wie soll das Device in FHEM heißen?
- Script: global_bridgeport = {value}
- Eingabedialog: AMADCommBridge Port Einzeiliger Text Bitte gebe den Port der AMADCommBridge vom FHEM Server an.
- Sprachausgabe: Du möchtest also nicht fortfahren. Das ist schade. Bitte bedenke das dieses Android Gerät somit nicht als Amaad Device in Fhem angelegt ist. Du kannst jeder Zeit den Assistenten Flow neu aktivieren und von vorn beginnen.
-Auf Wiedersehen.
- AMAD Voice Control
- Medienlautstärke Wiederherstellen
- Lautstärke einstellen: Medien auf Level 8
- Medianlautstärken Speichern
- Setze Flow Status: Aktivieren Informations
- Setze Flow Status: Aktivieren SetCommands,Update AMAD Flowset,VoiceControl
- Pause: 2s (Gerät wach halten)
- Script: readingsvalcmd = "{global_fhemdevice} deviceState kaputt"; fhemcmd = "readingsval"; respfirstrun = "none";
- Expression: value != ""
- Sprachausgabe: Oh das tut mir leid, da scheine ich Dich nicht verstanden zu haben. Bitte versuche es mit etwas Ruhe im Hintergrund noch einmal.
- Expression: value == "nein"
- Expression: value == "ja"
- Expression: value == "ja"
- Sprachausgabe: In Ordnung. Der Einrichtungs Assistent wird gelöscht. Auf Wiedersehen.
- Sprachausgabe: Oh das tut mir leid, da scheine ich Dich nicht verstanden zu haben. Bitte versuche es mit etwas Ruhe im Hintergrund noch einmal.
- Expression: value != ""
- Expression: value == "nein"
- Expression: value != ""
- Sprachausgabe: Oh das tut mir leid, da scheine ich Dich nicht verstanden zu haben. Bitte versuche es mit etwas Ruhe im Hintergrund noch einmal.
- Expression: value == "nein"
- Expression: value == "ja"
- Flows löschen: First Run Assistant
- Sprachausgabe: In Ordnung. Der Einrichtungs Assistent wird gelöscht. Auf Wiedersehen.
- Sprachausgabe: In Ordnung. Der Einrichtungs Assistent bleibt erhalten. Auf Wiedersehen.
- Expression: value != ""
- Sprachausgabe: Oh das tut mir leid, da scheine ich Dich nicht verstanden zu haben. Bitte versuche es mit etwas Ruhe im Hintergrund noch einmal.
- Sprachausgabe: In Ordnung. Der Einrichtungs Assistent wird gelöscht. Auf Wiedersehen.
- Sprachausgabe: In Ordnung. Der Einrichtungs Assistent bleibt erhalten. Auf Wiedersehen.
- Expression: value == "ja"
- Expression: value == "nein"
- Script: if(index == 0) { sprachassi = "ja"; } else { sprachassi = "nein"; }
- AMAD First Run Assistent Begrüßung
- Eingabedialog: Wünschst Du einen sprachgestützten oder dialoggestützten Installationsassistanten? Einfachauswahl Menü Sprache,Dialog (15s)
- Script: global_amadid = getDate();
- Setze Flow Status: Deaktivieren First Run Assistant
- Setze Flow Status: Aktivieren Send Data to AMADCommBridge
- Script: global_activetask = "none"; global_apssid = "none"; global_userflowstate = "none";
- Sprachausgabe: Wunderbar. Bitte nimm Dir Zeit und lese Dir die Hilfe Dialoge genau durch. Wenn Du Dir unsicher bist, kannst Du die Standardeinstellung, sofern vorhanden, belassen. Lass uns nun mit der Einrichtung beginnen.
- Meldungsdialog: Wunderbar. Bitte nimm Dir Zeit und lese Dir die Hilfe Dialoge genau durch. Wenn Du Dir unsicher bist, kannst Du die Standardeinstellung, sofern vorhanden, belassen. Lass uns nun mit der Einrichtung beginnen.
- Expression: sprachassi == "ja"
- Flows ausführen: Send Data to AMADCommBridge
- Sprachausgabe: Alle Informationen wurden nun erfasst und zur Amaad Comm Bridge gesendet. Ich werde gleich einmal prüfen ob die Einrichtung des Devices in Fhem gelungen ist. Gib mir bitte bis zu einer Minute Zeit für die Prüfung.
- Expression: sprachassi == "ja"
- Meldungsdialog: Alle Informationen wurden nun erfasst und zur Amaad Comm Bridge gesendet. Ich werde gleich einmal prüfen ob die Einrichtung des Devices in Fhem gelungen ist. Gib mir bitte bis zu einer Minute Zeit für die Prüfung.
- Expression: respreadingsval != "kaputt" and respreadingsval != "none"
- Expression: sprachassi == "ja"
- Sprachausgabe: Leider scheint es ein Problem beim einrichten des Fhem Devices gegeben zu haben. Hast Du die Amaad Comm Bridge definiert? Und ist sie auch aktiv? Sollte es weiterhin Probleme geben, wende Dich bitte an Cooltux alias Leon, im Fhem Forum.
-Soll der Assistent gelöscht werden?
- Meldungsdialog: Leider scheint es ein Problem beim Einrichten des FHEM Devices gegeben zu haben. Hast Du die AMADCommBridge definiert, und ist sie auch aktiv? Sollte es weiterhin Probleme geben, wende Dich bitte an CoolTux alias Leon, im FHEM Forum.
- Expression: sprachassi == "ja"
- Sprachausgabe: Die Einrichtung ist nun abgeschlossen und das Amaad Device wurde angelegt. Es scheint aber noch keine Verbindung zwischen Fhem und Deinem Amaad Device zu bestehen. Mache am besten einmal ein Status Request in Fhem für das Amaad Device. Ist der Status in Fhem weiterhin offline schaue bitte ob alle Amaad, Flows aktiv sind.
-Soll der Assistent gelöscht werden?
- Meldungsdialog: Die Einrichtung ist nun abgeschlossen und das Amaad Device wurde angelegt. Es scheint aber noch keine Verbindung zwischen Fhem und Deinem Amaad Device zu bestehen. Mache am besten einmal ein Status Request in Fhem für das Amaad Device. Ist der Status in Fhem weiterhin offline schaue bitte ob alle Am
- Expression: respreadingsval == "online"
- Sprachausgabe: Die Einrichtung ist nun abgeschlossen und das Amaad Device online.
-Soll der Assistent gelöscht werden?
- Expression: sprachassi == "ja"
- Meldungsdialog: Wunderbar. Bitte nimm Dir Zeit und lese Dir die Hilfe Dialoge genau durch. Wenn Du Dir unsicher bist, kannst Du die Standardeinstellung, sofern vorhanden, belassen. Lass uns nun mit der Einrichtung beginnen.
-
+ App Task Beendet: ch.gridvision.ppam.androidautomagic
-
-
-
-
-
-
+ AMAD Voice Control
+ Flows löschen: First Run Assistant
+ AMAD Voice Control
+ AMAD Voice Control
+ Flows löschen: First Run Assistant
+ Sprachausgabe: In Ordnung. Der Einrichtungs Assistent bleibt erhalten. Auf Wiedersehen.
+ Abfrage
+ Script: amadcmd = "firstrun"
+ Script: amaddevice_ip = {value}
+ Eingabedialog: Android Device IP Adresse Einzeiliger Text Bitte gebe die IP Adresse Deines Androidgerätes an. NUR IP kein FQDN!!!
+ Script: global_fhemip = {value}
+ Eingabedialog: FHEM Server IP Einzeiliger Text Bitte gebe die IP Adresse oder den FQDN Deines FHEM Servers an.
+ Script: global_fhemdevice = {value}
+ Eingabedialog: FHEM Devicename Einzeiliger Text Wie soll das Device in FHEM heißen?
+ Script: global_bridgeport = {value}
+ Eingabedialog: AMADCommBridge Port Einzeiliger Text Bitte gebe den Port der AMADCommBridge vom FHEM Server an.
+ Sprachausgabe: Du möchtest also nicht fortfahren. Das ist schade. Bitte bedenke das dieses Android Gerät somit nicht als Amaad Device in Fhem angelegt ist. Du kannst jeder Zeit den Assistenten Flow neu aktivieren und von vorn beginnen.
+Auf Wiedersehen.
+ AMAD Voice Control
+ Medienlautstärke Wiederherstellen
+ Lautstärke einstellen: Medien auf Level 8
+ Medianlautstärken Speichern
+ Setze Flow Status: Aktivieren Informations
+ Setze Flow Status: Aktivieren SetCommands,Update AMAD Flowset,VoiceControl
+ Pause: 2s (Gerät wach halten)
+ Script: readingsvalcmd = "{global_fhemdevice} deviceState kaputt"; fhemcmd = "readingsval"; respfirstrun = "none";
+ Expression: value != ""
+ Sprachausgabe: Oh das tut mir leid, da scheine ich Dich nicht verstanden zu haben. Bitte versuche es mit etwas Ruhe im Hintergrund noch einmal.
+ Expression: value == "nein"
+ Expression: value == "ja"
+ Expression: value == "ja"
+ Sprachausgabe: In Ordnung. Der Einrichtungs Assistent wird gelöscht. Auf Wiedersehen.
+ Sprachausgabe: Oh das tut mir leid, da scheine ich Dich nicht verstanden zu haben. Bitte versuche es mit etwas Ruhe im Hintergrund noch einmal.
+ Expression: value != ""
+ Expression: value == "nein"
+ Expression: value != ""
+ Sprachausgabe: Oh das tut mir leid, da scheine ich Dich nicht verstanden zu haben. Bitte versuche es mit etwas Ruhe im Hintergrund noch einmal.
+ Expression: value == "nein"
+ Expression: value == "ja"
+ Flows löschen: First Run Assistant
+ Sprachausgabe: In Ordnung. Der Einrichtungs Assistent wird gelöscht. Auf Wiedersehen.
+ Sprachausgabe: In Ordnung. Der Einrichtungs Assistent bleibt erhalten. Auf Wiedersehen.
+ Expression: value != ""
+ Sprachausgabe: Oh das tut mir leid, da scheine ich Dich nicht verstanden zu haben. Bitte versuche es mit etwas Ruhe im Hintergrund noch einmal.
+ Sprachausgabe: In Ordnung. Der Einrichtungs Assistent wird gelöscht. Auf Wiedersehen.
+ Sprachausgabe: In Ordnung. Der Einrichtungs Assistent bleibt erhalten. Auf Wiedersehen.
+ Expression: value == "ja"
+ Expression: value == "nein"
+ Script: if(index == 0) { sprachassi = "ja"; } else { sprachassi = "nein"; }
+ AMAD First Run Assistent Begrüßung
+ Eingabedialog: Wünschst Du einen sprachgestützten oder dialoggestützten Installationsassistanten? Einfachauswahl Menü Sprache,Dialog (15s)
+ Script: global_amadid = getDate();
+ Setze Flow Status: Deaktivieren First Run Assistant
+ Setze Flow Status: Aktivieren Send Data to AMADCommBridge
+ Script: global_activetask = "none"; global_apssid = "none"; global_userflowstate = "none";
+ Sprachausgabe: Wunderbar. Bitte nimm Dir Zeit und lese Dir die Hilfe Dialoge genau durch. Wenn Du Dir unsicher bist, kannst Du die Standardeinstellung, sofern vorhanden, belassen. Lass uns nun mit der Einrichtung beginnen.
+ Meldungsdialog: Wunderbar. Bitte nimm Dir Zeit und lese Dir die Hilfe Dialoge genau durch. Wenn Du Dir unsicher bist, kannst Du die Standardeinstellung, sofern vorhanden, belassen. Lass uns nun mit der Einrichtung beginnen.
+ Expression: sprachassi == "ja"
+ Flows ausführen: Send Data to AMADCommBridge
+ Sprachausgabe: Alle Informationen wurden nun erfasst und zur Amaad Comm Bridge gesendet. Ich werde gleich einmal prüfen ob die Einrichtung des Devices in Fhem gelungen ist. Gib mir bitte bis zu einer Minute Zeit für die Prüfung.
+ Expression: sprachassi == "ja"
+ Meldungsdialog: Alle Informationen wurden nun erfasst und zur Amaad Comm Bridge gesendet. Ich werde gleich einmal prüfen ob die Einrichtung des Devices in Fhem gelungen ist. Gib mir bitte bis zu einer Minute Zeit für die Prüfung.
+ Expression: respreadingsval != "kaputt" and respreadingsval != "none"
+ Expression: sprachassi == "ja"
+ Sprachausgabe: Leider scheint es ein Problem beim einrichten des Fhem Devices gegeben zu haben. Hast Du die Amaad Comm Bridge definiert? Und ist sie auch aktiv? Sollte es weiterhin Probleme geben, wende Dich bitte an Cooltux alias Leon, im Fhem Forum.
+Soll der Assistent gelöscht werden?
+ Meldungsdialog: Leider scheint es ein Problem beim Einrichten des FHEM Devices gegeben zu haben. Hast Du die AMADCommBridge definiert, und ist sie auch aktiv? Sollte es weiterhin Probleme geben, wende Dich bitte an CoolTux alias Leon, im FHEM Forum.
+ Expression: sprachassi == "ja"
+ Sprachausgabe: Die Einrichtung ist nun abgeschlossen und das Amaad Device wurde angelegt. Es scheint aber noch keine Verbindung zwischen Fhem und Deinem Amaad Device zu bestehen. Mache am besten einmal ein Status Request in Fhem für das Amaad Device. Ist der Status in Fhem weiterhin offline schaue bitte ob alle Amaad, Flows aktiv sind.
+Soll der Assistent gelöscht werden?
+ Meldungsdialog: Die Einrichtung ist nun abgeschlossen und das Amaad Device wurde angelegt. Es scheint aber noch keine Verbindung zwischen Fhem und Deinem Amaad Device zu bestehen. Mache am besten einmal ein Status Request in Fhem für das Amaad Device. Ist der Status in Fhem weiterhin offline schaue bitte ob alle Am
+ Expression: respreadingsval == "online"
+ Sprachausgabe: Die Einrichtung ist nun abgeschlossen und das Amaad Device online.
+Soll der Assistent gelöscht werden?
+ Expression: sprachassi == "ja"
+ Meldungsdialog: Wunderbar. Bitte nimm Dir Zeit und lese Dir die Hilfe Dialoge genau durch. Wenn Du Dir unsicher bist, kannst Du die Standardeinstellung, sofern vorhanden, belassen. Lass uns nun mit der Einrichtung beginnen.
+
+
+
+
+
+
+
@@ -3545,88 +3573,249 @@ Soll der Assistent gelöscht werden?
-
-
-
-
-
-
-
-
-
-
-
+
+
+
+
+
+
+
+
+
+
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+
+
+
+
+
+
+
+
+
+
+
+
+
+
-
-
-
-
-
-
-
-
-
-
-
-
-
+
+
+
+
+
+
+
+
+
+
+
+
+
-
-
-
-
-
+
+
+
+
+
+
-
-
-
-
-
-
+
+
+
+
+
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Informations
- AMADNG Info/Control Flowset v3.9.75
- true
+ AMADNG Info/Control Flowset v3.9.76
+ falseQUEUE900
-
+ Script: daydream_state = "on"
+ Script: daydream_state = "off"
+ Script: keyguard = "unlocked"
+ Display Orientierung: Portrait
+ Script: screen_orientation = "portrait"
+ Script: screen_orientation = "landscape"
+ Script: dock_state = "docked"
+ Script: dock_state = "undocked"
+ Script: keyguardSet = "0"
+ Script: screen_orientation_mode = "manual"
+ Script: scrcount = 0
+ Script: keyguard = "locked"
+ Expression: scrcount < 5
+ Script: scrcount = scrcount + 1
+ Pause: 2s (Gerät wach halten)
+ Dock Status: Docked
+ Display automatisch drehen eingeschaltet
+ Expression: trigger == "Daydream Status: Gestartet"
+ Bluetooth eingeschaltet
+ Expression: trigger == "App Task Beendet"
+ Keyguard gesperrt
+ Expression: keyguard == "locked"
+ Expression: getAndroidSDKVersion() >= "16"
+ Script: keyguardSet = "not supported from your device"
+ Display eingeschaltet
+ Display eingeschaltet
+ Expression: getAndroidSDKVersion() >= "16"
+ Unterbrechnungen-Modus: Nur Wecker (Android 6+)
+ Unterbrechnungen-Modus: Keine / Nicht unterbrechen
+ Unterbrechnungen-Modus: Wichtig / Nur wichtige Unterbrechnungen zulassen
+ Unterbrechnungen-Modus: Alle / Immer unterbrechen
+ Script: dndValue = "always"
+ Script: dndValue = "onlyImportant"
+ Script: dndValue = "never"
+ Script: dndValue = "alarmClockOnly"
+ Script: screen_state = "on"
+ Script: screen_state = "off"
+ Script: screen_state = "on {keyguard}"
+ Script: screen_state = "off {keyguard}"
+ Script: airplanemode = "off"
+ Script: bluetooth_state = "on"
+ Script: androidVersion = "not supported funktion"
+ App Task läuft: {global_activetask} (neuster)
+ Script: runTask = "1"
+ Script: runTask = "0"
+ Expression: getAndroidSDKVersion() >= "19"
+ Script: runTask = "not supported android version"
+ Script: runTask = "null"
+ Expression: trigger == "Periodischer Timer: alle 120s"
+ Expression: global_activetask != null
+ Expression: trigger == "Display Status: Aus" or trigger == "Display Status: Ein" or udef_trigger == "setLockPin" or trigger == "HTTP Request: /fhem-amad/deviceInfo/"
+ Expression: trigger == "Daydream Status: Gestartet" or trigger == "Daydream Status: Gestoppt"
+ Expression: trigger == "Display Orientierung: Landscape" or trigger == "Display Orientierung: Portrait" or trigger == "Display Status: Ein" or trigger == "Display Status: Aus" or trigger == "HTTP Request: /fhem-amad/deviceInfo/"
+ Expression: trigger == "Akku Ladestand: grösser als 0%"
+ Stromversorgung: Angeschlossen
+ Script: screen_orientation_mode = "auto"
+ Script: bluetooth_state = "off"
+ Script: if(trigger == "Genereller Broadcast: wenn com.android.deskclock.ALARM_ALERT") { nextalarmstate = "alert" } if(trigger == "Genereller Broadcast: wenn com.android.deskclock.ALARM_DISMISS") { nextalarmstate = "dismiss" } if(trigger == "Genereller Broadcast: wenn com.android.deskclock.ALARM_DONE") { nextalarmstate = "done" } if(trigger == "Genereller Broadcast: wenn com.android.deskclock.ALARM_SNOOZE") { nextalarmstate = "snooze" }
+ Keyguard mit Sicherheit
+ Script: keyguardSet = "1"
+ Expression: udef_trigger == "setLockPin" or trigger == "HTTP Request: /fhem-amad/deviceInfo/"
+ Expression: trigger == "Eingehender Anruf. Status: Klingelt, Nummern: Alle"
+ Expression: trigger == "Flugmodus: Aus" or trigger == "HTTP Request: /fhem-amad/deviceInfo/"
+ Expression: trigger == "Systemeinstellung verändert: System screen_brightness"
+ Bluetooth Gerät verbunden: Beliebiges Geräte (Advanced Audio Distribution)
+ Script: volume = {volumeBT}
+ Pause: 2s (Gerät wach halten)
+ Musik Aktiv
+ Benachrichtigung auf Bildschirm: [AMAD2] Nicht mehr benötigte AMAD Flows wurden entfernt! (lange)
+ Expression: trigger == "Systemeinstellung verändert: System volume_music_bt_a2dp" or trigger == "Systemeinstellung verändert: System volume_music_speaker" or trigger == "Systemeinstellung verändert: System volume_music_headphone" or trigger == "Systemeinstellung verändert: System volume_music_headset"
+ Initialisiere Variable Systemeinstellung: volumeMusikBluetooth.2
+ Script: volume = {volumeSP}
+ Initialisiere Variable Systemeinstellung: volumeMusikSpeaker.2
+ Expression: trigger == "Unterbrechnungen-Modus: Alle / Immer unterbrechen" or trigger == "Unterbrechnungen-Modus: Keine / Nicht unterbrechen" or trigger == "Unterbrechnungen-Modus: Nur Wecker (Android 6+)" or trigger == "Unterbrechnungen-Modus: Wichtig / Nur wichtige Unterbrechnungen zulassen" or trigger == "HTTP Request: /fhem-amad/deviceInfo/"
+ Expression: getAndroidSDKVersion() >= "21"
+ Script: airpcount = 0
+ Host erreichbar: {global_fhemip}:{global_bridgeport}
+ WLAN Reassoziieren
+ Expression: trigger == "Genereller Broadcast: wenn com.android.deskclock.ALARM_ALERT" or trigger == "Genereller Broadcast: wenn com.android.deskclock.ALARM_DISMISS" or trigger == "Genereller Broadcast: wenn com.android.deskclock.ALARM_DONE" or trigger == "Genereller Broadcast: wenn com.android.deskclock.ALARM_SNOOZE" or trigger == "HTTP Request: /fhem-amad/deviceInfo/"
+ Expression: trigger == "Systemeinstellung verändert: System next_alarm" or trigger == "HTTP Request: /fhem-amad/deviceInfo/"
+ Initialisiere Variable Nächster Alarm: next_alarm
+ Script: next_alarmday = "{next_alarm,dateformat,c}"
+ Script: next_alarmtime = "{next_alarm,dateformat,HH:mm}"
+ Expression: global_fhemip != null or global_bridgeport != null
+ Expression: getAndroidSDKVersion() >= "19"
+ Script: notification_text = "Aktiviere Automagic unter Einstellungen -> Benachrichtigungen -> Benachrichtigungszugriff"
+ Script: notification_text = "not supported from your device"
+ Expression: getAndroidSDKVersion() >= "19"
+ Script: notification_text = "Aktiviere Automagic unter Einstellungen -> Benachrichtigungen -> Benachrichtigungszugriff"
+ Expression: trigger == "Genereller Broadcast: wenn org.smblott.intentradio.STATE"
+ Expression: trigger == "Benachrichtigung in Statusbar angezeigt: com.whatsapp"
+ Benachrichtigung in Statusbar angezeigt: WhatsApp
+ Script: notification_text = "not supported from your device"
+ Expression: trigger == "Benachrichtigung in Statusbar angezeigt: org.telegram.messenger"
+ Initialisiere Variable Systemeinstellung: screenBrightness
+ Expression: trigger == "HTTP Request: /fhem-amad/deviceInfo/"
+ Expression: trigger == "Systemeinstellung verändert: System volume_ring_speaker"
+ Initialisiere Variable Systemeinstellung: volumeNotification
+ Expression: trigger == "Systemeinstellung verändert: System volume_ring"
+ Initialisiere Variable Systemeinstellung: volumeRingSound
+ Expression: trigger == "Medien Session verändert" or trigger == "HTTP Request: /fhem-amad/deviceInfo/"
+ Get Android Version
+ WLAN verfügbar: {global_apssid}
+ Script: volumeRingSound = "\"volumeRingSound\":" + " \"" + {volumeRingSound} + "\""; fhemcmd = "setreading";
+ Script: intentRadioState = "\"intentRadioState\":" + " \"" + {irstate} + "\"" + "," + "\"intentRadioName\":" + " \"" + {irname} + "\""; fhemcmd = "setreading";
+ Script: keyguardSet = "\"keyguardSet\":" + " \"" + {keyguardSet} + "\""; fhemcmd = "setreading";
+ Script: dockingState = "\"dockingState\":" + " \"" + {dock_state} + "\""; fhemcmd = "setreading";
+ Script: screenOrientation = "\"screenOrientation\":" + " \"" + {screen_orientation} + "\"" + "," + "\"screenOrientationMode\":" + " \"" + {screen_orientation_mode} + "\""; fhemcmd = "setreading";
+ Script: screenBrightness = "\"screenBrightness\":" + " \"" + {screenBrightness} + "\""; fhemcmd = "setreading";
+ Script: daydream = "\"daydream\":" + " \"" + {daydream_state} + "\""; fhemcmd = "setreading";
+ Script: nextAlarm = "\"nextAlarmTime\":" + " \"" + {next_alarmtime} + "\"" + "," + "\"nextAlarmDay\":" + " \"" + {next_alarmday} + "\""; fhemcmd = "setreading";
+ Script: volumevalue = "\"volume\":" + " \"" + {volume} + "\""; fhemcmd = "setreading";
+ Script: volumeNotification = "\"volumeNotification\":" + " \"" + {volumeNotification} + "\""; fhemcmd = "setreading";
+ Script: airplanemode = "\"airplanemode\":" + " \"" + {airplanemode} + "\""; fhemcmd = "setreading";
+ Script: screen = "\"screen\":" + " \"" + {screen_state} + "\""; fhemcmd = "setreading";
+ Script: nextAlarmState = "\"nextAlarmState\":" + " \"" + {nextalarmstate} + "\""; fhemcmd = "setreading";
+ Script: doNotDisturb = "\"doNotDisturb\":" + " \"" + {dndValue} + "\""; fhemcmd = "setreading";
+ Script: checkActiveTask = "\"checkActiveTask\":" + " \"" + {runTask} + "\""; fhemcmd = "setreading";
+ Expression: Leon == "Gaultier"
+ Flows löschen: MultimediaControl
+ Script: androidVersion = "\"androidVersion\":" + " \"" + {androidVersion} + "\""; fhemcmd = "setreading";
+ Script: powerinfo = "\"powerLevel\":" + " \"" + "{battery_percentage,numberformat,0}" + "\"" + "," + "\"powerPlugged\":" + " \"" + {battery_plugged} + "\"" + "," + "\"batteryTemperature\":" + " \"" + "{battery_temperature/10.0,numberformat.0.0}" + "\"" + "," + "\"batteryHealth\":" + " \"" + {battery_health} + "\""; fhemcmd = "setreading";
+ Expression: trigger == "Benachrichtigung in Statusbar angezeigt: ch.gridvision.ppam.androidautomagic" or trigger == "Benachrichtigung in Statusbar entfernt: ch.gridvision.ppam.androidautomagic" or trigger == "HTTP Request: /fhem-amad/deviceInfo/"
+ Expression: getAndroidSDKVersion() >= "19"
+ Script: notification_text = "Aktiviere Automagic unter Einstellungen -> Benachrichtigungen -> Benachrichtigungszugriff"
+ Benachrichtigung in Statusbar angezeigt: Automagic
+ Expression: package_name == {global_activetask}
+ Script: deviceState = "\"deviceState\": \"online\""; fhemcmd = "setreading";
+ Expression: trigger == "Dock Event: Docked" or trigger == "Dock Event: Undocked" or trigger == "HTTP Request: /fhem-amad/deviceInfo/"
+ Expression: trigger == "Periodischer Timer: alle 120s" or trigger == "HTTP Request: /fhem-amad/deviceInfo/"
+ Flows ausführen: Send Data to AMADCommBridge
+ Prüfe und setze globale Variable
+ Script: bluetooth = "\"bluetooth\":" + " \"" + {bluetooth_state} + "\""; fhemcmd = "setreading";
+ Script: connected_devices_names = "none"; connected_devices_addresses = "none"
+ Script: btdeviceinfo = "\"connectedBTdevices\":" + " \"" + {connected_devices_names} + "\"" + "," + "\"connectedBTdevicesMAC\":" + " \"" + {connected_devices_addresses} + "\""; fhemcmd = "setreading";
+ Bluetooth Gerät verbunden: Beliebiges Geräte
+ Expression: trigger == "Bluetooth Status: Schaltet aus, Aus" or trigger == "Bluetooth Gerät verbunden: Alle Geräte" or trigger == "Bluetooth Gerät getrennt: Alle Geräte" or trigger == "Bluetooth Status: Schaltet ein, Ein" or trigger == "HTTP Request: /fhem-amad/deviceInfo/"
+ Host erreichbar: {global_fhemip}:{global_bridgeport}
+ Script: flow_SetCommands = "\"flow_SetCommands\":" + " \"" + {setCommandFlow_state} + "\""; fhemcmd = "setreading";
+ Setze Flow Status: Aktivieren SetCommands
+ Script: setCommandFlow_state = "aktiv"
+ Script: setCommandFlow_state = "inaktiv"
+ Flow Aktiv: SetCommands
+ Expression: trigger == "Periodischer Timer: alle 120s"
+ Expression: global_userflowstate != "none"
+ Flow Aktiv: {global_userflowstate}
+ Script: flowState = "inactive"
+ Script: flowState = "active"
+ Script: flow_informations = "\"userFlowState\":" + " \"" + {flowState} + "\""; fhemcmd = "setreading";
+ Expression: trigger == "Periodischer Timer: alle 120s" or trigger == "HTTP Request: /fhem-amad/deviceInfo/"
+ Flow Aktiv: Send Data to AMADCommBridge
+ Setze Flow Status: Aktivieren Send Data to AMADCommBridge
+ Expression: trigger == "Periodischer Timer: alle 120s"
+ Script: incomingCaller = "\"incomingCallerName\":" + " \"" + {contact_name} + "\"" + "," + "\"incomingCallerNumber\":" + " \"" + {incoming_number} + "\""; fhemcmd = "setreading";
+ Script: incommingWhatsAppMessage = "\"incommingWhatsAppMessageFrom\":" + " \"" + replaceAll({notification_text}, "\\n", " ") + "\""; fhemcmd = "setreading";
+ Script: automagicState = "\"automagicState\":" + " \"" + replaceAll({notification_text}, "\\n", " ") + "\""; fhemcmd = "setreading";
+ Script: incommingTelegramMessage = "\"incommingTelegramMessageFrom\":" + " \"" + replaceAll({notification_text}, "\\n", " ") + "\""; fhemcmd = "setreading";
+ Benachrichtigung in Statusbar angezeigt: Telegram Messenger
+ Pause: 2s (Gerät wach halten)
+ Script: airpcount = airpcount + 1
+ Expression: airpcount < 11
+ Script: notification_text = "not supported from your device"
+ Genereller Broadcast: wenn com.android.deskclock.ALARM_DONEGenereller Broadcast: wenn org.smblott.intentradio.STATESystemeinstellung verändert: System volume_music_headphone
@@ -3640,7 +3829,6 @@ Soll der Assistent gelöscht werden?
Bluetooth Status: Schaltet aus, AusUnterbrechnungen-Modus: Wichtig / Nur wichtige Unterbrechnungen zulassenBenachrichtigung in Statusbar angezeigt: com.whatsapp
- Medien Session verändertDaydream Status: GestopptBenachrichtigung in Statusbar angezeigt: ch.gridvision.ppam.androidautomagicEingehender Anruf. Status: Klingelt, Nummern: Alle
@@ -3669,415 +3857,254 @@ Soll der Assistent gelöscht werden?
Systemeinstellung verändert: System volume_ringFlugmodus: AusSystemeinstellung verändert: System volume_ring_speaker
+ Medien Session verändert
- Script: daydream_state = "on"
- Script: daydream_state = "off"
- Script: keyguard = "unlocked"
- Display Orientierung: Portrait
- Script: screen_orientation = "portrait"
- Script: screen_orientation = "landscape"
- Script: dock_state = "docked"
- Script: dock_state = "undocked"
- Script: keyguardSet = "0"
- Script: screen_orientation_mode = "manual"
- Script: scrcount = 0
- Script: keyguard = "locked"
- Expression: scrcount < 5
- Script: scrcount = scrcount + 1
- Pause: 2s (Gerät wach halten)
- Dock Status: Docked
- Display automatisch drehen eingeschaltet
- Expression: trigger == "Daydream Status: Gestartet"
- Bluetooth eingeschaltet
- Expression: trigger == "App Task Beendet"
- Keyguard gesperrt
- Expression: keyguard == "locked"
- Expression: getAndroidSDKVersion() >= "16"
- Script: keyguardSet = "not supported from your device"
- Display eingeschaltet
- Display eingeschaltet
- Expression: getAndroidSDKVersion() >= "16"
- Unterbrechnungen-Modus: Nur Wecker (Android 6+)
- Unterbrechnungen-Modus: Keine / Nicht unterbrechen
- Unterbrechnungen-Modus: Wichtig / Nur wichtige Unterbrechnungen zulassen
- Unterbrechnungen-Modus: Alle / Immer unterbrechen
- Script: dndValue = "always"
- Script: dndValue = "onlyImportant"
- Script: dndValue = "never"
- Script: dndValue = "alarmClockOnly"
- Script: screen_state = "on"
- Script: screen_state = "off"
- Script: screen_state = "on {keyguard}"
- Script: screen_state = "off {keyguard}"
- Script: airplanemode = "off"
- Script: bluetooth_state = "on"
- Script: androidVersion = "not supported funktion"
- App Task läuft: {global_activetask} (neuster)
- Script: runTask = "1"
- Script: runTask = "0"
- Expression: getAndroidSDKVersion() >= "19"
- Script: runTask = "not supported android version"
- Script: runTask = "null"
- Expression: trigger == "Periodischer Timer: alle 120s"
- Expression: global_activetask != null
- Expression: trigger == "Display Status: Aus" or trigger == "Display Status: Ein" or udef_trigger == "setLockPin" or trigger == "HTTP Request: /fhem-amad/deviceInfo/"
- Expression: trigger == "Daydream Status: Gestartet" or trigger == "Daydream Status: Gestoppt"
- Expression: trigger == "Display Orientierung: Landscape" or trigger == "Display Orientierung: Portrait" or trigger == "Display Status: Ein" or trigger == "Display Status: Aus" or trigger == "HTTP Request: /fhem-amad/deviceInfo/"
- Expression: trigger == "Akku Ladestand: grösser als 0%"
- Stromversorgung: Angeschlossen
- Script: screen_orientation_mode = "auto"
- Script: bluetooth_state = "off"
- Script: if(trigger == "Genereller Broadcast: wenn com.android.deskclock.ALARM_ALERT") { nextalarmstate = "alert" } if(trigger == "Genereller Broadcast: wenn com.android.deskclock.ALARM_DISMISS") { nextalarmstate = "dismiss" } if(trigger == "Genereller Broadcast: wenn com.android.deskclock.ALARM_DONE") { nextalarmstate = "done" } if(trigger == "Genereller Broadcast: wenn com.android.deskclock.ALARM_SNOOZE") { nextalarmstate = "snooze" }
- Keyguard mit Sicherheit
- Script: keyguardSet = "1"
- Expression: udef_trigger == "setLockPin" or trigger == "HTTP Request: /fhem-amad/deviceInfo/"
- Expression: trigger == "Eingehender Anruf. Status: Klingelt, Nummern: Alle"
- Expression: trigger == "Flugmodus: Aus" or trigger == "HTTP Request: /fhem-amad/deviceInfo/"
- Expression: trigger == "Systemeinstellung verändert: System screen_brightness"
- Bluetooth Gerät verbunden: Beliebiges Geräte (Advanced Audio Distribution)
- Script: volume = {volumeBT}
- Pause: 2s (Gerät wach halten)
- Musik Aktiv
- Benachrichtigung auf Bildschirm: [AMAD2] Nicht mehr benötigte AMAD Flows wurden entfernt! (lange)
- Expression: trigger == "Systemeinstellung verändert: System volume_music_bt_a2dp" or trigger == "Systemeinstellung verändert: System volume_music_speaker" or trigger == "Systemeinstellung verändert: System volume_music_headphone" or trigger == "Systemeinstellung verändert: System volume_music_headset"
- Initialisiere Variable Systemeinstellung: volumeMusikBluetooth.2
- Script: volume = {volumeSP}
- Initialisiere Variable Systemeinstellung: volumeMusikSpeaker.2
- Expression: trigger == "Unterbrechnungen-Modus: Alle / Immer unterbrechen" or trigger == "Unterbrechnungen-Modus: Keine / Nicht unterbrechen" or trigger == "Unterbrechnungen-Modus: Nur Wecker (Android 6+)" or trigger == "Unterbrechnungen-Modus: Wichtig / Nur wichtige Unterbrechnungen zulassen" or trigger == "HTTP Request: /fhem-amad/deviceInfo/"
- Expression: getAndroidSDKVersion() >= "21"
- Script: airpcount = 0
- Host erreichbar: {global_fhemip}:{global_bridgeport}
- WLAN Reassoziieren
- Expression: trigger == "Genereller Broadcast: wenn com.android.deskclock.ALARM_ALERT" or trigger == "Genereller Broadcast: wenn com.android.deskclock.ALARM_DISMISS" or trigger == "Genereller Broadcast: wenn com.android.deskclock.ALARM_DONE" or trigger == "Genereller Broadcast: wenn com.android.deskclock.ALARM_SNOOZE" or trigger == "HTTP Request: /fhem-amad/deviceInfo/"
- Expression: trigger == "Systemeinstellung verändert: System next_alarm" or trigger == "HTTP Request: /fhem-amad/deviceInfo/"
- Initialisiere Variable Nächster Alarm: next_alarm
- Script: next_alarmday = "{next_alarm,dateformat,c}"
- Script: next_alarmtime = "{next_alarm,dateformat,HH:mm}"
- Expression: global_fhemip != null or global_bridgeport != null
- Expression: getAndroidSDKVersion() >= "19"
- Script: notification_text = "Aktiviere Automagic unter Einstellungen -> Benachrichtigungen -> Benachrichtigungszugriff"
- Script: notification_text = "not supported from your device"
- Expression: getAndroidSDKVersion() >= "19"
- Script: notification_text = "Aktiviere Automagic unter Einstellungen -> Benachrichtigungen -> Benachrichtigungszugriff"
- Expression: trigger == "Genereller Broadcast: wenn org.smblott.intentradio.STATE"
- Expression: trigger == "Benachrichtigung in Statusbar angezeigt: com.whatsapp"
- Benachrichtigung in Statusbar angezeigt: WhatsApp
- Script: notification_text = "not supported from your device"
- Expression: trigger == "Benachrichtigung in Statusbar angezeigt: org.telegram.messenger"
- Initialisiere Variable Systemeinstellung: screenBrightness
- Expression: trigger == "HTTP Request: /fhem-amad/deviceInfo/"
- Expression: trigger == "Systemeinstellung verändert: System volume_ring_speaker"
- Initialisiere Variable Systemeinstellung: volumeNotification
- Expression: trigger == "Systemeinstellung verändert: System volume_ring"
- Initialisiere Variable Systemeinstellung: volumeRingSound
- Script: subtitle = "no player active"; title = "no player active"; description = "no player active"; musicapp = "no player active"; icon = "no player active"
- Script: if(playback_state == 0) { playback_state = "keiner" } if(playback_state == 1) { playback_state = "gestoppt" } if(playback_state == 2) { playback_state = "pausiert" } if(playback_state == 3) { playback_state = "spielt ab" } if(playback_state == 4) { playback_state = "spult vorwärts" } if(playback_state == 5) { playback_state = "spült rückwärts" } if(playback_state == 6) { playback_state = "buffert" } if(playback_state == 7) { playback_state = "Fehler" } if(playback_state == 8) { playback_state = "verbindet" } if(playback_state == 9) { playback_state = "springt zum vorherigen" } if(playback_state == 10) { playback_state = "springt zum nächsten" } if(playback_state == 11) { playback_state = "springt zu Position in Wiedergabeliste" }
- Expression: trigger == "Medien Session verändert" or trigger == "HTTP Request: /fhem-amad/deviceInfo/"
- Script: if(package_name == "com.google.android.music") { musicapp = "Google Musik" } if(package_name == "com.amazon.mp3") { musicapp = "Amazon Musik" } if(package_name == "com.google.android.videos") { musicapp = "Google Video" } if(package_name == "com.spotify.music") { musicapp = "Spotify Musik" } if(package_name == "com.google.android.youtube") { musicapp = "YouTube" } if(package_name == "tunein.player") { musicapp = "TuneIn Player" } if(package_name == "com.rhapsody.alditalk") { musicapp = "Aldi Life Musik" } if(package_name == "org.videolan.vlc") { musicapp = "VLC Player" }
- Get Android Version
- WLAN verfügbar: {global_apssid}
- Script: volumeRingSound = "\"volumeRingSound\":" + " \"" + {volumeRingSound} + "\""; fhemcmd = "setreading";
- Script: intentRadioState = "\"intentRadioState\":" + " \"" + {irstate} + "\"" + "," + "\"intentRadioName\":" + " \"" + {irname} + "\""; fhemcmd = "setreading";
- Script: keyguardSet = "\"keyguardSet\":" + " \"" + {keyguardSet} + "\""; fhemcmd = "setreading";
- Script: dockingState = "\"dockingState\":" + " \"" + {dock_state} + "\""; fhemcmd = "setreading";
- Script: screenOrientation = "\"screenOrientation\":" + " \"" + {screen_orientation} + "\"" + "," + "\"screenOrientationMode\":" + " \"" + {screen_orientation_mode} + "\""; fhemcmd = "setreading";
- Script: screenBrightness = "\"screenBrightness\":" + " \"" + {screenBrightness} + "\""; fhemcmd = "setreading";
- Script: daydream = "\"daydream\":" + " \"" + {daydream_state} + "\""; fhemcmd = "setreading";
- Script: nextAlarm = "\"nextAlarmTime\":" + " \"" + {next_alarmtime} + "\"" + "," + "\"nextAlarmDay\":" + " \"" + {next_alarmday} + "\""; fhemcmd = "setreading";
- Script: volumevalue = "\"volume\":" + " \"" + {volume} + "\""; fhemcmd = "setreading";
- Script: volumeNotification = "\"volumeNotification\":" + " \"" + {volumeNotification} + "\""; fhemcmd = "setreading";
- Script: airplanemode = "\"airplanemode\":" + " \"" + {airplanemode} + "\""; fhemcmd = "setreading";
- Script: screen = "\"screen\":" + " \"" + {screen_state} + "\""; fhemcmd = "setreading";
- Script: nextAlarmState = "\"nextAlarmState\":" + " \"" + {nextalarmstate} + "\""; fhemcmd = "setreading";
- Script: doNotDisturb = "\"doNotDisturb\":" + " \"" + {dndValue} + "\""; fhemcmd = "setreading";
- Script: checkActiveTask = "\"checkActiveTask\":" + " \"" + {runTask} + "\""; fhemcmd = "setreading";
- Expression: Leon == "Gaultier"
- Flows löschen: MultimediaControl
- Script: androidVersion = "\"androidVersion\":" + " \"" + {androidVersion} + "\""; fhemcmd = "setreading";
- Script: powerinfo = "\"powerLevel\":" + " \"" + "{battery_percentage,numberformat,0}" + "\"" + "," + "\"powerPlugged\":" + " \"" + {battery_plugged} + "\"" + "," + "\"batteryTemperature\":" + " \"" + "{battery_temperature/10.0,numberformat.0.0}" + "\"" + "," + "\"batteryHealth\":" + " \"" + {battery_health} + "\""; fhemcmd = "setreading";
- Script: currentMusic = "\"currentMusicTrack\":" + " \"" + {title} + "\"" + "," + "\"currentMusicAlbum\":" + " \"" + {description} + "\"" + "," + "\"currentMusicArtist\":" + " \"" + {subtitle} + "\"" + "," + "\"currentMusicApp\":" + " \"" + {musicapp} + "\"" + "," + "\"currentMusicIcon\":" + " \"" + {icon} + "\"" + "," + "\"currentMusicState\":" + " \"" + {playback_state} + "\""; fhemcmd = "setreading";
- Expression: trigger == "Benachrichtigung in Statusbar angezeigt: ch.gridvision.ppam.androidautomagic" or trigger == "Benachrichtigung in Statusbar entfernt: ch.gridvision.ppam.androidautomagic" or trigger == "HTTP Request: /fhem-amad/deviceInfo/"
- Expression: getAndroidSDKVersion() >= "19"
- Script: notification_text = "Aktiviere Automagic unter Einstellungen -> Benachrichtigungen -> Benachrichtigungszugriff"
- Benachrichtigung in Statusbar angezeigt: Automagic
- Script: notification_text = "not supported from your device"
- Expression: package_name == {global_activetask}
- Script: deviceState = "\"deviceState\": \"online\""; fhemcmd = "setreading";
- Expression: trigger == "Dock Event: Docked" or trigger == "Dock Event: Undocked" or trigger == "HTTP Request: /fhem-amad/deviceInfo/"
- Expression: trigger == "Periodischer Timer: alle 120s" or trigger == "HTTP Request: /fhem-amad/deviceInfo/"
- Flows ausführen: Send Data to AMADCommBridge
- Prüfe und setze globale Variable
- Script: bluetooth = "\"bluetooth\":" + " \"" + {bluetooth_state} + "\""; fhemcmd = "setreading";
- Script: connected_devices_names = "none"; connected_devices_addresses = "none"
- Script: btdeviceinfo = "\"connectedBTdevices\":" + " \"" + {connected_devices_names} + "\"" + "," + "\"connectedBTdevicesMAC\":" + " \"" + {connected_devices_addresses} + "\""; fhemcmd = "setreading";
- Bluetooth Gerät verbunden: Beliebiges Geräte
- Expression: trigger == "Bluetooth Status: Schaltet aus, Aus" or trigger == "Bluetooth Gerät verbunden: Alle Geräte" or trigger == "Bluetooth Gerät getrennt: Alle Geräte" or trigger == "Bluetooth Status: Schaltet ein, Ein" or trigger == "HTTP Request: /fhem-amad/deviceInfo/"
- Host erreichbar: {global_fhemip}:{global_bridgeport}
- Script: flow_SetCommands = "\"flow_SetCommands\":" + " \"" + {setCommandFlow_state} + "\""; fhemcmd = "setreading";
- Setze Flow Status: Aktivieren SetCommands
- Script: setCommandFlow_state = "aktiv"
- Script: setCommandFlow_state = "inaktiv"
- Flow Aktiv: SetCommands
- Expression: trigger == "Periodischer Timer: alle 120s"
- Expression: global_userflowstate != "none"
- Flow Aktiv: {global_userflowstate}
- Script: flowState = "inactive"
- Script: flowState = "active"
- Script: flow_informations = "\"userFlowState\":" + " \"" + {flowState} + "\""; fhemcmd = "setreading";
- Expression: trigger == "Periodischer Timer: alle 120s" or trigger == "HTTP Request: /fhem-amad/deviceInfo/"
- Flow Aktiv: Send Data to AMADCommBridge
- Setze Flow Status: Aktivieren Send Data to AMADCommBridge
- Expression: trigger == "Periodischer Timer: alle 120s"
- Script: incomingCaller = "\"incomingCallerName\":" + " \"" + {contact_name} + "\"" + "," + "\"incomingCallerNumber\":" + " \"" + {incoming_number} + "\""; fhemcmd = "setreading";
- Script: incommingWhatsAppMessage = "\"incommingWhatsAppMessageFrom\":" + " \"" + replaceAll({notification_text}, "\\n", " ") + "\""; fhemcmd = "setreading";
- Script: automagicState = "\"automagicState\":" + " \"" + replaceAll({notification_text}, "\\n", " ") + "\""; fhemcmd = "setreading";
- Script: incommingTelegramMessage = "\"incommingTelegramMessageFrom\":" + " \"" + replaceAll({notification_text}, "\\n", " ") + "\""; fhemcmd = "setreading";
- Benachrichtigung in Statusbar angezeigt: Telegram Messenger
- Pause: 2s (Gerät wach halten)
- Script: airpcount = airpcount + 1
- Expression: airpcount < 11
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+ Script: subtitle = "no player active"; title = "no player active"; description = "no player active"; musicapp = "no player active"; icon = "no player active"
+ Script: if(playback_state == 0) { playback_state = "keiner" } if(playback_state == 1) { playback_state = "gestoppt" } if(playback_state == 2) { playback_state = "pausiert" } if(playback_state == 3) { playback_state = "spielt ab" } if(playback_state == 4) { playback_state = "spult vorwärts" } if(playback_state == 5) { playback_state = "spült rückwärts" } if(playback_state == 6) { playback_state = "buffert" } if(playback_state == 7) { playback_state = "Fehler" } if(playback_state == 8) { playback_state = "verbindet" } if(playback_state == 9) { playback_state = "springt zum vorherigen" } if(playback_state == 10) { playback_state = "springt zum nächsten" } if(playback_state == 11) { playback_state = "springt zu Position in Wiedergabeliste" }
+ Script: currentMusic = "\"currentMusicTrack\":" + " \"" + {title} + "\"" + "," + "\"currentMusicAlbum\":" + " \"" + {description} + "\"" + "," + "\"currentMusicArtist\":" + " \"" + {subtitle} + "\"" + "," + "\"currentMusicApp\":" + " \"" + {musicapp} + "\"" + "," + "\"currentMusicIcon\":" + " \"" + {icon} + "\"" + "," + "\"currentMusicState\":" + " \"" + {playback_state} + "\""; fhemcmd = "setreading";
+ Script: if(package_name == "com.google.android.music") { musicapp = "Google Musik" } if(package_name == "com.amazon.mp3") { musicapp = "Amazon Musik" } if(package_name == "com.google.android.videos") { musicapp = "Google Video" } if(package_name == "com.spotify.music") { musicapp = "Spotify Musik" } if(package_name == "com.google.android.youtube") { musicapp = "YouTube" } if(package_name == "tunein.player") { musicapp = "TuneIn Player" } if(package_name == "com.rhapsody.alditalk") { musicapp = "Aldi Life Musik" } if(package_name == "org.videolan.vlc") { musicapp = "VLC Player" } if(package_name == "com.sec.android.app.music") { musicapp = "Samsung Music Player" }
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Send Data to AMADCommBridge
- AMADNG Info/Control Flowset v3.9.75
+ AMADNG Info/Control Flowset v3.9.76truePARALLEL900
@@ -4112,8 +4139,8 @@ Soll der Assistent gelöscht werden?
HTTP Request: send SET data to AMADCommBridge JSONHTTP Request: send READINGSVAL data to AMADCommBridge JSONHTTP Request: send VOICEINPUTVALUE data to AMADCommBridge
- Script: Set FHEMDATA JSON
- Script: if(togocount > 0) { togocount = togocount + 1; } else { togocount = 0; togocount = togocount + 1; }
+ Script: if(togocount > 0) { togocount = togocount + 1; } else { togocount = 0; togocount = togocount + 1; }
+ Script: Set FHEMDATA JSON
@@ -4122,7 +4149,7 @@ Soll der Assistent gelöscht werden?
-
+
@@ -4135,18 +4162,18 @@ Soll der Assistent gelöscht werden?
-
+
-
-
+
+ SetCommands
- AMADNG Info/Control Flowset v3.9.75
- true
+ AMADNG Info/Control Flowset v3.9.76
+ falseQUEUE900
@@ -4286,38 +4313,38 @@ Soll der Assistent gelöscht werden?
Script: notification_text = "Flow '{param_flowname}' has been set {param_flowstate}"Expression: flowState"Expression: closeCall"
- Audio Player steuern: Medienknopf Stopp ({pname}/{kname})
- Expression: multimediaControl"
- Starte Daydream
- Expression: startDaydream"
- Lautstärken setzen param_volume
- Expression: setNotifiVolume"
- Lautstärken setzen param_notifivolume
- Expression: trigger == "HTTP Request: /fhem-amad/setCommands/*"
- Expression: setRingSoundVolume"
- Lautstärken setzen param_ringsoundvolume
- Expression: param_button == "play/pause"
- Audio Player steuern: Medienknopf Play/Pause (/{kname})
- Script: Zuordnung Mediaplayer
- Sound: {param_notifypath}{param_notifyfile} als Benachrichtigung
- Gerätespeicherplatz: Freier Speicherplatz > 1kb (/storage/emulated/0)
- Download URL: http://{global_fhemip}:{global_bridgeport}/installFlow_{param_flowname} to /storage/emulated/0/Download
- Script: flow_informations = "\"flow_informations\":" + " \"" + {informationFlow_state} + "\""; fhemcmd = "setreading";
- Script: automagicState = "\"automagicState\":" + " \"" + replaceAll({notification_text}, "\\n", " ") + "\""; fhemcmd = "setreading";
- Script: automagicState = "\"automagicState\":" + " \"" + replaceAll({notification_text}, "\\n", " ") + "\""; fhemcmd = "setreading";
- Flows ausführen: Send Data to AMADCommBridge
- Sprachausgabe: Englisch
- Sprachausgabe: Deutsch
- Flows ausführen: VoiceControl
- Flows ausführen: udef_trigger setLockPin
- Setze Flow Status: Aktivieren {param_flowname}
- Flow Aktiv: Informations
- Script: informationFlow_state = "aktiv"
- Script: informationFlow_state = "inaktiv"
- Setze Flow Status: Aktivieren Informations
- Host erreichbar: {global_fhemip}:{global_bridgeport}
- Flow Aktiv: Send Data to AMADCommBridge
- Setze Flow Status: Aktivieren Send Data to AMADCommBridge
+ Expression: multimediaControl"
+ Starte Daydream
+ Expression: startDaydream"
+ Lautstärken setzen param_volume
+ Expression: setNotifiVolume"
+ Lautstärken setzen param_notifivolume
+ Expression: trigger == "HTTP Request: /fhem-amad/setCommands/*"
+ Expression: setRingSoundVolume"
+ Lautstärken setzen param_ringsoundvolume
+ Expression: param_button == "play/pause"
+ Audio Player steuern: Medienknopf Play/Pause (/{kname})
+ Sound: {param_notifypath}{param_notifyfile} als Benachrichtigung
+ Gerätespeicherplatz: Freier Speicherplatz > 1kb (/storage/emulated/0)
+ Download URL: http://{global_fhemip}:{global_bridgeport}/installFlow_{param_flowname} to /storage/emulated/0/Download
+ Script: flow_informations = "\"flow_informations\":" + " \"" + {informationFlow_state} + "\""; fhemcmd = "setreading";
+ Script: automagicState = "\"automagicState\":" + " \"" + replaceAll({notification_text}, "\\n", " ") + "\""; fhemcmd = "setreading";
+ Script: automagicState = "\"automagicState\":" + " \"" + replaceAll({notification_text}, "\\n", " ") + "\""; fhemcmd = "setreading";
+ Flows ausführen: Send Data to AMADCommBridge
+ Sprachausgabe: Englisch
+ Sprachausgabe: Deutsch
+ Flows ausführen: VoiceControl
+ Flows ausführen: udef_trigger setLockPin
+ Setze Flow Status: Aktivieren {param_flowname}
+ Flow Aktiv: Informations
+ Script: informationFlow_state = "aktiv"
+ Script: informationFlow_state = "inaktiv"
+ Setze Flow Status: Aktivieren Informations
+ Host erreichbar: {global_fhemip}:{global_bridgeport}
+ Flow Aktiv: Send Data to AMADCommBridge
+ Setze Flow Status: Aktivieren Send Data to AMADCommBridge
+ Audio Player steuern: Medienknopf Stopp ({pname}/{kname})
+ Script: Zuordnung Mediaplayer
@@ -4347,18 +4374,18 @@ Soll der Assistent gelöscht werden?
-
+
-
+
-
+
@@ -4384,8 +4411,8 @@ Soll der Assistent gelöscht werden?
-
-
+
+
@@ -4399,7 +4426,7 @@ Soll der Assistent gelöscht werden?
-
+
@@ -4411,94 +4438,94 @@ Soll der Assistent gelöscht werden?
-
+
-
+
-
+
-
-
-
+
+
+
-
+
-
+
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Update AMAD Flowset
- AMADNG Info/Control Flowset v3.9.75
+ AMADNG Info/Control Flowset v3.9.76trueQUEUE
@@ -4554,7 +4581,7 @@ Soll der Assistent gelöscht werden?
VoiceControl
- AMADNG Info/Control Flowset v3.9.75
+ AMADNG Info/Control Flowset v3.9.76trueQUEUE
From 222379d54e3defd3479d56996f77208e5e344b97 Mon Sep 17 00:00:00 2001
From: Marko Oldenburg
Date: Mon, 3 Jul 2017 18:37:22 +0200
Subject: [PATCH 24/32] fix Umlaute Problem bei voiceInput
---
73_AMADCommBridge.pm | 382 ++++++-------------------------------------
74_AMADDevice.pm | 4 +-
2 files changed, 50 insertions(+), 336 deletions(-)
diff --git a/73_AMADCommBridge.pm b/73_AMADCommBridge.pm
index b947e46..54ff1eb 100644
--- a/73_AMADCommBridge.pm
+++ b/73_AMADCommBridge.pm
@@ -65,10 +65,12 @@ use warnings;
use HttpUtils;
use TcpServerUtils;
+
+eval "use Encode qw(encode encode_utf8);1" or $missingModul .= "Encode ";
eval "use JSON;1" or $missingModul .= "JSON ";
-my $modulversion = "3.9.75";
+my $modulversion = "3.9.77";
my $flowsetversion = "3.9.76";
@@ -713,11 +715,9 @@ sub AMADCommBridge_ResponseProcessing($$) {
my $response;
my $c;
- my $decode_json;
-
- $decode_json = eval{decode_json($json)};
-
+
+ my $decode_json = eval{decode_json($json)};
if($@){
Log3 $bname, 4, "AMADCommBridge ($name) - ERROR while request: $@";
@@ -811,7 +811,7 @@ sub AMADCommBridge_ResponseProcessing($$) {
}
elsif ( $fhemcmd eq 'voiceinputvalue' ) {
- my $fhemCmd = lc($decode_json->{payload}{voiceinputdata});
+ my $fhemCmd = lc(encode_utf8($decode_json->{payload}{voiceinputdata}));
readingsBeginUpdate( $bhash);
readingsBulkUpdate( $bhash, "receiveVoiceCommand", $fhemCmd, 1 );
@@ -971,175 +971,7 @@ sub AMADCommBridge_ParseMsg($$) {
AMADCommBridge
-
- AMAD - Automagic Android Device
-
- This module integrates Android devices into FHEM and displays several settings using the Android app "Automagic".
- Automagic is comparable to the "Tasker" app for automating tasks and configuration settings. But Automagic is more user-friendly. The "Automagic Premium" app currently costs EUR 2.90.
-
- Any information retrievable by Automagic can be displayed in FHEM by this module. Just define your own Automagic-"flow" and send the data to the AMADCommBridge. One even can control several actions on Android devices.
-
- To be able to make use of all these functions the Automagic app and additional flows need to be installed on the Android device. The flows can be retrieved from the FHEM directory, the app can be bought in Google Play Store.
-
- How to use AMAD?
-
-
install the "Automagic Premium" app from the Google Play store.
-
install the flowset 74_AMADautomagicFlowset$VERSION.xml from the directory $INSTALLFHEM/FHEM/lib/ on your Android device and activate.
-
-
- Now you need to define a device in FHEM.
-
-
- Define
-
- define <name> AMAD <IP-ADDRESS>
-
- Example:
-
- define WandTabletWohnzimmer AMAD 192.168.0.23
-
-
- With this command two new AMAD devices in a room called AMAD are created. The parameter <IP-ADDRESS< defines the IP address of your Android device. The second device created is the AMADCommBridge which serves as a communication device from each Android device to FHEM.
- !!!Coming Soon!!! The communication port of each AMAD device may be set by the definition of the "port" attribute. One needs background knowledge of Automagic and HTTP requests as this port will be set in the HTTP request trigger of both flows, therefore the port also needs to be set there.
-
- The communication port of the AMADCommBridge device can easily be changed within the attribut "port".
-
-
- AMAD Communication Bridge
-
- Creating your first AMAD device automatically creates the AMADCommBridge device in the room AMAD. With the help of the AMADCommBridge any Android device communicates initially to FHEM.To make the IP addresse of the FHEM server known to the Android device, the FHEM server IP address needs to be configured in the AMADCommBridge. WITHOUT THIS STEP THE AMADCommBridge WILL NOT WORK PROPERLY.
- Please us the following command for configuration of the FHEM server IP address in the AMADCommBridge: set AMADCommBridge fhemServerIP <FHEM-IP>.
- Additionally the expertMode may be configured. By this setting a direct communication with FHEM will be established without the restriction of needing to make use of a notify to execute set commands.
-
-
- You are finished now! After 15 seconds latest the readings of your AMAD Android device should be updated. Consequently each 15 seconds a status request will be sent. If the state of your AMAD Android device does not change to "active" over a longer period of time one should take a look into the log file for error messages.
-
-
- Readings
-
-
airplanemode - on/off, state of the aeroplane mode
-
androidVersion - currently installed version of Android
-
automagicState - state of the Automagic App (prerequisite Android >4.3). In case you have Android >4.3 and the reading says "not supported", you need to enable Automagic inside Android / Settings / Sound & notification / Notification access
-
batteryHealth - the health of the battery (1=unknown, 2=good, 3=overheat, 4=dead, 5=over voltage, 6=unspecified failure, 7=cold)
-
batterytemperature - the temperature of the battery
-
bluetooth - on/off, bluetooth state
-
checkActiveTask - state of an app (needs to be defined beforehand). 0=not active or not active in foreground, 1=active in foreground, see note below
-
connectedBTdevices - list of all devices connected via bluetooth
-
connectedBTdevicesMAC - list of MAC addresses of all devices connected via bluetooth
-
currentMusicAlbum - currently playing album of mediaplayer
-
currentMusicApp - currently playing player app (Amazon Music, Google Play Music, Google Play Video, Spotify, YouTube, TuneIn Player, Aldi Life Music)
-
currentMusicArtist - currently playing artist of mediaplayer
-
currentMusicIcon - cover of currently play albumNoch nicht fertig implementiert
-
currentMusicState - state of currently/last used mediaplayer
-
currentMusicTrack - currently playing song title of mediaplayer
-
daydream - on/off, daydream currently active
-
deviceState - state of Android devices. unknown, online, offline.
-
doNotDisturb - state of do not Disturb Mode
-
dockingState - undocked/docked, Android device in docking station
-
flow_SetCommands - active/inactive, state of SetCommands flow
-
flow_informations - active/inactive, state of Informations flow
-
flowsetVersionAtDevice - currently installed version of the flowsets on the Android device
-
incomingCallerName - Callername from last Call
-
incomingCallerNumber - Callernumber from last Call
-
incommingWhatsAppMessageFrom - last WhatsApp message
-
incommingWhatsTelegramMessageFrom - last telegram message
-
intentRadioName - name of the most-recent streamed intent radio
-
intentRadioState - state of intent radio player
-
keyguardSet - 0/1 keyguard set, 0=no 1=yes, does not indicate whether it is currently active
-
lastSetCommandError - last error message of a set command
-
lastSetCommandState - last state of a set command, command send successful/command send unsuccessful
-
lastStatusRequestError - last error message of a statusRequest command
-
lastStatusRequestState - ast state of a statusRequest command, command send successful/command send unsuccessful
-
nextAlarmDay - currently set day of alarm
-
nextAlarmState - alert/done, current state of "Clock" stock-app
-
nextAlarmTime - currently set time of alarm
-
powerLevel - state of battery in %
-
powerPlugged - 0=no/1,2=yes, power supply connected
-
screen - on locked,unlocked/off locked,unlocked, state of display
-
screenBrightness - 0-255, level of screen-brightness
screenOrientationMode - auto/manual, mode for screen orientation
-
state - current state of AMAD device
-
userFlowState - current state of a Flow, established under setUserFlowState Attribut
-
volume - media volume setting
-
volumeNotification - notification volume setting
-
- Prerequisite for using the reading checkActivTask the package name of the application to be checked needs to be defined in the attribute checkActiveTask. Example: attr Nexus10Wohnzimmer
- checkActiveTask com.android.chrome für den Chrome Browser.
-
-
-
-
- Set
-
-
activateVoiceInput - start voice input on Android device
-
bluetooth - on/off, switch bluetooth on/off
-
clearNotificationBar - All/Automagic, deletes all or only Automagic notifications in status bar
-
closeCall - hang up a running call
-
currentFlowsetUpdate - start flowset update on Android device
-
installFlowSource - install a Automagic flow on device, XML file must be stored in /tmp/ with extension xml. Example:set TabletWohnzimmer installFlowSource WlanUebwerwachen.xml
-
doNotDisturb - sets the do not Disturb Mode, always Disturb, never Disturb, alarmClockOnly alarm Clock only, onlyImportant only important Disturbs
-
mediaAmazonMusic - play/stop/next/back , controlling the amazon music media player
-
mediaGoogleMusic - play/stop/next/back , controlling the google play music media player
-
mediaSpotifyMusic - play/stop/next/back , controlling the spotify media player
-
mediaTuneinRadio - play/stop/next/back , controlling the TuneinRadio media player
-
mediaAldiMusic - play/stop/next/back , controlling the Aldi music media player
-
mediaAudible - play/stop/next/back , controlling the Audible media player
-
mediaYouTube - play/stop/next/back , controlling the YouTube media player
-
mediaVlcPlayer - play/stop/next/back , controlling the VLC media player
-
nextAlarmTime - sets the alarm time. Only valid for the next 24 hours.
-
notifySndFile - plays a media-file which by default needs to be stored in the folder "/storage/emulated/0/Notifications/" of the Android device. You may use the attribute setNotifySndFilePath for defining a different folder.
-
openCall - initial a call and hang up after optional time / set DEVICE openCall 0176354 10 call this number and hang up after 10s
-
screenBrightness - 0-255, set screen brighness
-
screenMsg - display message on screen of Android device
-
sendintent - send intent string Example: set $AMADDEVICE sendIntent org.smblott.intentradio.PLAY url http://stream.klassikradio.de/live/mp3-192/stream.klassikradio.de/play.m3u name Klassikradio, first parameter contains the action, second parameter contains the extra. At most two extras can be used.
-
sendSMS - Sends an SMS to a specific phone number. Bsp.: sendSMS Dies ist ein Test|555487263
-
startDaydream - start Daydream
-
statusRequest - Get a new status report of Android device. Not all readings can be updated using a statusRequest as some readings are only updated if the value of the reading changes.
-
timer - set a countdown timer in the "Clock" stock app. Only seconds are allowed as parameter.
-
ttsMsg - send a message which will be played as voice message
-
userFlowState - set Flow/s active or inactive,set Nexus7Wohnzimmer Badezimmer:inactive vorheizen or set Nexus7Wohnzimmer Badezimmer vorheizen,Nachtlicht Steven:inactive
-
vibrate - vibrate Android device
-
volume - set media volume. Works on internal speaker or, if connected, bluetooth speaker or speaker connected via stereo jack
-
volumeNotification - set notifications volume
-
-
- Set (depending on attribute values)
-
-
changetoBtDevice - switch to another bluetooth device. Attribute setBluetoothDevice needs to be set. See note below!
-
openApp - start an app. attribute setOpenApp
-
openURL - opens a URLS in the standard browser as long as no other browser is set by the attribute setOpenUrlBrowser.Example: attr Tablet setOpenUrlBrowser de.ozerov.fully|de.ozerov.fully.MainActivity, first parameter: package name, second parameter: Class Name
-
screen - on/off/lock/unlock, switch screen on/off or lock/unlock screen. In Automagic "Preferences" the "Device admin functions" need to be enabled, otherwise "Screen off" does not work. attribute setScreenOnForTimer changes the time the display remains switched on!
-
screenFullscreen - on/off, activates/deactivates full screen mode. attribute setFullscreen
-
screenLock - Locks screen with request for PIN. attribute setScreenlockPIN - enter PIN here. Only use numbers, 4-16 numbers required.
system - issue system command (only with rooted Android devices). reboot,shutdown,airplanemodeON (can only be switched ON) attribute root, in Automagic "Preferences" "Root functions" need to be enabled.
-
setAPSSID - set WLAN AccesPoint SSID to prevent WLAN sleeps
-
setNotifySndFilePath - set systempath to notifyfile (default /storage/emulated/0/Notifications/
-
setTtsMsgSpeed - set speaking speed for TTS (Value between 0.5 - 4.0, 0.5 Step) default is 1.0
-
setTtsMsgLang - set speaking language for TTS, de or en (default is de)
-
- To be able to use "openApp" the corresponding attribute "setOpenApp" needs to contain the app package name.
-
- To be able to switch between bluetooth devices the attribute "setBluetoothDevice" needs to contain (a list of) bluetooth devices defined as follows: attr <DEVICE> BTdeviceName1|MAC,BTDeviceName2|MAC No spaces are allowed in any BTdeviceName. Defining MAC please make sure to use the character : (colon) after each second digit/character.
- Example: attr Nexus10Wohnzimmer setBluetoothDevice Logitech_BT_Adapter|AB:12:CD:34:EF:32,Anker_A3565|GH:56:IJ:78:KL:76
-
-
-
- state
-
-
initialized - shown after initial define.
-
active - device is active.
-
disabled - device is disabled by the attribute "disable".
+comming soon
=end html
=begin html_DE
@@ -1147,177 +979,59 @@ sub AMADCommBridge_ParseMsg($$) {
AMADCommBridge
- AMAD - Automagic Android Device
-
- Dieses Modul liefert, in Verbindung mit der Android APP Automagic, diverse Informationen von Android Geräten.
- Die AndroidAPP Automagic (welche nicht von mir stammt und 2.90 Euro kostet) funktioniert wie Tasker, ist aber bei weitem User freundlicher.
-
- Mit etwas Einarbeitung können jegliche Informationen welche Automagic bereit stellt in FHEM angezeigt werden. Hierzu bedarf es lediglich eines eigenen Flows welcher seine Daten an die AMADCommBridge sendet. Das Modul gibt auch die Möglichkeit Androidgeräte zu steuern.
-
- Für all diese Aktionen und Informationen wird auf dem Androidgerät "Automagic" und ein so genannter Flow benötigt. Die App ist über den Google PlayStore zu beziehen. Das benötigte Flowset bekommt man aus dem FHEM Verzeichnis.
+ AMAD - Automagic Android Device
+ AMADCommBridge - Kommunikationsbrücke für alle AMAD Geräte
+
+ Dieses Modul ist das Ausgangsmodul zur erfolgreichen Integration von Androidgeräten in FHEM. Es stellt ferner eine Verbindungsebene zwischen AMAD unterstützten Geräten und FHEM zur Verfügung. Alle Kommunikation zwischen AMAD Android und FHEM läuft über diese Schnittstelle.
+ Daher erfolgt die Ersteinrichtung eines AMAD Devices auch genau über diese Modulinstanz.
+
+ Damit erfolgreich ein Androidgerät in FHEM eingerichtet werden kann, muss im ersten Schritt ein AMADCommBridge Device angelegt werden.
- Wie genau verwendet man nun AMAD?
-
-
man installiert die App "Automagic Premium" aus dem PlayStore.
-
dann installiert man das Flowset 74_AMADautomagicFlowset$VERSION.xml aus dem Ordner $INSTALLFHEM/FHEM/lib/ auf dem Androidgerät und aktiviert die Flows.
-
-
- Es muß noch ein Device in FHEM anlegt werden.
-
- Diese Anweisung erstellt zwei neues AMAD-Device im Raum AMAD.Der Parameter <IP-ADRESSE> legt die IP Adresse des Android Gerätes fest.
- Das zweite Device ist die AMADCommBridge welche als Kommunikationsbrücke vom Androidgerät zu FHEM diehnt. !!!Comming Soon!!! Wer den Port ändern möchte, kann dies über das Attribut "port" tun. Ihr solltet aber wissen was Ihr tut, da dieser Port im HTTP Request Trigger der beiden Flows eingestellt ist. Demzufolge muß der Port dort auch geändert werden. Der Port für die Bridge kann ohne Probleme im Bridge Device mittels dem Attribut "port" verändert werden.
-
- Der Port für die Bridge kann ohne Probleme im Bridge Device mittels dem Attribut "port" verändert werden.
+ Diese Anweisung erstellt ein neues AMADCommBridge Device Namens AMADBridge.
+
+ Im folgenden muß lediglich das Flowset auf dem Android Gerät installiert werden und der Flow 'First Run Assistant' ausgeführt werden. (einfach den Homebutton drücken)
+ Der Assistant geleitet Dich dann durch die Einrichtung Deines AMAD Gerätes und sorgt dafür das am Ende des Installationsprozess das Androidgerät als AMAD Device in FHEM angelegt wird.
-
- AMAD Communication Bridge
-
- Beim ersten anlegen einer AMAD Deviceinstanz wird automatisch ein Gerät Namens AMADCommBridge im Raum AMAD mit angelegt. Dieses Gerät diehnt zur Kommunikation vom Androidgerät zu FHEM ohne das zuvor eine Anfrage von FHEM aus ging. Damit das Androidgerät die IP von FHEM kennt, muss diese sofort nach dem anlegen der Bridge über den set Befehl in ein entsprechendes Reading in die Bridge geschrieben werden. DAS IST SUPER WICHTIG UND FÜR DIE FUNKTION DER BRIDGE NOTWENDIG.
- Hierfür muß folgender Befehl ausgeführt werden. set AMADCommBridge fhemServerIP <FHEM-IP>.
- Als zweites Reading kann expertMode gesetzen werden. Mit diesem Reading wird eine unmittelbare Komminikation mit FHEM erreicht ohne die Einschränkung über ein
- Notify gehen zu müssen und nur reine set Befehle ausführen zu können.
-
- NUN bitte die Flows AKTIVIEREN!!!
-
- Fertig! Nach anlegen der Geräteinstanz und dem eintragen der fhemServerIP in der CommBridge sollten nach spätestens 15 Sekunden bereits die ersten Readings reinkommen. Nun wird alle 15 Sekunden probiert einen Status Request erfolgreich ab zu schließen. Wenn der Status sich über einen längeren Zeitraum nicht auf "active" ändert, sollte man im Log nach eventuellen Fehlern suchen.
-
automagicState - Statusmeldungen von der AutomagicApp (Voraussetzung Android >4.3). Ist Android größer 4.3 vorhanden und im Reading steht "wird nicht unterstützt", muß in den Androideinstellungen unter Ton und Benachrichtigungen -> Benachrichtigungszugriff ein Haken für Automagic gesetzt werden
checkActiveTask - Zustand einer zuvor definierten APP. 0=nicht aktiv oder nicht aktiv im Vordergrund, 1=aktiv im Vordergrund, siehe Hinweis unten
-
connectedBTdevices - eine Liste der verbundenen Gerät
-
connectedBTdevicesMAC - eine Liste der MAC Adressen aller verbundender BT Geräte
-
currentMusicAlbum - aktuell abgespieltes Musikalbum des verwendeten Mediaplayers
-
currentMusicApp - aktuell verwendeter Mediaplayer (Amazon Music, Google Play Music, Google Play Video, Spotify, YouTube, TuneIn Player, Aldi Life Music)
-
currentMusicArtist - aktuell abgespielter Musikinterpret des verwendeten Mediaplayers
-
currentMusicIcon - Cover vom aktuell abgespielten Album Noch nicht fertig implementiert
-
currentMusicState - Status des aktuellen/zuletzt verwendeten Mediaplayers
-
currentMusicTrack - aktuell abgespielter Musiktitel des verwendeten Mediaplayers
-
daydream - on/off, Daydream gestartet oder nicht
-
deviceState - Status des Androidgerätes. unknown, online, offline.
-
doNotDisturb - aktueller Status des nicht stören Modus
-
dockingState - undocked/docked Status ob sich das Gerät in einer Dockinstation befindet.
-
flow_SetCommands - active/inactive, Status des SetCommands Flow
-
flow_informations - active/inactive, Status des Informations Flow
-
flowsetVersionAtDevice - aktuell installierte Flowsetversion auf dem Device
-
incomingCallerName - Anrufername des eingehenden Anrufes
-
incomingCallerNumber - Anrufernummer des eingehenden Anrufes
-
incommingWhatsAppMessageFrom - letzte WhatsApp Nachricht
-
incommingWhatsTelegramMessageFrom - letzte Telegram Nachricht
-
intentRadioName - zuletzt gesrreamter Intent Radio Name
-
intentRadioState - Status des IntentRadio Players
-
keyguardSet - 0/1 Displaysperre gesetzt 0=nein 1=ja, bedeutet nicht das sie gerade aktiv ist
-
lastSetCommandError - letzte Fehlermeldung vom set Befehl
-
lastSetCommandState - letzter Status vom set Befehl, Befehl erfolgreich/nicht erfolgreich gesendet
-
lastStatusRequestError - letzte Fehlermeldung vom statusRequest Befehl
-
lastStatusRequestState - letzter Status vom statusRequest Befehl, Befehl erfolgreich/nicht erfolgreich gesendet
-
nextAlarmDay - aktiver Alarmtag
-
nextAlarmState - aktueller Status des "Androidinternen" Weckers
screenOrientationMode - auto/manual, Modus für die Ausrichtung (Automatisch, Manuell)
-
state - aktueller Status
-
userFlowState - aktueller Status eines Flows, festgelegt unter dem setUserFlowState Attribut
-
volume - Media Lautstärkewert
-
volumeNotification - Benachrichtigungs Lautstärke
-
- Beim Reading checkActivTask muß zuvor der Packagename der zu prüfenden App als Attribut checkActiveTask angegeben werden. Beispiel: attr Nexus10Wohnzimmer
- checkActiveTask com.android.chrome für den Chrome Browser.
-
-
-
-
- Set
-
-
activateVoiceInput - aktiviert die Spracheingabe
-
bluetooth - on/off, aktiviert/deaktiviert Bluetooth
-
clearNotificationBar - All,Automagic, löscht alle Meldungen oder nur die Automagic Meldungen in der Statusleiste
-
closeCall - beendet einen laufenden Anruf
-
currentFlowsetUpdate - fürt ein Flowsetupdate auf dem Device durch
-
doNotDisturb - schaltet den nicht stören Modus, always immer stören, never niemals stören, alarmClockOnly nur Wecker darf stören, onlyImportant nur wichtige Störungen
-
installFlowSource - installiert einen Flow auf dem Device, das XML File muss unter /tmp/ liegen und die Endung xml haben. Bsp:set TabletWohnzimmer installFlowSource WlanUebwerwachen.xml
-
mediaAmazonMusic - play, stop, next, back ,steuert den Amazon Musik Mediaplayer
-
mediaGoogleMusic - play, stop, next, back ,steuert den Google Play Musik Mediaplayer
-
mediaSpotifyMusic - play, stop, next, back ,steuert den Spotify Mediaplayer
-
mediaTuneinRadio - play, stop, next, back ,steuert den TuneIn Radio Mediaplayer
-
mediaAldiMusic - play, stop, next, back ,steuert den Aldi Musik Mediaplayer
-
mediaAudible - play, stop, next, back ,steuert den Audible Mediaplayer
-
mediaYouTube - play, stop, next, back ,steuert den YouTube Mediaplayer
-
mediaVlcPlayer - play, stop, next, back ,steuert den VLC Mediaplayer
-
nextAlarmTime - setzt die Alarmzeit. gilt aber nur innerhalb der nächsten 24Std.
-
openCall - ruft eine Nummer an und legt optional nach X Sekunden auf / set DEVICE openCall 01736458 10 / ruft die Nummer an und beendet den Anruf nach 10s
-
screenBrightness - setzt die Bildschirmhelligkeit, von 0-255.
-
screenMsg - versendet eine Bildschirmnachricht
-
sendintent - sendet einen Intentstring Bsp: set $AMADDEVICE sendIntent org.smblott.intentradio.PLAY url http://stream.klassikradio.de/live/mp3-192/stream.klassikradio.de/play.m3u name Klassikradio, der erste Befehl ist die Aktion und der zweite das Extra. Es können immer zwei Extras mitgegeben werden.
-
sendSMS - sendet eine SMS an eine bestimmte Telefonnummer. Bsp.: sendSMS Dies ist ein Test|555487263
-
startDaydream - startet den Daydream
-
statusRequest - Fordert einen neuen Statusreport beim Device an. Es können nicht von allen Readings per statusRequest die Daten geholt werden. Einige wenige geben nur bei Statusänderung ihren Status wieder.
-
timer - setzt einen Timer innerhalb der als Standard definierten ClockAPP auf dem Device. Es können nur Sekunden angegeben werden.
-
ttsMsg - versendet eine Nachricht welche als Sprachnachricht ausgegeben wird
-
userFlowState - aktiviert oder deaktiviert einen oder mehrere Flows,set Nexus7Wohnzimmer Badezimmer vorheizen:inactive oder set Nexus7Wohnzimmer Badezimmer vorheizen,Nachtlicht Steven:inactive
-
vibrate - lässt das Androidgerät vibrieren
-
volume - setzt die Medialautstärke. Entweder die internen Lautsprecher oder sofern angeschlossen die Bluetoothlautsprecher und per Klinkenstecker angeschlossene Lautsprecher, + oder - vor dem Wert reduziert die aktuelle Lautstärke um den Wert
-
volumeNotification - setzt die Benachrichtigungslautstärke.
-
-
- Set abhängig von gesetzten Attributen
-
-
changetoBtDevice - wechselt zu einem anderen Bluetooth Gerät. Attribut setBluetoothDevice muß gesetzt sein. Siehe Hinweis unten!
-
notifySndFile - spielt die angegebene Mediadatei auf dem Androidgerät ab. Die aufzurufende Mediadatei sollte sich im Ordner /storage/emulated/0/Notifications/ befinden. Ist dies nicht der Fall kann man über das Attribut setNotifySndFilePath einen Pfad vorgeben.
-
openApp - öffnet eine ausgewählte App. Attribut setOpenApp
-
openURL - öffnet eine URL im Standardbrowser, sofern kein anderer Browser über das Attribut setOpenUrlBrowser ausgewählt wurde. Bsp: attr Tablet setOpenUrlBrowser de.ozerov.fully|de.ozerov.fully.MainActivity, das erste ist der Package Name und das zweite der Class Name
-
setAPSSID - setzt die AccessPoint SSID um ein WLAN sleep zu verhindern
-
screen - on/off/lock/unlock schaltet den Bildschirm ein/aus oder sperrt/entsperrt ihn, in den Automagic Einstellungen muss "Admin Funktion" gesetzt werden sonst funktioniert "Screen off" nicht. Attribut setScreenOnForTimer ändert die Zeit wie lange das Display an bleiben soll!
-
screenFullscreen - on/off, (aktiviert/deaktiviert) den Vollbildmodus. Attribut setFullscreen
-
screenLock - Sperrt den Bildschirm mit Pinabfrage. Attribut setScreenlockPIN - hier die Pin dafür eingeben. Erlaubt sind nur Zahlen. Es müßen mindestens 4, bis max 16 Zeichen verwendet werden.
-
screenOrientation - Auto,Landscape,Portait, aktiviert die Bildschirmausrichtung (Automatisch,Horizontal,Vertikal). Attribut setScreenOrientation
-
system - setzt Systembefehle ab (nur bei gerootetet Geräen). reboot,shutdown,airplanemodeON (kann nur aktiviert werden) Attribut root, in den Automagic Einstellungen muss "Root Funktion" gesetzt werden
-
setNotifySndFilePath - setzt den korrekten Systempfad zur Notifydatei (default ist /storage/emulated/0/Notifications/
-
setTtsMsgSpeed - setzt die Sprachgeschwindigkeit bei der Sprachausgabe(Werte zwischen 0.5 bis 4.0 in 0.5er Schritten) default ist 1.0
-
setTtsMsgSpeed - setzt die Sprache bei der Sprachausgabe, de oder en (default ist de)
-
- Um openApp verwenden zu können, muss als Attribut der Package Name der App angegeben werden.
-
- Um zwischen Bluetoothgeräten wechseln zu können, muß das Attribut setBluetoothDevice mit folgender Syntax gesetzt werden. attr <DEVICE> BTdeviceName1|MAC,BTDeviceName2|MAC Es muss
- zwingend darauf geachtet werden das beim BTdeviceName kein Leerzeichen vorhanden ist. Am besten zusammen oder mit Unterstrich. Achtet bei der MAC darauf das Ihr wirklich nach jeder zweiten Zahl auch
- einen : drin habt
- Beispiel: attr Nexus10Wohnzimmer setBluetoothDevice Logitech_BT_Adapter|AB:12:CD:34:EF:32,Anker_A3565|GH:56:IJ:78:KL:76
-
-
-
- state
-
-
initialized - Ist der Status kurz nach einem define.
-
active - die Geräteinstanz ist im aktiven Status.
-
disabled - die Geräteinstanz wurde über das Attribut disable deaktiviert
JSON_ERROR - JSON Fehlermeldung welche von Perl gemeldet wird
+
JSON_ERROR_STRING - der String welcher die JSON Fehlermeldung verursacht hat
+
fhemServerIP - die Ip-Adresse des FHEM Servers, wird vom Modul auf Basis des JSON Strings vom Installationsassistenten gesetzt. Kann aber auch mittels set Befehles vom User gesetzt werden
+
receiveFhemCommand - ist das Attribut fhemControlMode auf trigger gestellt, wird das Reading gesetzt sobald ein FHEM Befehl übersendet wird. Hierauf kann dann ein Notify triggern.
+ Wird anstelle von trigger setControl als Wert für fhemControlMode eingestellt, wird das Reading nicht gestzt sondern der set Behel sofort ausgeführt.
+
receiveVoiceCommand - wird die Sprachsteuerung von AMAD aktiviert (set DEVICE activateVoiceInput) so wird der letzte erkannten Sprachbefehle in dieses Reading geschrieben.
+
receiveVoiceDevice - Name des Devices von wo aus der letzte erkannte Sprachbefehl gesendet wurde
+
state - Status der Bridge, open, closed
-
+
+
+ Attribute
+
+
allowFrom - Regexp der erlaubten IP-Adressen oder Hostnamen. Wenn dieses Attribut gesetzt wurde, werden ausschließlich Verbindungen von diesen Adressen akzeptiert.
+ Achtung: falls allowfrom nicht gesetzt ist, und keine gütige allowed Instanz definiert ist, und die Gegenstelle eine nicht lokale Adresse hat, dann wird die Verbindung abgewiesen. Folgende Adressen werden als local betrachtet:
+ IPV4: 127/8, 10/8, 192.168/16, 172.16/10, 169.254/16
+ IPV6: ::1, fe80/10
+
debugJSON - wenn auf 1 gesetzt, werden JSON Fehlermeldungen in Readings geschrieben. Siehe hierzu JSON_ERROR* unter Readings
+
fhemControlMode - steuert die zulässige Art der Kontrolle von FHEM Devices. Du kannst über die Bridge auf 2 Arten FHEM Devices steuern. Entweder per direktem FHEM Befehl aus einem Flow heraus, oder als Sprachbefehl mittels Sprachsteuerung (set DEVICE activateVoiceInput)
+
trigger - ist der Wert trigger gesetzt, werden alle an die Bridge gesendeten FHEM set Befehle in das Reading receiveFhemCommand geschrieben und können so mittels notify ausgeführt werden. Sprachsteuerung ist möglich, es werden Readings receiveVoice* gesetzt. Auf dem Androidgerät können bei Sprachsteuerung mehrere Sprachbefehle mittels "und" verknüpft/aneinander gereiht werden. Bsp: schalte die Lichtszene Abends an und schalte den Fernsehr an
+
setControl - alle set Befehle welche mittels eines Flows über die Bridge gesendet werden, werden automatisch ausgeführt. Das triggern eines Readings ist nicht nötig. Die Steuerung mittels Sprache verhält sich wie beim Wert trigger
+
thirdPartControl - verhält sich wie trigger, bei der Sprachsteuerung ist jedoch ein anreihen von Sprachbefehlen mittels "und" nicht möglich. Dient der Sprachsteuerung über Module anderer Modulautoren ((z.B. 39_TEERKO.pm)
userFlowState - set Flow/s active or inactive,set Nexus7Wohnzimmer Badezimmer:inactive vorheizen or set Nexus7Wohnzimmer Badezimmer vorheizen,Nachtlicht Steven:inactive
vibrate - vibrate Android device
volume - set media volume. Works on internal speaker or, if connected, bluetooth speaker or speaker connected via stereo jack
+
volumeUp - Increases the volume by the value from the attribute. Is no Attribut set, the default is 2
+
volumeDown - Decreases the volume by the value from the attribute. Is no Attribut set, the default is 2.
volumeNotification - set notifications volume
@@ -1007,10 +1014,12 @@ sub AMADDevice_decrypt($) {
screenLock - Locks screen with request for PIN. attribute setScreenlockPIN - enter PIN here. Only use numbers, 4-16 numbers required.
system - issue system command (only with rooted Android devices). reboot,shutdown,airplanemodeON (can only be switched ON) attribute root, in Automagic "Preferences" "Root functions" need to be enabled.
-
setAPSSID - set WLAN AccesPoint SSID to prevent WLAN sleeps
-
setNotifySndFilePath - set systempath to notifyfile (default /storage/emulated/0/Notifications/
-
setTtsMsgSpeed - set speaking speed for TTS (Value between 0.5 - 4.0, 0.5 Step) default is 1.0
-
setTtsMsgLang - set speaking language for TTS, de or en (default is de)
+
setAPSSID - Sets WLAN AccesPoint SSID to prevent WLAN sleeps
+
setNotifySndFilePath - Sets systempath to notifyfile (default /storage/emulated/0/Notifications/
+
setTtsMsgSpeed - Sets speaking speed for TTS (Value between 0.5 - 4.0, 0.5 Step) default is 1.0
+
setTtsMsgLang - Sets speaking language for TTS, de or en (default is de)
+
setVolMax - Sets the maximum volume for the volume Slider
+
setVolUpDownStep - Sets the Stepvalue for volumeUp/Down
To be able to use "openApp" the corresponding attribute "setOpenApp" needs to contain the app package name.
@@ -1169,7 +1178,9 @@ sub AMADDevice_decrypt($) {
ttsMsg - versendet eine Nachricht welche als Sprachnachricht ausgegeben wird
userFlowState - aktiviert oder deaktiviert einen oder mehrere Flows,set Nexus7Wohnzimmer Badezimmer vorheizen:inactive oder set Nexus7Wohnzimmer Badezimmer vorheizen,Nachtlicht Steven:inactive
vibrate - lässt das Androidgerät vibrieren
-
volume - setzt die Medialautstärke. Entweder die internen Lautsprecher oder sofern angeschlossen die Bluetoothlautsprecher und per Klinkenstecker angeschlossene Lautsprecher, + oder - vor dem Wert reduziert die aktuelle Lautstärke um den Wert
+
volume - setzt die Medialautstärke. Entweder die internen Lautsprecher oder sofern angeschlossen die Bluetoothlautsprecher und per Klinkenstecker angeschlossene Lautsprecher, + oder - vor dem Wert reduziert die aktuelle Lautstärke um den Wert. Der maximale Sliderwert kann über das Attribut setVolMax geregelt werden.
+
volumeUp - erhöt die Lautstärke um den angegeben Wert im entsprechenden Attribut. Ist kein Attribut angegeben wird per default 2 genommen.
+
volumeDown - reduziert die Lautstärke um den angegeben Wert im entsprechenden Attribut. Ist kein Attribut angegeben wird per default 2 genommen.
volumeNotification - setzt die Benachrichtigungslautstärke.
@@ -1188,6 +1199,8 @@ sub AMADDevice_decrypt($) {
setNotifySndFilePath - setzt den korrekten Systempfad zur Notifydatei (default ist /storage/emulated/0/Notifications/
setTtsMsgSpeed - setzt die Sprachgeschwindigkeit bei der Sprachausgabe(Werte zwischen 0.5 bis 4.0 in 0.5er Schritten) default ist 1.0
setTtsMsgSpeed - setzt die Sprache bei der Sprachausgabe, de oder en (default ist de)
+
setVolUpDownStep - setzt den Step für volumeUp und volumeDown
+
setVolMax - setzt die maximale Volume Gr&uoml;e
Um openApp verwenden zu können, muss als Attribut der Package Name der App angegeben werden.
setTtsMsgSpeed - Sets speaking speed for TTS (Value between 0.5 - 4.0, 0.5 Step) default is 1.0
setTtsMsgLang - Sets speaking language for TTS, de or en (default is de)
setVolMax - Sets the maximum volume for the volume Slider
+
setNotifyVolMax - Sets the maximum volume for the notify volume Slider
+
setRingSoundVolMax - Sets the maximum volume for the ring sound volume Slider
setVolUpDownStep - Sets the Stepvalue for volumeUp/Down
To be able to use "openApp" the corresponding attribute "setOpenApp" needs to contain the app package name.
@@ -1179,7 +1188,7 @@ sub AMADDevice_decrypt($) {
userFlowState - aktiviert oder deaktiviert einen oder mehrere Flows,set Nexus7Wohnzimmer Badezimmer vorheizen:inactive oder set Nexus7Wohnzimmer Badezimmer vorheizen,Nachtlicht Steven:inactive
vibrate - lässt das Androidgerät vibrieren
volume - setzt die Medialautstärke. Entweder die internen Lautsprecher oder sofern angeschlossen die Bluetoothlautsprecher und per Klinkenstecker angeschlossene Lautsprecher, + oder - vor dem Wert reduziert die aktuelle Lautstärke um den Wert. Der maximale Sliderwert kann über das Attribut setVolMax geregelt werden.
-
volumeUp - erhöt die Lautstärke um den angegeben Wert im entsprechenden Attribut. Ist kein Attribut angegeben wird per default 2 genommen.
+
volumeUp - erhöh;t die Lautstärke um den angegeben Wert im entsprechenden Attribut. Ist kein Attribut angegeben wird per default 2 genommen.
volumeDown - reduziert die Lautstärke um den angegeben Wert im entsprechenden Attribut. Ist kein Attribut angegeben wird per default 2 genommen.
volumeNotification - setzt die Benachrichtigungslautstärke.
@@ -1200,7 +1209,9 @@ sub AMADDevice_decrypt($) {
setTtsMsgSpeed - setzt die Sprachgeschwindigkeit bei der Sprachausgabe(Werte zwischen 0.5 bis 4.0 in 0.5er Schritten) default ist 1.0
setTtsMsgSpeed - setzt die Sprache bei der Sprachausgabe, de oder en (default ist de)
setVolUpDownStep - setzt den Step für volumeUp und volumeDown
-
setVolMax - setzt die maximale Volume Gr&uoml;e
+
setVolMax - setzt die maximale Volume Gr&uoml;e für den Slider
+
setNotifyVolMax - setzt den maximalen Lautstärkewert für Benachrichtigungslautstärke für den Slider
+
setRingSoundVolMax - setzt den maximalen Lautstärkewert für Klingellautstärke für den Slider
Um openApp verwenden zu können, muss als Attribut der Package Name der App angegeben werden.
- AMADDevice - Automagic Android Device
-
- This module integrates Android devices into FHEM and displays several settings using the Android app "Automagic".
- Automagic is comparable to the "Tasker" app for automating tasks and configuration settings. But Automagic is more user-friendly. The "Automagic Premium" app currently costs EUR 2.90.
-
- Any information retrievable by Automagic can be displayed in FHEM by this module. Just define your own Automagic-"flow" and send the data to the AMADDeviceCommBridge. One even can control several actions on Android devices.
-
- To be able to make use of all these functions the Automagic app and additional flows need to be installed on the Android device. The flows can be retrieved from the FHEM directory, the app can be bought in Google Play Store.
-
- How to use AMADDevice?
-
-
install the "Automagic Premium" app from the Google Play store.
-
install the flowset 74_AMADDeviceautomagicFlowset$VERSION.xml from the directory $INSTALLFHEM/FHEM/lib/ on your Android device and activate.
-
- With this command two new AMADDevice devices in a room called AMADDevice are created. The parameter <IP-ADDRESS< defines the IP address of your Android device. The second device created is the AMADDeviceCommBridge which serves as a communication device from each Android device to FHEM.
- !!!Coming Soon!!! The communication port of each AMADDevice device may be set by the definition of the "port" attribute. One needs background knowledge of Automagic and HTTP requests as this port will be set in the HTTP request trigger of both flows, therefore the port also needs to be set there.
-
- The communication port of the AMADDeviceCommBridge device can easily be changed within the attribut "port".
-
-
- AMADDevice Communication Bridge
-
- Creating your first AMADDevice device automatically creates the AMADDeviceCommBridge device in the room AMADDevice. With the help of the AMADDeviceCommBridge any Android device communicates initially to FHEM.To make the IP addresse of the FHEM server known to the Android device, the FHEM server IP address needs to be configured in the AMADDeviceCommBridge. WITHOUT THIS STEP THE AMADDeviceCommBridge WILL NOT WORK PROPERLY.
- Please us the following command for configuration of the FHEM server IP address in the AMADDeviceCommBridge: set AMADDeviceCommBridge fhemServerIP <FHEM-IP>.
- Additionally the expertMode may be configured. By this setting a direct communication with FHEM will be established without the restriction of needing to make use of a notify to execute set commands.
-
-
- You are finished now! After 15 seconds latest the readings of your AMADDevice Android device should be updated. Consequently each 15 seconds a status request will be sent. If the state of your AMADDevice Android device does not change to "active" over a longer period of time one should take a look into the log file for error messages.
-
-
- Readings
-
-
airplanemode - on/off, state of the aeroplane mode
-
androidVersion - currently installed version of Android
-
automagicState - state of the Automagic App (prerequisite Android >4.3). In case you have Android >4.3 and the reading says "not supported", you need to enable Automagic inside Android / Settings / Sound & notification / Notification access
-
batteryHealth - the health of the battery (1=unknown, 2=good, 3=overheat, 4=dead, 5=over voltage, 6=unspecified failure, 7=cold)
-
batterytemperature - the temperature of the battery
-
bluetooth - on/off, bluetooth state
-
checkActiveTask - state of an app (needs to be defined beforehand). 0=not active or not active in foreground, 1=active in foreground, see note below
-
connectedBTdevices - list of all devices connected via bluetooth
-
connectedBTdevicesMAC - list of MAC addresses of all devices connected via bluetooth
-
currentMusicAlbum - currently playing album of mediaplayer
-
currentMusicApp - currently playing player app (Amazon Music, Google Play Music, Google Play Video, Spotify, YouTube, TuneIn Player, Aldi Life Music)
-
currentMusicArtist - currently playing artist of mediaplayer
-
currentMusicIcon - cover of currently play albumNoch nicht fertig implementiert
-
currentMusicState - state of currently/last used mediaplayer
-
currentMusicTrack - currently playing song title of mediaplayer
-
daydream - on/off, daydream currently active
-
deviceState - state of Android devices. unknown, online, offline.
-
doNotDisturb - state of do not Disturb Mode
-
dockingState - undocked/docked, Android device in docking station
-
flow_SetCommands - active/inactive, state of SetCommands flow
-
flow_informations - active/inactive, state of Informations flow
-
flowsetVersionAtDevice - currently installed version of the flowsets on the Android device
-
incomingCallerName - Callername from last Call
-
incomingCallerNumber - Callernumber from last Call
-
incommingWhatsAppMessageFrom - last WhatsApp message
-
incommingWhatsTelegramMessageFrom - last telegram message
-
intentRadioName - name of the most-recent streamed intent radio
-
intentRadioState - state of intent radio player
-
keyguardSet - 0/1 keyguard set, 0=no 1=yes, does not indicate whether it is currently active
-
lastSetCommandError - last error message of a set command
-
lastSetCommandState - last state of a set command, command send successful/command send unsuccessful
-
lastStatusRequestError - last error message of a statusRequest command
-
lastStatusRequestState - ast state of a statusRequest command, command send successful/command send unsuccessful
-
nextAlarmDay - currently set day of alarm
-
nextAlarmState - alert/done, current state of "Clock" stock-app
-
nextAlarmTime - currently set time of alarm
-
powerLevel - state of battery in %
-
powerPlugged - 0=no/1,2=yes, power supply connected
-
screen - on locked,unlocked/off locked,unlocked, state of display
-
screenBrightness - 0-255, level of screen-brightness
screenOrientationMode - auto/manual, mode for screen orientation
-
state - current state of AMADDevice device
-
userFlowState - current state of a Flow, established under setUserFlowState Attribut
-
volume - media volume setting
-
volumeNotification - notification volume setting
-
- Prerequisite for using the reading checkActivTask the package name of the application to be checked needs to be defined in the attribute checkActiveTask. Example: attr Nexus10Wohnzimmer
- checkActiveTask com.android.chrome für den Chrome Browser.
-
-
-
-
- Set
-
-
activateVoiceInput - start voice input on Android device
-
bluetooth - on/off, switch bluetooth on/off
-
clearNotificationBar - All/Automagic, deletes all or only Automagic notifications in status bar
-
closeCall - hang up a running call
-
currentFlowsetUpdate - start flowset update on Android device
-
installFlowSource - install a Automagic flow on device, XML file must be stored in /tmp/ with extension xml. Example:set TabletWohnzimmer installFlowSource WlanUebwerwachen.xml
-
doNotDisturb - sets the do not Disturb Mode, always Disturb, never Disturb, alarmClockOnly alarm Clock only, onlyImportant only important Disturbs
-
mediaAmazonMusic - play/stop/next/back , controlling the amazon music media player
-
mediaGoogleMusic - play/stop/next/back , controlling the google play music media player
-
mediaSpotifyMusic - play/stop/next/back , controlling the spotify media player
-
mediaTuneinRadio - play/stop/next/back , controlling the TuneinRadio media player
-
mediaAldiMusic - play/stop/next/back , controlling the Aldi music media player
-
mediaAudible - play/stop/next/back , controlling the Audible media player
-
mediaYouTube - play/stop/next/back , controlling the YouTube media player
-
mediaVlcPlayer - play/stop/next/back , controlling the VLC media player
-
nextAlarmTime - sets the alarm time. Only valid for the next 24 hours.
-
notifySndFile - plays a media-file which by default needs to be stored in the folder "/storage/emulated/0/Notifications/" of the Android device. You may use the attribute setNotifySndFilePath for defining a different folder.
-
openCall - initial a call and hang up after optional time / set DEVICE openCall 0176354 10 call this number and hang up after 10s
-
screenBrightness - 0-255, set screen brighness
-
screenMsg - display message on screen of Android device
-
sendintent - send intent string Example: set $AMADDeviceDEVICE sendIntent org.smblott.intentradio.PLAY url http://stream.klassikradio.de/live/mp3-192/stream.klassikradio.de/play.m3u name Klassikradio, first parameter contains the action, second parameter contains the extra. At most two extras can be used.
-
sendSMS - Sends an SMS to a specific phone number. Bsp.: sendSMS Dies ist ein Test|555487263
-
startDaydream - start Daydream
-
statusRequest - Get a new status report of Android device. Not all readings can be updated using a statusRequest as some readings are only updated if the value of the reading changes.
-
timer - set a countdown timer in the "Clock" stock app. Only seconds are allowed as parameter.
-
ttsMsg - send a message which will be played as voice message
-
userFlowState - set Flow/s active or inactive,set Nexus7Wohnzimmer Badezimmer:inactive vorheizen or set Nexus7Wohnzimmer Badezimmer vorheizen,Nachtlicht Steven:inactive
-
vibrate - vibrate Android device
-
volume - set media volume. Works on internal speaker or, if connected, bluetooth speaker or speaker connected via stereo jack
-
volumeUp - Increases the volume by the value from the attribute. Is no Attribut set, the default is 2
-
volumeDown - Decreases the volume by the value from the attribute. Is no Attribut set, the default is 2.
-
volumeNotification - set notifications volume
-
-
- Set (depending on attribute values)
-
-
changetoBtDevice - switch to another bluetooth device. Attribute setBluetoothDevice needs to be set. See note below!
-
openApp - start an app. attribute setOpenApp
-
openURL - opens a URLS in the standard browser as long as no other browser is set by the attribute setOpenUrlBrowser.Example: attr Tablet setOpenUrlBrowser de.ozerov.fully|de.ozerov.fully.MainActivity, first parameter: package name, second parameter: Class Name
-
screen - on/off/lock/unlock, switch screen on/off or lock/unlock screen. In Automagic "Preferences" the "Device admin functions" need to be enabled, otherwise "Screen off" does not work. attribute setScreenOnForTimer changes the time the display remains switched on!
-
screenFullscreen - on/off, activates/deactivates full screen mode. attribute setFullscreen
-
screenLock - Locks screen with request for PIN. attribute setScreenlockPIN - enter PIN here. Only use numbers, 4-16 numbers required.
system - issue system command (only with rooted Android devices). reboot,shutdown,airplanemodeON (can only be switched ON) attribute root, in Automagic "Preferences" "Root functions" need to be enabled.
-
setAPSSID - Sets WLAN AccesPoint SSID to prevent WLAN sleeps
-
setNotifySndFilePath - Sets systempath to notifyfile (default /storage/emulated/0/Notifications/
-
setTtsMsgSpeed - Sets speaking speed for TTS (Value between 0.5 - 4.0, 0.5 Step) default is 1.0
-
setTtsMsgLang - Sets speaking language for TTS, de or en (default is de)
-
setVolMax - Sets the maximum volume for the volume Slider
-
setNotifyVolMax - Sets the maximum volume for the notify volume Slider
-
setRingSoundVolMax - Sets the maximum volume for the ring sound volume Slider
-
setVolUpDownStep - Sets the Stepvalue for volumeUp/Down
-
- To be able to use "openApp" the corresponding attribute "setOpenApp" needs to contain the app package name.
-
- To be able to switch between bluetooth devices the attribute "setBluetoothDevice" needs to contain (a list of) bluetooth devices defined as follows: attr <DEVICE> BTdeviceName1|MAC,BTDeviceName2|MAC No spaces are allowed in any BTdeviceName. Defining MAC please make sure to use the character : (colon) after each second digit/character.
- Example: attr Nexus10Wohnzimmer setBluetoothDevice Logitech_BT_Adapter|AB:12:CD:34:EF:32,Anker_A3565|GH:56:IJ:78:KL:76
-
-
-
- state
-
-
initialized - shown after initial define.
-
active - device is active.
-
disabled - device is disabled by the attribute "disable".
man installiert die App "Automagic Premium" aus dem PlayStore.
-
dann installiert man das Flowset 74_AMADDeviceautomagicFlowset$VERSION.xml aus dem Ordner $INSTALLFHEM/FHEM/lib/ auf dem Androidgerät und aktiviert die Flows.
+
stelle sicher das als aller erstes die AMADCommBridge in FHEM definiert wurde
+
installiere die App "Automagic Premium" aus dem PlayStore.
+
installiere das Flowset 74_AMADDeviceautomagicFlowset$VERSION.xml aus dem Ordner $INSTALLFHEM/FHEM/lib/ auf dem Androidgerät
+
aktiviere den Installationsassistanten Flow in Automagic. Wenn man nun Automagic in den Hintergrund schickt, z.B. Hometaste drücken, startet der Assistant und legt automatisch ein Device für das Androidgerät an.
-
- Es muß noch ein Device in FHEM anlegt werden.
+
- Diese Anweisung erstellt zwei neues AMADDevice-Device im Raum AMADDevice.Der Parameter <IP-ADRESSE> legt die IP Adresse des Android Gerätes fest.
- Das zweite Device ist die AMADDeviceCommBridge welche als Kommunikationsbrücke vom Androidgerät zu FHEM diehnt. !!!Comming Soon!!! Wer den Port ändern möchte, kann dies über das Attribut "port" tun. Ihr solltet aber wissen was Ihr tut, da dieser Port im HTTP Request Trigger der beiden Flows eingestellt ist. Demzufolge muß der Port dort auch geändert werden. Der Port für die Bridge kann ohne Probleme im Bridge Device mittels dem Attribut "port" verändert werden.
-
- Der Port für die Bridge kann ohne Probleme im Bridge Device mittels dem Attribut "port" verändert werden.
+ In diesem Fall wird ein AMADDevice von Hand angelegt. Die AMAD_ID, hier 123456, muß auch exakt so als globale Variable in Automagic eingetragen sein.
-
- AMADDevice Communication Bridge
-
- Beim ersten anlegen einer AMADDevice Deviceinstanz wird automatisch ein Gerät Namens AMADDeviceCommBridge im Raum AMADDevice mit angelegt. Dieses Gerät diehnt zur Kommunikation vom Androidgerät zu FHEM ohne das zuvor eine Anfrage von FHEM aus ging. Damit das Androidgerät die IP von FHEM kennt, muss diese sofort nach dem anlegen der Bridge über den set Befehl in ein entsprechendes Reading in die Bridge geschrieben werden. DAS IST SUPER WICHTIG UND FÜR DIE FUNKTION DER BRIDGE NOTWENDIG.
- Hierfür muß folgender Befehl ausgeführt werden. set AMADDeviceCommBridge fhemServerIP <FHEM-IP>.
- Als zweites Reading kann expertMode gesetzen werden. Mit diesem Reading wird eine unmittelbare Komminikation mit FHEM erreicht ohne die Einschränkung über ein
- Notify gehen zu müssen und nur reine set Befehle ausführen zu können.
-
- NUN bitte die Flows AKTIVIEREN!!!
-
- Fertig! Nach anlegen der Geräteinstanz und dem eintragen der fhemServerIP in der CommBridge sollten nach spätestens 15 Sekunden bereits die ersten Readings reinkommen. Nun wird alle 15 Sekunden probiert einen Status Request erfolgreich ab zu schließen. Wenn der Status sich über einen längeren Zeitraum nicht auf "active" ändert, sollte man im Log nach eventuellen Fehlern suchen.
stelle sicher das als aller erstes die AMADCommBridge in FHEM definiert wurde
installiere die App "Automagic Premium" aus dem PlayStore.
-
installiere das Flowset 74_AMADDeviceautomagicFlowset$VERSION.xml aus dem Ordner $INSTALLFHEM/FHEM/lib/ auf dem Androidgerät
+
installiere das Flowset 74_AMADDeviceautomagicFlowset$VERSION.xml aus dem Ordner $INSTALLFHEM/FHEM/lib/ auf dem Androidgerät
aktiviere den Installationsassistanten Flow in Automagic. Wenn man nun Automagic in den Hintergrund schickt, z.B. Hometaste drücken, startet der Assistant und legt automatisch ein Device für das Androidgerät an.
In diesem Fall wird ein AMADDevice von Hand angelegt. Die AMAD_ID, hier 123456, muß auch exakt so als globale Variable in Automagic eingetragen sein.
From 3c66d2a94d2ef85dfec02ac4b2f11ad7e8ccc697 Mon Sep 17 00:00:00 2001
From: Marko Oldenburg
Date: Mon, 24 Jul 2017 10:57:33 +0200
Subject: [PATCH 32/32] ready for final, add englisch Commandref
---
73_AMADCommBridge.pm | 68 +-
74_AMADDevice.pm | 165 +-
74_AMADautomagicFlowset_4.0.0.xml | 4618 +++++++++++++++++++++++++++++
3 files changed, 4841 insertions(+), 10 deletions(-)
create mode 100644 74_AMADautomagicFlowset_4.0.0.xml
diff --git a/73_AMADCommBridge.pm b/73_AMADCommBridge.pm
index 29d1778..46315e0 100644
--- a/73_AMADCommBridge.pm
+++ b/73_AMADCommBridge.pm
@@ -70,8 +70,8 @@ eval "use Encode qw(encode encode_utf8);1" or $missingModul .= "Encode ";
eval "use JSON;1" or $missingModul .= "JSON ";
-my $modulversion = "3.9.80";
-my $flowsetversion = "3.9.76";
+my $modulversion = "4.0.0";
+my $flowsetversion = "4.0.0";
@@ -979,7 +979,61 @@ sub AMADCommBridge_ParseMsg($$) {
AMADCommBridge
-comming soon
+
+ AMAD - Automagic Android Device
+ AMADCommBridge - Communication bridge for all AMAD devices
+
+ This module is the central point for the successful integration of Android devices in FHEM. It also provides a link level between AMAD supported devices and FHEM. All communication between AMAD Android and FHEM runs through this interface.
+ Therefore, the initial setup of an AMAD device is also performed exactly via this module instance.
+
+ In order to successfully establish an Android device in FHEM, an AMADCommBridge device must be created in the first step.
+
+
+ Define
+
+ define <name> AMADCommBridge
+
+ Example:
+
+ define AMADBridge AMADCommBridge
+
+
+ This statement creates a new AMADCommBridge device named AMADBridge.
+
+ In the following, only the Flowset has to be installed on the Android device and the Flow 'First Run Assistant' run. (Simply press the Homebutton)
+ The wizard then guides you through the setup of your AMAD device and ensures that at the end of the installation process the Android device is created as an AMAD device in FHEM.
+
+
+
+ Readings
+
+
JSON_ERROR - JSON Error message reported by Perl
+
JSON_ERROR_STRING - The string that caused the JSON error message
+
fhemServerIP - The IP address of the FHEM server, is set by the module based on the JSON string from the installation wizard. Can also be set by user using set command
+
receiveFhemCommand - is set the fhemControlMode attribute to trigger, the reading is set as soon as an FHEM command is sent. A notification can then be triggered.
+ If set instead of trigger setControl as value for fhemControlMode, the reading is not executed but the set command executed immediately.
+
receiveVoiceCommand - The speech control is activated by AMAD (set DEVICE activateVoiceInput), the last recognized voice command is written into this reading.
+
receiveVoiceDevice - Name of the device from where the last recognized voice command was sent
+
state - state of the Bridge, open, closed
+
+
+
+ Attributes
+
+
allowFrom - Regexp the allowed IP addresses or hostnames. If this attribute is set, only connections from these addresses are accepted.
+ Attention: If allowfrom is not set, and no kind allowed instance is defined, and the remote has a non-local address, then the connection is rejected. The following addresses are considered local:
+ IPV4: 127/8, 10/8, 192.168/16, 172.16/10, 169.254/16
+ IPV6: ::1, fe80/10
+
debugJSON - If set to 1, JSON error messages are written in readings. See JSON_ERROR * under Readings
+
fhemControlMode - Controls the permissible type of control of FHEM devices. You can control the bridge in two ways FHEM devices. Either by direct FHEM command from a flow, or as a voice command by means of voice control (set DEVICE activateVoiceInput)
+
trigger - If the value trigger is set, all FHEM set commands sent to the bridge are written to the reading receiveFhemCommand and can be executed using notify. Voice control is possible; readings receiveVoice * are set. On the Android device several voice commands can be linked by means of "and". Example: turn on the light scene in the evening and turn on the TV
+
setControl - All set commands sent via the flow are automatically executed. The triggering of a reading is not necessary. The control by means of language behaves like the value trigger
+
thirdPartControl - Behaves as triggered, but in the case of voice control, a series of voice commands by means of "and" is not possible. Used for voice control via modules of other module authors ((z.B. 39_TEERKO.pm)
+
+
+
+ If you have problems with the wizard, an Android device can also be applied manually, you will find in the Commandref to the AMADDevice module.
+
=end html
=begin html_DE
@@ -1007,8 +1061,8 @@ comming soon
Diese Anweisung erstellt ein neues AMADCommBridge Device Namens AMADBridge.
- Im folgenden muß lediglich das Flowset auf dem Android Gerät installiert werden und der Flow 'First Run Assistant' ausgeführt werden. (einfach den Homebutton drücken)
- Der Assistant geleitet Dich dann durch die Einrichtung Deines AMAD Gerätes und sorgt dafür das am Ende des Installationsprozess das Androidgerät als AMAD Device in FHEM angelegt wird.
+ Im folgenden muß lediglich das Flowset auf dem Android Gerät installiert werden und der Flow 'First Run Assistent' ausgeführt werden. (einfach den Homebutton drücken)
+ Der Assistent geleitet Dich dann durch die Einrichtung Deines AMAD Gerätes und sorgt dafür das am Ende des Installationsprozess das Androidgerät als AMAD Device in FHEM angelegt wird.
@@ -1018,7 +1072,7 @@ comming soon
JSON_ERROR_STRING - der String welcher die JSON Fehlermeldung verursacht hat
fhemServerIP - die Ip-Adresse des FHEM Servers, wird vom Modul auf Basis des JSON Strings vom Installationsassistenten gesetzt. Kann aber auch mittels set Befehles vom User gesetzt werden
receiveFhemCommand - ist das Attribut fhemControlMode auf trigger gestellt, wird das Reading gesetzt sobald ein FHEM Befehl übersendet wird. Hierauf kann dann ein Notify triggern.
- Wird anstelle von trigger setControl als Wert für fhemControlMode eingestellt, wird das Reading nicht gestzt sondern der set Behel sofort ausgeführt.
+ Wird anstelle von trigger setControl als Wert für fhemControlMode eingestellt, wird das Reading nicht gestzt sondern der set Befehl sofort ausgeführt.
receiveVoiceCommand - wird die Sprachsteuerung von AMAD aktiviert (set DEVICE activateVoiceInput) so wird der letzte erkannten Sprachbefehle in dieses Reading geschrieben.
receiveVoiceDevice - Name des Devices von wo aus der letzte erkannte Sprachbefehl gesendet wurde
state - Status der Bridge, open, closed
@@ -1039,7 +1093,7 @@ comming soon
- Wie man bei Problemen mit dem Assistenten ein Androidgerät auch von Hand anlegen kann, erfärst Du in der Commandref zum AMADDevice Modul.
+ Wie man bei Problemen mit dem Assistenten ein Androidgerät auch von Hand anlegen kann, erfährst Du in der Commandref zum AMADDevice Modul.
=end html_DE
diff --git a/74_AMADDevice.pm b/74_AMADDevice.pm
index b73f9f6..6410b46 100644
--- a/74_AMADDevice.pm
+++ b/74_AMADDevice.pm
@@ -54,8 +54,8 @@ eval "use Encode qw(encode encode_utf8);1" or $missingModul .= "Encode ";
eval "use JSON;1" or $missingModul .= "JSON ";
-my $modulversion = "3.9.80";
-my $flowsetversion = "3.9.76";
+my $modulversion = "4.0.0";
+my $flowsetversion = "4.0.0";
@@ -881,7 +881,166 @@ sub AMADDevice_decrypt($) {
AMADDevice
-
+
+ AMAD - Automagic Android Device
+
+ This module integrates Android devices into FHEM and displays several settings using the Android app "Automagic".
+ Automagic is comparable to the "Tasker" app for automating tasks and configuration settings. But Automagic is more user-friendly. The "Automagic Premium" app currently costs EUR 2.90.
+
+ Any information retrievable by Automagic can be displayed in FHEM by this module. Just define your own Automagic-"flow" and send the data to the AMADCommBridge. One even can control several actions on Android devices.
+
+ To be able to make use of all these functions the Automagic app and additional flows need to be installed on the Android device. The flows can be retrieved from the FHEM directory, the app can be bought in Google Play Store.
+
+ How to use AMADDevice?
+
+
first, make sure that the AMADCommBridge in FHEM was defined
+
install the "Automagic Premium" app from the PlayStore
+
install the flowset 74_AMADDeviceautomagicFlowset$VERSION.xml file from the $INSTALLFHEM/FHEM/lib/ directory on the Android device
+
activate the "installation assistant" Flow in Automagic. If one now sends Automagic into the background, e.g. Homebutton, the assistant starts and creates automatically a FHEM device for the android device
+
+ In this case, an AMADDevice is created by hand. The AMAD_ID, here 123456, must also be entered exactly as a global variable in Automagic.
+
+
+
+ Readings
+
+
airplanemode - on/off, state of the aeroplane mode
+
androidVersion - currently installed version of Android
+
automagicState - state of the Automagic App (prerequisite Android >4.3). In case you have Android >4.3 and the reading says "not supported", you need to enable Automagic inside Android / Settings / Sound & notification / Notification access
+
batteryHealth - the health of the battery (1=unknown, 2=good, 3=overheat, 4=dead, 5=over voltage, 6=unspecified failure, 7=cold)
+
batterytemperature - the temperature of the battery
+
bluetooth - on/off, bluetooth state
+
checkActiveTask - state of an app (needs to be defined beforehand). 0=not active or not active in foreground, 1=active in foreground, see note below
+
connectedBTdevices - list of all devices connected via bluetooth
+
connectedBTdevicesMAC - list of MAC addresses of all devices connected via bluetooth
+
currentMusicAlbum - currently playing album of mediaplayer
+
currentMusicApp - currently playing player app (Amazon Music, Google Play Music, Google Play Video, Spotify, YouTube, TuneIn Player, Aldi Life Music)
+
currentMusicArtist - currently playing artist of mediaplayer
+
currentMusicIcon - cover of currently play albumNoch nicht fertig implementiert
+
currentMusicState - state of currently/last used mediaplayer
+
currentMusicTrack - currently playing song title of mediaplayer
+
daydream - on/off, daydream currently active
+
deviceState - state of Android devices. unknown, online, offline.
+
doNotDisturb - state of do not Disturb Mode
+
dockingState - undocked/docked, Android device in docking station
+
flow_SetCommands - active/inactive, state of SetCommands flow
+
flow_informations - active/inactive, state of Informations flow
+
flowsetVersionAtDevice - currently installed version of the flowsets on the Android device
+
incomingCallerName - Callername from last Call
+
incomingCallerNumber - Callernumber from last Call
+
incommingWhatsAppMessageFrom - last WhatsApp message
+
incommingWhatsTelegramMessageFrom - last telegram message
+
intentRadioName - name of the most-recent streamed intent radio
+
intentRadioState - state of intent radio player
+
keyguardSet - 0/1 keyguard set, 0=no 1=yes, does not indicate whether it is currently active
+
lastSetCommandError - last error message of a set command
+
lastSetCommandState - last state of a set command, command send successful/command send unsuccessful
+
lastStatusRequestError - last error message of a statusRequest command
+
lastStatusRequestState - ast state of a statusRequest command, command send successful/command send unsuccessful
+
nextAlarmDay - currently set day of alarm
+
nextAlarmState - alert/done, current state of "Clock" stock-app
+
nextAlarmTime - currently set time of alarm
+
powerLevel - state of battery in %
+
powerPlugged - 0=no/1,2=yes, power supply connected
+
screen - on locked,unlocked/off locked,unlocked, state of display
+
screenBrightness - 0-255, level of screen-brightness
screenOrientationMode - auto/manual, mode for screen orientation
+
state - current state of AMAD device
+
userFlowState - current state of a Flow, established under setUserFlowState Attribut
+
volume - media volume setting
+
volumeNotification - notification volume setting
+
+ Prerequisite for using the reading checkActivTask the package name of the application to be checked needs to be defined in the attribute checkActiveTask. Example: attr Nexus10Wohnzimmer
+ checkActiveTask com.android.chrome für den Chrome Browser.
+
+
+
+
+ Set
+
+
activateVoiceInput - start voice input on Android device
+
bluetooth - on/off, switch bluetooth on/off
+
clearNotificationBar - All/Automagic, deletes all or only Automagic notifications in status bar
+
closeCall - hang up a running call
+
currentFlowsetUpdate - start flowset update on Android device
+
installFlowSource - install a Automagic flow on device, XML file must be stored in /tmp/ with extension xml. Example:set TabletWohnzimmer installFlowSource WlanUebwerwachen.xml
+
doNotDisturb - sets the do not Disturb Mode, always Disturb, never Disturb, alarmClockOnly alarm Clock only, onlyImportant only important Disturbs
+
mediaAmazonMusic - play/stop/next/back , controlling the amazon music media player
+
mediaGoogleMusic - play/stop/next/back , controlling the google play music media player
+
mediaSpotifyMusic - play/stop/next/back , controlling the spotify media player
+
mediaTuneinRadio - play/stop/next/back , controlling the TuneinRadio media player
+
mediaAldiMusic - play/stop/next/back , controlling the Aldi music media player
+
mediaAudible - play/stop/next/back , controlling the Audible media player
+
mediaYouTube - play/stop/next/back , controlling the YouTube media player
+
mediaVlcPlayer - play/stop/next/back , controlling the VLC media player
+
nextAlarmTime - sets the alarm time. Only valid for the next 24 hours.
+
notifySndFile - plays a media-file which by default needs to be stored in the folder "/storage/emulated/0/Notifications/" of the Android device. You may use the attribute setNotifySndFilePath for defining a different folder.
+
openCall - initial a call and hang up after optional time / set DEVICE openCall 0176354 10 call this number and hang up after 10s
+
screenBrightness - 0-255, set screen brighness
+
screenMsg - display message on screen of Android device
+
sendintent - send intent string Example: set $AMADDEVICE sendIntent org.smblott.intentradio.PLAY url http://stream.klassikradio.de/live/mp3-192/stream.klassikradio.de/play.m3u name Klassikradio, first parameter contains the action, second parameter contains the extra. At most two extras can be used.
+
sendSMS - Sends an SMS to a specific phone number. Bsp.: sendSMS Dies ist ein Test|555487263
+
startDaydream - start Daydream
+
statusRequest - Get a new status report of Android device. Not all readings can be updated using a statusRequest as some readings are only updated if the value of the reading changes.
+
timer - set a countdown timer in the "Clock" stock app. Only seconds are allowed as parameter.
+
ttsMsg - send a message which will be played as voice message
+
userFlowState - set Flow/s active or inactive,set Nexus7Wohnzimmer Badezimmer:inactive vorheizen or set Nexus7Wohnzimmer Badezimmer vorheizen,Nachtlicht Steven:inactive
+
vibrate - vibrate Android device
+
volume - set media volume. Works on internal speaker or, if connected, bluetooth speaker or speaker connected via stereo jack
+
volumeNotification - set notifications volume
+
+
+ Set (depending on attribute values)
+
+
changetoBtDevice - switch to another bluetooth device. Attribute setBluetoothDevice needs to be set. See note below!
+
openApp - start an app. attribute setOpenApp
+
openURL - opens a URLS in the standard browser as long as no other browser is set by the attribute setOpenUrlBrowser.Example: attr Tablet setOpenUrlBrowser de.ozerov.fully|de.ozerov.fully.MainActivity, first parameter: package name, second parameter: Class Name
+
screen - on/off/lock/unlock, switch screen on/off or lock/unlock screen. In Automagic "Preferences" the "Device admin functions" need to be enabled, otherwise "Screen off" does not work. attribute setScreenOnForTimer changes the time the display remains switched on!
+
screenFullscreen - on/off, activates/deactivates full screen mode. attribute setFullscreen
+
screenLock - Locks screen with request for PIN. attribute setScreenlockPIN - enter PIN here. Only use numbers, 4-16 numbers required.
system - issue system command (only with rooted Android devices). reboot,shutdown,airplanemodeON (can only be switched ON) attribute root, in Automagic "Preferences" "Root functions" need to be enabled.
+
setAPSSID - set WLAN AccesPoint SSID to prevent WLAN sleeps
+
setNotifySndFilePath - set systempath to notifyfile (default /storage/emulated/0/Notifications/
+
setTtsMsgSpeed - set speaking speed for TTS (Value between 0.5 - 4.0, 0.5 Step) default is 1.0
+
setTtsMsgLang - set speaking language for TTS, de or en (default is de)
+
+ To be able to use "openApp" the corresponding attribute "setOpenApp" needs to contain the app package name.
+
+ To be able to switch between bluetooth devices the attribute "setBluetoothDevice" needs to contain (a list of) bluetooth devices defined as follows: attr <DEVICE> BTdeviceName1|MAC,BTDeviceName2|MAC No spaces are allowed in any BTdeviceName. Defining MAC please make sure to use the character : (colon) after each second digit/character.
+ Example: attr Nexus10Wohnzimmer setBluetoothDevice Logitech_BT_Adapter|AB:12:CD:34:EF:32,Anker_A3565|GH:56:IJ:78:KL:76
+
+
+
+ state
+
+
initialized - shown after initial define.
+
active - device is active.
+
disabled - device is disabled by the attribute "disable".