Doctrine Naming Strategy in Zend Framework 2

Database Table Prefixes are easy to configure with the Doctrine Naming Strategies.
Just create and register a new Strategy in your global config:

config/autoload/global.php

<?php
 
 
namespace Album\Doctrine\Strategy;
 
 
use Doctrine\ORM\Mapping\DefaultNamingStrategy;
 
class PrefixNamingStrategy extends DefaultNamingStrategy
{
    /**
     * {@inheritdoc}
     */
    public function classToTableName($className)
    {
        return '_' . substr($className, strrpos($className, '\\') + 1);
    }
}
<?php
return array(
     /* ... */
    'doctrine' => array(
        'configuration' => array(
            'orm_default' => array(
                'naming_strategy' => new \Album\Doctrine\Strategy\PrefixNamingStrategy()
            ),
        ),
 
    ),
   /* ... */  
);

References:
Doctrine Manual Implementing a NamingStrategy

WordPress, Uberspace, Https

Ich habe heute eine Stunde investiert, un diesen Blog auf SSL umzustellen. Dank Let’s encrypt kriegt man diesen Spaß nun auch kostenlos.

Im ersten Augenblick mag es sinnlos erscheinen einen öffentlichen Blog über Https auszuliefern. Diese Mentalität kommt aus der Zeit in der man jahrlich irgendeiner obskuren Zertifikatsbude eine bestimmte Summe Geld (wenig bei einer Domain bis verdammt viel für ein Wildcard Zertifikat) in den Rachen schmeißen mußte um an ein Zertifikat zu kommen, damit der normale User ein grünes Schloss in seinem Browser sieht. Dank Let’s encrypt können wir mit diesem Denkansatz brechen und alles über SSL liefern. Dank Https wird es schwieriger Malware in die Verbindung zu schleusen und das Lauschen gestaltet sich schwieriger. Manche Stimmen meinen, daß wir diversen Geheimdiensten das Leben schwerer machen, wenn die Masse an verschlüsselten Übertragungen ansteigt.  Angeblich bekommen Https Seiten in der Google Suche auch einen Bonus.

Hier schreibe ich grob nieder was ich machen mußte. Wenn ich was vergessen habe werde ich den Post anpassen. Über Tipps und Verbesserungsvorschläge freue ich mich natürlich

Der Blog läuft seit geraumer Zeit stressfrei auf uberspace.de wobei stressfrei für mich das wohl höchste Lob an einen Hoster ist, welches ich vergeben kann. Das Zertifikat wird auf dem Terminal erzeugt und aktiviert. Eine nette Anleitung gibt es im Blog. Der Apache wird per Rewrite Rule gezwugen Http Requests immer auf Https umzubiegen.

RewriteEngine On
RewriteCond %{HTTPS} !=on
RewriteCond %{ENV:HTTPS} !=on
RewriteRule .* https://%{SERVER_NAME}%{REQUEST_URI} [R=301,L]

Im Anschluss müssen noch ein Paar WordPress spezifische Sachen angepasst werden. Ich habe das in der Datenbank getan (vorher unbedingt ein Backup machen!).
Die Queries fand ich bei „Webongo“. Vor der Ausführung das sollte das ihreseite.de durch was sinnvolles ersetzt werden:

s/ihreseite.de/meineseite.de/g
#blog urls
UPDATE wp_options SET option_value = replace(option_value, 'http://www.ihreseite.de', 'https://www.ihreseite.de') WHERE option_name = 'home' OR option_name = 'siteurl';
#permalinks
UPDATE wp_posts SET guid = replace(guid, 'http://www.ihreseite.de','https://www.ihreseite.de');
#links, img src's
UPDATE wp_posts SET post_content = replace(post_content, 'http://www.ihreseite.de', 'https://www.ihreseite.de');
#Meta values
UPDATE wp_postmeta SET meta_value = replace(meta_value,'http://www.ihreseite.de','https://www.ihreseite.de');

In manchen Artikeln habe ich Bilder von anderen Domains referenziert und das auch noch über http!
Solch Unfug läßt sich leicht mit LIKE finden:

select id, post_title, post_content from wp_posts where post_content like "&lt;img%src=\"http://%" AND post_status="publish";

Einfach die ID an die Post.php Url dranhängen https://www.radikalblogger.de/wp-admin/post.php?post=[HIER REIN MIT DER ID]&action=edit und das Bild anpassen.

ESP8266 debuggen

Über diesen netten Chip habe ich bereits einen Artikel geschrieben. Lief problemlos, weil die Bauteile „zusammengepasst“ haben. Ich habe mir 2 Platinen gebastelt die Raumtemperatur und Feuchtigkeit messen. Den „Weg“ zu dieser Wetterstation habe ich auf Github abgelegt – vielleicht hilft es ja jemandem weiter

2015-10-30 20.08.48
Von oben
2015-10-30 20.09.01
Und von unten

Schwer motiviert habe ich mir noch ein paar Arduino Nanos und ESP8266 bestellt und damit hat erstmal nichts geklappt! Das ist im ersten Moment ärgerlich, hat aber auch den Vorteil, daß man sich näher mit der Materie auseinander setzen muß.

Den Chip auf Breadboards benutzen

Durch den geringen Abstand der Pins kann man den ESP8266 schlecht mit Breadboards verwenden. Deshalb mußt Du vor jeglicher Art von Bastelei einen Adapter löten um Dein Leben leichter zu machen.

Benötigt werden ein Stück Lochraster Platine, eine Buchsenleiste und eine Steckerleiste mit jeweils 8 Pins. Die Steckerleiste besteht aus einem Kunststoffteil und Pins. Ich habe den Kunststoffteil ganz nach oben gedrück und dann falsch herum eingelötet. Die Buchsen ganz normal einlöten und dann auf der Unterseite verbinden. Mangels Draht und Bock habe ich die Brücken mit dem Lötkolben gemacht. Das dauert keine 10 Minuten und der Komfortgewinn ist enorm!

adapter

Probleme mit der Spannungsversorgung

Die ESP’s laufen mit 3,3V. Der Arduino hat einen 3,3V Pin der je nach verbautem Spannungsregler nicht genügend Strom liefert (wie meine neuen Arduinos). Das Problem wird sichtbar wenn die LED’s am ESP8266 dunkler werden oder die Spannung zusammenbricht. Mit einem externen Spannungsregler wie dem. AMS1117 läßt sich das Problem beheben.

Übertragungsraten

Mein erster Satz ESP8266  hat mit einer Symbolrate 9600 Baud gearbeitet. Die nächste Charge mit 115200, Baud die schafft mein neuer Satz Nanos, aber nicht die Alten.

Laut diesem Post läßt sich die Baudrate mit einer aktuellen Firmware setzen. Muß ich unbedingt ausprobieren!

Firmware ist vom Hersteller angepasst

Der gesamte Bereich Firmware ist ungemein spannend. Der ESP8266 wurde von der Firma ESPRESSIF erfunden oder produziert oder kopiert. Mein 2. Satz Chips war von der Firma AI-Thinker, die eine eigene, leicht inkompatible Firmware auf die Geräte gespielt hat und die ich nicht will weil die Sketches nicht damit laufen!

Um angenehmer mit den Chips  rumzumachen habe ich mir einen USB TTL Konverter gekauft (kostet zwischen 3€ und 8€). An Software wird nur die unsägliche Arduino IDE benötigt. Konfiguration ist unter Linux nicht nötig. Einfach die Arduino IDE starten und den Serial Monitor öffnen. Hier solange mit der Baudrate spielen, bis man auf das Kommando AT ein OK zurückbekommt. Hier mal ein Auszug aus einem solchen seriellen Gespräch – meine Kommandos sind fett, die Antworten kursiv:

AT
OK
AT+GMR 
AT version:0.30.0.0(Jul 3 2015 19:35:49)
SDK version:1.2.0
Ai-Thinker Technology Co.,Ltd.
Build:1.2.0.A Aug 7 2015 17:21:44
OK

