Archiv des Autors: hermann

[puppet] Benutzer anlegen

Wird ein Benutzer auf einem node benötigt, müssen nur folgende Zeilen in der Konfiguration hinterlegt werden:

user { 'stefan':
ensure => present,
comment => 'Entwickler Projekt 1',
home => '/home/stefan',
managehome => true,
shell => '/bin/bash',
}
ssh_authorized_key { 'stefan_ssh':
user => 'stefan',
type => 'rsa',
key => 'djdjdjdjdj',
}

Da der Benutzer und vermutlich auch die Benutzer der Kollegen auf verschiedenen Servern benötigt werden, wurde hierfür ein Modul /etc/puppetlabs/code/environments/production/modules/ewl_gruppe1/manifests/init.pp erstellt in dem die Mitglieder aufgeführt sind:
class ewl_gruppe1 {

group {'ewl_gruppe1':
ensure => 'present',
}

user { 'stefan':
ensure => present,
comment => 'Entwickler Projekt 1',
home => '/home/stefan',
managehome => true,
shell => '/bin/bash',
gid => 'ewl_gruppe1',
}
ssh_authorized_key { 'stefan_ssh':
user => 'stefan',
type => 'rsa',
key => 'djdjdjdjdj',
}

user { 'heino':
ensure => present,
comment => 'Entwickler Projekt 1',
home => '/home/heino',
managehome => true,
shell => '/bin/bash',
gid => 'ewl_gruppe1',
}
ssh_authorized_key { 'heino_ssh':
user => 'heino',
type => 'rsa',
key => 'dlwfjwdcweiufwiecniwefn',
}

}

Damit die weitere Verwaltung bzw Berechtigung über eine Gruppe erfolgen kann, wurde die Gruppe ewl_gruppe1 erstellt. Die Benutzer wurden über den Eintrag gid => ‚ewl_gruppe1‘ hinzugefügt.

Die Application auf dem Node läuft unter dem Benutzer application1, es ist nun für die Mitglieder der ewl_gruppe1 notwendig mittels su in den Benutzer zu wechseln.

Für die Anpassung der /etc/sudoers wurde das folgende Modul installiert:
puppet module install saz-sudo --version 5.0.0

In der Konfiguration des Nodes wird für die sudoers Anpassung folgendes hinterlegt:

sudo::conf { 'ewl_grupp1':
priority => 10,
content => "%ewl_gruppe1 ALL= NOPASSWD:/bin/su - application1",
}

Damit das Modul genutzt werden kann muss zunächst auf dem Puppet Master die folgende Zeile ausgeführt werden:
puppet apply /etc/puppetlabs/code/environments/production/manifests/site.pp --modulepath=/etc/puppetlabs/code/environments/production/modules/ $*
Auf dem Node reicht ein puppet agent --test und die Mitglieder der Gruppe ewl_gruppe1 können über sudo su – application1 zum entsprechenden Applicationsbenutzer wechseln.

[openhab2] Sicherheitskamera im Habpanel einbinden

Im Habpanel können die unterschiedlichsten Aktoren oder Widgets für Informationen hinterlegt werden. Eigentlich war es geplant das Live Bild einer Überwachungskamera von Foscam ebenfalls einzubinden. Leider bietet die eingesetzte Kamera nicht die Option das Livebild per URL abzurufen, hierfür muss die Handyapp oder das webfrontend verwendet werden. Beim suchen nach einer geeigneten Lösung für das Problem bin ich in dem openhab Forum auf einen funktionierenden Ansatz gestoßen. Die Kameras bieten zwar kein Livebild per URL, jedoch kann ein Standbild abgerufen werden. In dem Image Widgets des Habpanels kann die entsprechende URL hinterlegt werden und das Widget bietet die Option das Bild in bestimmten Intervallen neu zu laden.

Die hinterlegte Url lautet http://ipadresse:88/cgi-bin/CGIProxy.fcgi?cmd=getDevState&usr=benutzer&pwd=kennwort, das Intervall wurde auf 2 Sekunden gesetzt.

[openhab2] Habpanel

Neben der App, der Website oder Integration in Amazon Alexa kann für das Schalten der Aktoren auch das Habpanel genutzt werden. Auf dem Habpanel können verschiedene Seiten erstellt werden, unter den Seiten können Schalter angelegt werden oder Kacheln in denen Informationen ausgegeben werden. Für einen schaltbaren Aktor verwende ich folgende Einstellung im Habpanel:

Das Ergebnis sieht wie folgt aus:

Hier ein Beispiel um den Zustand von Kontakten in einer Kachel auszugeben, es wurde dafür ein Template verwendet:


<div class="row" ng-repeat="item in itemsInGroup('kontakte')">
<div class="col-xs-8 text-right">{{item.name}}</div>
<div class="col-xs-4 text-left" ng-style="{ color: itemValue(item.name)=='OPEN'?'red':'green' }">
{{itemValue(item.name)}}
</div>
</div>