Dies ist die Antwort der inkompatiblen Firmware. Eine schöne Übersicht über Kommandos habe ich bei Iteadstudio gefunden.

Eine nette Anleitung um die Firmware loszuwerden gibt es im Wiki von mikrocontroller.net.

Zusammengefasst (und darum geht’s in dem Beitrag) braucht man das Esptool zum Flashen und eine aktuelle Firmware. Der Chip muß dazu auch besonders beschaltet werden. Ronny Simon von Simtronyx hat das auf seinem Blog sehr nett beschrieben. Wenn die Schaltung steht alle Serial Monitors schließen und kurz Masse an Reset legen. In das Verzeichnisse der Firmware wechseln und mit esptool flashen

ms@w530: /tmp/esp_iot_sdk_v0.9.5/bin$ sudo esptool.py -p /dev/ttyUSB2 write_flash 0x00000 boot_v1.2.bin 0x01000 at/user1.512.new.bin 0x3e000 blank.bin 0x7e000 blank.bin
Connecting...
Erasing flash...
Wrote 2048 bytes at 0x00000000 in 0.2 seconds (81.7 kbit/s)...
Erasing flash...
Wrote 211968 bytes at 0x00001000 in 20.5 seconds (82.7 kbit/s)...
Erasing flash...
Wrote 4096 bytes at 0x0003e000 in 0.4 seconds (85.6 kbit/s)...
Erasing flash...
Wrote 4096 bytes at 0x0007e000 in 0.4 seconds (85.6 kbit/s)...
 
Leaving...

Zumindest bei mir hat danach alles wirklich super funktioniert 🙂

Alternative Firmware

Ein paar ziemlich coole Leute bieten eine eine Firmware an, die das Ausführen von LUA Script ermöglicht. Eine Anleitung gibts hier. Eine einfache Möglichkeit um an angepasste Firmware zu gelangen ist dieser Build Service. 

 

Dies waren soweit meine Probleme mit dem netten Chip. Falls neue auftreten werde ich diesen Beitrag entsprechend erweitern.

Wiedergabe pausieren in Kodi

Ich schaue mir gerne TV Streams mit meinem Kodi an. Um Bandbreite zu sparen ist es ganz nett diesen auch zu pausieren, wenn man das TV ausschaltet und nicht nur wenn man den Stop Befehl per Fernbedienung sendet. Dieses Verhalten läßt sich sehr leicht konfigurieren. Unter Einstellungen -> System -> Eingabegeräte die Option „Wiedergabe pausieren, wenn eine andere Quelle ausgewählt wird“ aktivieren.

screenshot002

 

Screenshots mit Kodi

Ich nutze Kodi auf einem Raspberry Pi2 ohne Keyboard.In dieser Konstellation erstellt man Screenshots am einfachsten per API Request.
http://192.168.0.148:8080/jsonrpc?request={%20%22jsonrpc%22:%20%222.0%22,%20%22id%22:%201,%20%22method%22:%20%22Input.ExecuteAction%22,%20%22params%22:%20{%20%22action%22:%20%22screenshot%22%20}}

Damit das klappt muß in den Settings ein Pfad gesetzt werden.

Einstellungen -> System -> Debugging
Einstellungen -> System -> Debugging

Ich ziehe die Bilder danach bequem scp oder Nautilus Caja auf den Rechner.

Arduino mit Wlan Modul ESP8266

Vor ca. 9 Monaten hat mein Feedreader mir einen interessanten Artikel präsentiert. Er handelte von einem Elektronik-Modul namens ESP8266 der TCP/IP Kommunikation über WLAN mit Arduino Controllern ermöglicht. Low-Level Geschichten interessieren mich normalerweise nicht, weil es meist aufwändig und kostspielig war die Hardware ins Netz zu bringen- vor allem ohne Kabel. Dank der netten Ebay Händler aus Shenzhen bekommt man die Hardware für solche Unterfangen inzwischen unter 10€. Ich hatte das Teil sofort bestellt, aber habe es nie geschafft es in Betrieb zu nehmen weil immer was dazwischen kam und mir die Muße fehlte – bis vor ca. 1h. Warum meine ersten Versuche das Teil in Betrieb zu nehmen fehlschlugen kann ich leider nicht mehr sagen. Als ausgebildete Fachkraft bin ich zu 100% sicher die Schaltung 1:1 nachgebaut zu haben aber es wollte nicht klappen. Aufgrund solcher Gedächtnisslücken schreibe ich jetzt diesen Artikel:).

 

 

Auf der Website Instructables.com bin ich auf eine vergleichbare Anleitung gestoßen, die eine Verkabelung ohne Spannugnsteiler und Stützkondensator vorsieht und auf einmal hatte es funktioniert! In dem Tutorial dreht sich alles darum per Http Request Sensordaten von einem DS1820 Temperatursensor per HTTP auf eine recht interessante Seite namens Thingspeak zu übertragen. Ich habe den Code ein wenig angepasst, da ich weder die Hardware dafür besitze noch die Libraries einbinden wollte. Wenn Du das nachbauen möchtest benötigst Du einen Account auf der Seite und mußt den Präprozessor neben SSID und Passwort mit einen API-KEY für Thingspeak füttern.

#include
#include 
 
 
#define SSID "SSID"
#define PASS "PASSWORD"
#define IP "184.106.153.149" // thingspeak.com
String GET = "GET /update?key=[APIKEY]]&amp;field1=";
SoftwareSerial monitor(10, 11); // RX, TX
 
void setup()
{
  monitor.begin(9600);
  Serial.begin(9600);
 
  sendDebug("AT");
  delay(5000);
  if(Serial.find("OK")){
    monitor.println("RECEIVED: OK");
    connectWiFi();
  }
}
 
void loop(){
 
  //float tempC = sensors.getTempCByIndex(0);
 
  char buffer[10];
  String tempF = dtostrf(989, 4, 1, buffer);
  updateTemp(tempF);
  delay(60000);
}
 
void updateTemp(String tenmpF){
  String cmd = "AT+CIPSTART=\"TCP\",\"";
  cmd += IP;
  cmd += "\",80";
  sendDebug(cmd);
  delay(2000);
  if(Serial.find("Error")){
    monitor.print("RECEIVED: Error");
    return;
  }
  cmd = GET;
  cmd += tenmpF;
  cmd += "\r\n";
  Serial.print("AT+CIPSEND=");
  Serial.println(cmd.length());
  if(Serial.find("&gt;")){
    monitor.print("&gt;");
    monitor.print(cmd);
    Serial.print(cmd);
  }else{
    sendDebug("AT+CIPCLOSE");
  }
  if(Serial.find("OK")){
    monitor.println("RECEIVED: OK");
  }else{
    monitor.println("RECEIVED: Error");
  }
}
void sendDebug(String cmd){
  monitor.print("SEND: ");
  monitor.println(cmd);
  Serial.println(cmd);
} 
 
boolean connectWiFi(){
  Serial.println("AT+CWMODE=1");
  delay(2000);
  String cmd="AT+CWJAP=\"";
  cmd+=SSID;
  cmd+="\",\"";
  cmd+=PASS;
  cmd+="\"";
  sendDebug(cmd);
  delay(5000);
  if(Serial.find("OK")){
    monitor.println("RECEIVED: OK");
    return true;
  }else{
    monitor.println("RECEIVED: Error");
    return false;
  }
}

Die Verdrahtung gestaltet sich sehr einfach und funktioniert mit meinem Arduino UNO- und dem Arduino NANO 328-Klon:

ESP8266 Arduino
TXD RXD
CH_PD VCC 3V3
VXX VCC 3V3
GND GND
RXD TXD

Die Pins auf dem WLAN Chip sind so belegt:

Bild von http://mcuoneclipse.com/2014/10/15/cheap-and-simple-wifi-with-esp8266-for-the-frdm-board/

Hier 2 Bilder die zeigen wie die PINS auf den Arduinos herausgeführt sind:

 

Der Arduino Nano mit 328 Mega Chip