Ebenfalls können im Habpanel die Zeiten ausgegeben werden, wann zum Beispiel ein Fensterkontakt das letzte Mal den Status geändert hat.

Hierzu wurde ein entsprechendes Item angelegt, in dem per Rule die Zeit geschrieben wird sobald sich der Status des Items ändert.

Innerhalb der Rule wird wie folgt der Timestamp geschrieben
var local_time = java::util::Calendar::getInstance(TimeZone::getTimeZone("Europe/Berlin"))
postUpdate(Wohnzimmer_Tuer_rechts_bewegung, new DateTimeType(local_time))

Am Anfang der rules Datei wurden noch folgende Zeilen eingefügt:
import org.openhab.core.library.types.*
import java.util.Calendar
import java.util.Date
import java.util.TimeZone

Vermutlich gibt es noch weitere Möglichkeiten die Uhrzeit bzw den Timestamp in einem Item zu hinterlegen, wenn einfachere oder andere Möglichkeiten bekannt sind würde ich mich über einen entsprechenden Kommentar freuen.

Für die Ausgabe der Zeiten im Habpanel wurde ein Template mit folgendem Inhalt verwendet:

 

<div class="row" ng-repeat="item in itemsInGroup('bewegung')">
<div class="col-xs-8 text-right">{{item.name}}</div>
<div class="col-xs-4 text-left" ng-style="{ color: itemValue('item.name') }">
{{itemValue(item.name) | date:'dd.MM HH:mm' }}
</div>
</div>

[openhab2] in Amazon Alexa integrieren

Wenn man eine Alexa inkl. Smart HUB besitzt lassen sich sehr einfach die Lampen von Philips HUE einbinden und per Sprache steuern. Existiert bereits eine Hausautomation über openhab, so können die Aktoren ebenfalls über Alexa angesprochen werden.

Zunächst muss hierfür ein Konto bei https://myopenhab.org eingerichtet werden. Für die Einrichtung wird die openhab UUID und das openhab Secret benötigt.

Die UUID befindet sich unter /var/lib/openhab2/uuid und das Secret unter /var/lib/openhab2/uuid.

Nachdem das Konto eingerichtet wurde muss unter der PaperUI(MISC) das Modul openHAB Cloud Connector installiert werden, im Anschluss erfolgt unter Configuration => Services die Einrichtung. Nach einem Neustart ist es möglich über myopenhab.org die Aktoren zu schalten.

Für die Verbindung von Alexa zum myopenhab wird der entsprechende Skill benötigt.
Damit Aktoren beim Pairing gefunden werden, muss in der items.cfg beim Item der Paramter Lighting hinterlegt werden.

Switch Lampe "Lampe" (flur) ["Lighting"] {fs20="1B1111"}

Für das einfachere Ansprechen der Aktoren kann in der Amazon Alexa App ein anderer Name hingelegt werden als im openhab2.


Update

Ich wurde darauf hingewiesen das eine Integration von Amazon Alexa zu openhab auch möglich ist in dem in openhab die HUE Emulation genutzt wird und auf der Alexa der HUE Skill installiert wird. Somit ist der Onlinezugang zu myopenhab nicht notwendig.

Ich habe eine Neue und Sie heißt Alexa

Unter Weihnachtsbaum lag vermutlich wie bei vielen anderen eine Alexa. Schon länger liebäugelte ich mit dem Sprachassistenten von Amazon.
Nach dem Auspacken war die Einrichtung schnell erledigt und die ersten Skills wurden eingerichtet. Primär wollte ich den Amazon Echo nutzen um Musik zu hören, zum Beispiel über Spotify oder Amazon Music. Mittlerweile wird auch der ein oder andere Skill verwendet.

Wie bereits geschrieben verwenden wir Amazon Echo hauptsächlich zum Musik hören, hier reicht ein einfaches „Alexa spiel mit Lied x von y“ oder „Alexa spiele mir 90er“ . Der große Echo plus mit integriertem Home-Hub hat einen sehr guten Klang und kann eine kleinere Stereo Anlage ersetzen.

Auf dem Handy sowie Tablet verwende ich schon länger die App Bring! als Einkaufsliste. Hierfür gibt es nun einen entsprechenden Skill. Es reicht ein „Alexa öffne bring und füge Milch hinzu.“ und der Artikel wird der Einkaufsliste hinzugefügt. Bei der ersten Nutzung des Skills wird die Standardeinkaufsliste festgelegt.

Ein Zugriff auf den Kalender von Google ist ebenfalls möglich, es können darüber unter anderem neue Termine erstellt werden.

Als letzen Skill wird der von openhab verwendet um zum Beispiel die definierten Items in Openhab über myopenhab zu schalten. Für das Zusammenspiel zwischen Echo und Openhab werde ich noch einen weiteren Artikel verfassen.

Abgesehen von dem ganzen „Die hört ja alles mit und und zeichnet alles auf“ gefällt mir der Sprachassistent sehr gut und bin gespannt welche Möglichkeiten noch kommen werden.