uno

Tükisch waren 2 Dinge an der Geschichte:

  1. Nmap findet das Gerät nicht im Netzwerk. Ich bin der Sache noch nicht nachgestiegen, aber mit <ahref=“http://linux.die.net/man/8/arp“>arp ist es kein Problem. Das muß ich mir anschauen
  2. Der Arduino kann nur programmiert werden, wenn man das WLAN Modul spannungsfrei macht. Auch ein Trennen der Verbindungen WLAN Modul Arduino und Arduino PC erleichtert das übertragen…

In den kommenden Tagen werde ich wohl ein kleines Programm schreiben, daß auf Port 80 lauscht und entsprechenden POST Requests analoge und digitale Ports schaltet und Stati ausgibt. Auch eine Anbindung an mein Openhab wäre sehr nett…

Bequem Phar Files erzeugen

Ich schreibe sehr gerne Bash Scripte, aber noch lieber Scripte in PHP. Solange man alles in ein File bekommt ist das auch kein Problem. Bei größeren Geschichten oder bei der Verwendung von Libs streut das Script leider auf mehrere Dateien. Entsprechend sind Installation und Updates dann auch aufwendiger. Irgendwer hat sich für diese Problematik Phar (PHP Archive) ausgedacht. Dabei werden alle Abhängigkeiten in ein komprimiertes Archiv gepackt – vom Prinzip her wie ein Jar in Java. Das manuelle Erzeugen von diesen Dateien ist leider recht unangenehm und verbraucht nach zuviel Zeit. Viel schneller geht’s mit dem PHP PHAR Compiler von Christian Neff. Bevor man loslegen kann muß die php.ini angepasst werden:

phar.readonly = 0

Anschließend den Compiler via Composer installieren und ein Script zum Bauen anlegen:

<?php
/**
 * User: ms
 * Date: 29.08.15
 * Time: 20:22
 * @see https://github.com/secondtruth/php-phar-compiler
 */
require_once dirname(__FILE__) . DIRECTORY_SEPARATOR . 'vendor/autoload.php';
use Secondtruth\Compiler\Compiler;
$compiler = new Compiler('./');
$compiler->addIndexFile('cli.php');
$compiler->addFile('vendor/autoload.php');
$compiler->addDirectory('vendor/composer', '!*.php');
$compiler->addDirectory('vendor/electrolinux', '!*.php');
$compiler->addDirectory('vendor/zendframework', '!*.php');
$compiler->addDirectory('src', '!*.php');
$compiler->compile("build/mvv-cli.phar");

Fertig.

Kabelsalate bändigen

Ich habe inzwischen mehr elektrische Geräte mit einer USB Buchse als mit klassischem Schuko Stecker. Als logische Konsequenz besitze ich auch recht viele Netzteile die Steckdosen verstopfen. Der Worstcase in Sachen Aufladung schaut so aus:

Akku entladen bei Ipad, Ebook Reader, Mobiltelefon, Mobiltelefon Freundin.

In dem Fall brauche ich 4 Geräte gleichzeitig. Wenn nun an verschiedenen Orten geladen werden soll steigt die Anzahl entsprechend. Zusätzlich schauen solche Installationen auch immer aus wie die Sau – überall fliegen Kabel herum und müssen für den Ladevorgang entwirrt werden, unter dem Sofa rausgekramt werden und was weiß ich. Alles sehr suboptimal.

Das Problem mit den vielen Netzteilen habe ich mit einem Großen  erschlagen – 5 USB-Geräte werden gleichzeitig geladen – P max =40W. Lädt auch Geräte von der Firma Apple. Ein bisschen werde ich damit wohl auch sparen aber für einen ROI < 1 wird es nicht reichen 🙂

Das Kabelgewirr war ein wenig kniffliger. Ich bin kein Freund von Kabelbindern in der Wohnung und hatte auch keine Lust mich mit dem Thema Kabelorganisierung zu beschäftigen. Abhilfe konnte ich mit meinem 3d Drucker und dem Tool OpenSCAD schaffen. Diese Kombination ist ideal um schnell Halterungen, Ersatz für kaputte Deckel von Fernbedienungen oder sinnlosen Nippes zu produzieren. Das schöne an OpenSCAD ist, daß man keine Kenntnisse in der Modellierung von 3d Modellen haben muß. Die Objekte werden einfach in einer Skriptsprache beschrieben. Dabei dreht es sich immer um das definieren von 3d Objekten, rotieren, transformieren usw.

39 Zeilen Script erzeugen die Halterung für den Tisch:

/**
 *Draw a parametric cable holder
 *
**/
use &lt;../../_library/roundedCornerCube.scad&gt;;
use &lt;../../_library/screwHoles.scad&gt;;
 
module holder(width, heightTable, length) {
    heightBottomPart =6;
    heightTopPart =5;
    widthLongPart = 6;
    //Table
    /*
    color( "Aqua", a=0.3 ) { 
       cube(size=[500,500,heightTable]); 
    }
    */
    difference() {
        translate([-widthLongPart ,50,- heightBottomPart]) {
          difference(){
                cube(size= [length, width, heightTable+heightBottomPart +heightTopPart]);
                    translate([10,width/2,0]){
                        holeM3(30);
                }            
                //Hole for the Long Part
                translate([-10,width/2, (heightTable/10*8)]) {               
                    rotate([0,90,0]){
                        holeM3(30);
                    }
                }           
            }                   
        }
        //Cut the table out
        cube(size=[500,500,heightTable]); 
    }
}
 
rotate( [90,0,0])
holder(20, 50,30);

Nach ca. einer Stunde warten auf den Drucker hat man eine Halterung

 

2015-08-22 17.39.28

 

 

 

 

 

 

 

 

Das Konzept schaut so aus: Kabel in die Führungen einlegen, Halterung an den Tisch drücken, von unten mit einer Schraube kontern. Wenn man etwas laden möchte einfach am Kabel ziehen und einstecken. Wenn der Vorgang abgeschlossen ist das Kabel aus dem Gerät entfernen und zurückdrücken. Fertig. Wer den Spaß nachbauen möchte kann sich den „Quellcode“ bei Thingiverse laden. Hier noch ein Bild von dem sensationell aufgeräumten Tisch 🙂

2015-08-22 17.39.17

Systemfreien Kaffee produzieren und Konsumieren

Wer als Konsument mangelnde Vorsicht walten läßt findet sich rasch in einem Konsumsystem wieder. Das Konzept ähnelt der iOS Plattform von Apple mit dem Unterschied, daß der Einstieg in ein solches System wesentlich günstiger ist als bei Apple.  Vor langer Zeit ist mir das mit Kaffee passiert: Ich bekam eine Nespresso Maschine geschenkt, die man mit Kapseln aus Aluminium füttern muß. Die Gegenleistung dabei ist eine kleine Tasse Kaffee und Müll in Form einer Metallkapsel. Subjektiv schmeckt der Kaffee wesentlich besser als klassischer Filterkaffee, dafür bezahlt man wirklich unverschämte Preise pro Tasse. Nestle, der Hersteller der Kapseln scheint sehr gut damit zu verdienen. Neben einem äußerst bizarren Ladengeschäft am Odeonsplatz in München reicht das Geld auch noch für eine Werbekampagne mit prominentem Schauspieler die aus so etwas trivialem wie Kaffeetrinken einen Lifestyle-Tätigkeit macht. Die Nespressomaschinen verarbeiten nur Kapseln, kein Pulver. Man kann diese auch von anderen Herstellern, erwerben aber der Kaffee ist immer von viel Plastik oder Metall umhüllt und extrem teuer.

Das ständige Einkaufen und Entsorgen von Kapseln hat mich nach 6 Monaten derart angekotzt, daß ich mich auf die Suche nach einer Alternative gemacht habe. Vollautomaten kommen für mich nicht in Frage, da sich mein Kaffeekonsum mit solchen Maschinen der Unendlichkeit nähert – bei guter Laune und interessanter Aufgabe hab ich schon locker 15 Tassen auf der Arbeit mit solchen Geräten geschafft – tut zwar der Umwelt gut, aber meinem Körper eher weniger. Filterkaffee schmeckt mir einfach nicht und eine ordentliche Espressomaschine ist mir (momentan?) zu Aufwändig im Betrieb.

Im Pflichtenheft steht also eine Gerätschaft die eine kleine Portion Kaffee (meist für 1- 2 Personen) schnell und einfach zubereitet und so wenig Müll wie möglich bei überschaubaren Kosten produziert. 

Die Lösung meines Problems fand ich im Urlaub in Italien. Jeder Haushalt in diesem Land scheint mit einer Espressokanne von Bialetti für den Herd ausgestattet zu sein. Mir wurde das Model „Moka Express“ der Marke Bialetti empfohlen. Erworben habe ich es inklusive allerhand Ersatzteile für 25€ in einem Eisenwarengeschäft in Norditalien.

Die Bedienung des Geräts ist simpel jedoch aufwändiger als bei der Kapselmaschine:

    1. Kessel und Kanne durch Drehung demontieren
    2. Sieb entfernen
    3. Kessel mit Wasser befüllen
    4. Sieb einsetzen
    5. Das Sieb bis zur Oberkante mit Kaffee füllen und leicht andrücken.
    6. Kanne auf den Kessel schrauben
    7. Maschine auf der Herdplatte erhitzen

Klingt aufwändig, geht aber wirklich schnell von der Hand und schmeckt ganz gut. Außerdem hat man bei jedem Schluck Kaffee das gute Gefühl, daß man einem ekelhaften Großkonzern  kein Geld in den Rachen geworfen hat.

Anfangs habe ich die Maschine mit gemahlenem Kaffee aus dem Supermarkt betrieben. Meine Freundin schlug dann irgendwann vor Bohnen zu erwerben und diese selbst zu mahlen. Aus einer Laune heraus habe ich mich dazu entschlossen die oben beschriebene Prozedur noch komplexer zu machen und eine Mühle ohne elektrischen Antrieb zu erwerben. Um eine Wochenration Kaffeepulver zu produzieren muß man ca. 15 Minuten aufwenden. Dafür wird man mit interessanten olfaktorischen Erlebnissen während der Produktion belohnt (riecht wirklich fein) und kann Erfahrungen bezüglich des Mahlgrads sammeln, der eine wichtige Rolle bei der Produktion spielt. Ich mahle momentan Arabica Bohnen mit einer japanischen Mühle für ca. 35€ und bevorzuge etwas groberes Pulver. Das Endprodukt schmeckt mir mit einem Schuss Milch besser als alles was aus Kapselmaschinen oder Vollautomaten kommt. Sicherlich ist der Arbeitsaufwand höher als bei Kapselmaschinen, dafür sind die laufenden Kosten deutlich geringer  – 1kg Kaffeebohnen von der Kooperative Espanica kosten ca. 9€ und nach 2 Wochen Konsum ist der erste Beutel noch zu 70% gefüllt. Weiterhin habe ich in der jetzigen Situation den Vorteil, daß nur wenige mechanische und elektrische Komponenten kaputt gehen können.

Mit diesem Artikel möchte ich niemanden belehren, ihm den Geschmack der Kaffeekapseln madig machen oder auf Lebensmittelkonzernen rumbashen. Ich will eher einen kleinen Denkanstoß geben um über Konsumsysteme im eigenen Haushalt nachzudenken. Hier noch ein paar Bilder:

Bialetti Maschine, Pulver und Kopf der Mühle
Maschine, Pulver und Kopf der Mühle
Pulver und gefüllte Espressokanne
Pulver sowie gefülltes Unterteil (Kessel + Sieb)
Fertiger Kaffee
Fertiger Kaffee

 

Wie sicher ist die Cloud?

Wie sicher ist die Cloud?

 

Es ist wohl keine sehr gewagte Prognose zu behaupten, dass so ziemlich jeder, der das Internet nutzt, in Zukunft mit der Cloud in Berührung kommen wird. Zu nützlich sind all die Vorteile, die die Cloud mit sich bringt. Man verbraucht viel weniger Speicherplatz auf seinem PC oder Laptop, was in der Regel dazu führt, dass er schneller arbeitet. Bei vielen von uns haben sich zwischenzeitlich so viele Dateien, die man nicht oft braucht, aber trotzdem nicht löschen will (vor allem Fotos und Filme), angesammelt, dass man nicht wirklich weiß, wohin damit. Die Cloud ist genau für diese Dateien der perfekte Ort.

 

Und auch in der Berufswelt legen sich Skepsis und Zweifel und immer mehr Firmen gehen dazu über, die Cloud zu benutzen.

 

Quelle: https://upload.wikimedia.org/wikipedia/commons/d/d4/Popular_BYOD.jpg

 

 

Das führt dazu, dass die Mitarbeiter wesentlich flexibler sind und nicht zwangsläufig ins Büro kommen müssen, sondern die Möglichkeit haben, von jedem Ort der Welt, an dem es eine Internetverbindung gibt, auf die Firmendaten zugreifen und daran arbeiten zu können. Oft greifen die Mitarbeiter mit ihrem privaten Mobilgerät auf die Daten zu. Bring your own device, kurz BYOD, ist ein immer beliebter werdendes Prinzip, dass dem Unternehmen Geld spart und den Mitarbeitern ungeahnte Freiheiten bietet.

 

Höheres Risiko beim Zugriff über Mobilgeräte

 

Allerdings liegen gerade in diesen Zugriffen über private Mobilgeräte und fremde Netzwerke die Gefahren, die das Arbeiten mit der Cloud in sich birgt. Hier muss man ein großes Augenmerk auf die Sicherheit legen. Denn die vertraulichen Firmendaten liegen nicht mehr sicher und geschützt vor unautorisierten Fremdzugriffen auf dem eigenen Server, sondern sie befinden sich in den Weiten des Internets. Und um die größtmögliche Sicherheit gewährleisten zu können, müssen alle Beteiligten darauf achten, die Sicherheitsstandards einzuhalten. Der Anbieter sollte seine Cloudserver mit mehreren Firewalls absichern, das Unternehmen sollte bei der Auswahl von Benutzernamen und Passwörtern aufpassen und die Mitarbeiter müssen dafür sorgen, dass ihre privaten Mobilgeräte ausreichend geschützt sind und sie sollten vor allem auch darauf achten, dass sie über geschützte und sichere W-Lan Verbindungen ins Internet gehen.

 

 

Quelle: https://flic.kr/p/cvNwF3

 

Und es gibt inzwischen noch weitere Möglichkeiten, sich zusätzlich abzusichern. Ein immer öfters angewandtes Verfahren ist die Multi-Faktor-Authentifizierung. Hier muss man sich zusätzlich zum Benutzernamen und Passwort noch durch weitere Faktoren ausweisen, beispielsweise durch einen zusätzlichen Code, der dem Benutzer per E-Mail oder per SMS gesendet wird. Somit kann man den Benutzer noch eindeutiger identifizieren und erschwert es Hackern enorm, sich hier unerlaubten Zutritt zu verschaffen.

 

Alles in allem ist das Arbeiten mit der Cloud aber auch nicht gefährlicher oder weniger sicher, als viele Dinge, die wir bereits jetzt im Internet tun, erledigen und preisgeben. Einen garantierten hundertprozentigen Schutz gibt es nicht, aber man kann es den kriminellen Hackern dieser Welt auf jeden Fall sehr schwer machen, sich Zugang zu den Daten zu verschaffen. Insgesamt überwiegen die Vorteile und Vorzüge der Cloud aber deutlich, sodass man sich von diesen Sicherheitsbedenken nicht abschrecken lassen sollte. Ihre Mitarbeiter werden das Vertrauen, die Freiheit und die Flexibilität sehr zu schätzen wissen und es Ihnen mit ausgezeichneter Arbeit und einer höheren Produktivität zurückzahlen.