Unser altes Notebook mit einem betagten Celeron 400 unter der Haube ist langsam aber sicher hinüber. Auf dem 21C3 hat her Cobe schon gewitzelt, ob ich mir nicht langsam mal ein neues Notebook kaufen will, immerhin schleppe ich es seit 5 Jahren auf dem Chaos-Congress 🙂
Nicht dass die CPU zu schwachbrüstig wäre, mit 196 MB Ram ist es die perfekte Surfstation. Leider wird das Display immer dunkler, man kann bei Tageslicht fast gar nichts mehr erkennen. Ich durfte entsprechend viele Flüche von meiner Dame vernehmen, die viel Zeit damit verbrachte den Mauscursor zu suchen.
Ein Neues Notebook muss also her. Das bedeutet erstmal ein Wochenende Arbeit für mich, Gentoo compilieren braucht auch mit distcc einige Zeit. Ich frage besser vorher nochmal die Zielperson: „Möchtest Du mit Linux oder Windows arbeiten?“ „Dann lieber Windows, unter Linux geht immer irgend etwas nicht.“ Für einen kleinen Moment setzt mein Herzschlag aus. Windows! Himmel! All die Jahre habe ich ihr versucht die Vorzüge von Linux näher zu bringen und dann das! Eine Virenschleuder soll in unseren Haushalt einziehen? Verrat!!!
Andererseits: wo sie recht hat… irgendwo hakt es immer. Ein xterm zu öffnen um das Lockfile eines abgestürzten Mozilla zu löschen, das sich irgendwo tief im profile versteckt, ist eine Zumutung. Drucken aus dem WLAN geht derzeit auch nicht.
Hauptanforderung ist also „Er soll einfach nur funktionieren.“ „Dann nimm einen Mac. Einfach zu bedienen, funktioniert immer.“. Gesagt, getan. Wenige Stunden später sitzt meine Dame auf der Couch und erkundet freudestrahlend ihr neues iBook.
Ich grinse derweil in mich hinein. Switched – von Linux nach MacOS. Der Arbeitsaufwand für mich beschränkte sich auf die Proxy-Einstellungen. Ich brauche wohl doch kein „No, I will not fix your computer!“ T-Shirt. Meine Antwort wird in Zukunft immer sein: „Kauf Dir einen Mac“ 😉
Warte nur ein Weilchen…
Ich habe Doxygen auf ein etwas größeres Projekt losgelassen. Das war Vorgestern, genauer gesagt vor 38 Stunden… Zum Glück hat sich noch niemand beschwert wegen der CPU-Last 🙂
and thanks for all the fish://
Heute habe ich von der netten Dame an der Rezeption ein neues WLAN-Ticket bekommen und kann nun fröhlich das Internetz leersaugen. Ich habe zwar lauter Filme mitgenommen, die ich schon immer mal sehen wollte, aber da man beim Musikhören herumhacken kann, ziehe ich mir Musik von zu hause.
KDE ist toll. Mit fish:// stöber‘ ich auf meinem Server und entdecke die Perlen in meiner MP3-Sammlung wieder. Warum muss man dafür immer erst hunderte von Kilometern fahren?
KDE Anwendungen fernsteuern
Mit dem dcop-Browser kdcop kann man sehr bequem die öffentlichen Interfaces beliebiger KDE-Komponenten erkunden.
Noatun stellt in der Klasse Noatun die Methoden playpause()
, stop()
, forward()
und back()
bereit. Wie praktisch, dass mein Notebook über „Multimediatasten“ mit der gleichen Bezeichnung verfügt 🙂 Über den Ausführen-Knopf (STRG-E) kann der Methodenaufruf getestet werden.
Wird die erwartete Funktion ausgeführt, kann der entsprechende Fernsteuerungsbefehl in ein Script gegossen werden. Die Syntax dabei ist
dcop [Komponente] [Klasse] [Methode] [Parameter]
z.B.
dcop noatun Noatun playpause
Tja, häte ich gestern mal nachgeschaut, was ich heute in mein Blog schreibe. Dann wäre mir die Sucherei erspart geblieben… 😉
KDE Screensaver scriptgesteuert starten
Screensaver einschalten:
dcop kdesktop KScreensaverIface save
Screensaver einschalten und Bildschirm sperren:
dcop kdesktop KScreensaverIface lock
Großmutter, warum hast du so große Ohren?
Diesem Thema widmet sich morgen das Chaosradio:
„Flirten, Lästern, Tratschen. Und niemand hört mit.“ – so warb 2002 die Bundesregierung um Vertrauen in eine funktionierende Demokratie mit intakten Bürgerrechten. Seit dieser Werbekampagne ist das Fernmeldegeheimnis stark eingeschränkt worden und trotz eines strengen Urteils des Bunderverfassungsgerichtes zum großen Lauschangriff steigen
die Zahl der Telefonüberwachung kontinuierlich stark an.
Seit Beginn dieses Jahres hat die Telekommunikationsüberwachung eine neue Dimension: Internet-Provider und E-Mail-Anbieter sind verpflichtet, den Behörden umfangreiche Schnittstellen zum Einblick in die E-Mail-Postfächer zur Verfügung zu stellen. Neben den horrenden Kosten, die letztendlich von den Kunden getragen werden müssen, bedeutet diese Möglichkein einen massiven Angriff auf das Fernmeldegeheimnis.
Chaosradio will mit euch über die neuen Einschränkungen sprechen und Tipps für die sichere Kommunikation geben.
21C3: Folien
Die meisten Folien der Vorträge vom 21C3 sind jetzt im Fahrplan verlinkt. Viel Spaß bei der Lektüre 😉 [ 21C3 Weblog ]
21C3: Eindrücke
Ein paar Eindrücke vom 21C3.
„21C3: Eindrücke“ weiterlesen
21C3: Watch you DNS-traffic!
Dan Kaminsky hat in seinem sehr lebhaftigen und witzigen Vortrag über die weniger bekannten Möglichkeiten von DNS gesprochen.
Weil DNS durch jede Firewall kommt, liegt es doch nahe, DNS als Transportschicht für Daten zu nutzen. Es gibt Gerüchte, dass Viren- und Botprogrammierer diese Technik für sich entdeckt haben, denn IRC scheitert meist an der Firewall.
Eigentlich kann man alle Record-Typen benutzen, praktikabel sind jedoch TXT, A und PTR Records, weil sie am gebräuchlisten sind bzw. viel Daten transportieren können. Alles was man braucht, ist ein bösartiger DNS-Server. Um zu beweisen, dass man alles über DNS tunneln kann, wurde praktisch SSH via DNS und Webradio via DNS vorgeführt. Das Tunneling kann sehr interessant werden, wenn man im Starbucks sitzt und keine Lust hat, für den Netzzugang Geld zu bezahlen. Die WLAN-Router lassen nämlich in 99% der Fälle DNS durch. Irgendwie muss der zahlungswillige Kunde ja auf die Login-Seite kommen, oder ? 😉
Diese Idee kann man noch weiter spinnen, so ist eine Peer-To-Peer System auf DNS-Basis vorstellbar. DNS-Server sind so nett, Daten mit einer von uns festgelegten Dauer zwischenzuspeichern. Ich könnte meine MP3s auf einer gewissen Anzahl von Servern ablegen und diese Adressen meinen Freunden geben. Datentransport über DNS ist zwar nicht besonders schnell, aber es gibt Millonen DNS-Server dort draußen…
21C3: Der unbekannte serielle Bus.
1stein referierte über die unteren Protokollschichten des Unbekannten Seriellen Buses. „Jeder hat es, keiner weiss, wie es funktioniert“ 😉
Er gab einen sehr guten Überblick über die Low-Level Kommunikation auf dem USB. Zum Schluss erklärte er seinen Hackerport, der die Möglichkeiten der aussterbenden parallelen Schnittstelle (und noch viel mehr) über USB bereitstellt.
21C3: Gnome Anwendungsentwicklung
In Gnome Anwendungsentwicklung ging es hauptsächlich um das objektorientierte C-Framework, auf dem GTK und Gnome basieren. Gnome began als reines C-Projekt, die Objektorientierung wurde nicht etwa mit dem Umstieg auf C++ eingeführt, sondern mit GObject und seinen Erben.
Ich sehe diese Technologie mit gemischten Gefühlen. Einerseits sind gute Ansätze dabei, es gibt endlich eine echte Typprüfung, die nicht mal C++ von Hause aus liefert. Andererseits sehe ich den entsprechenden Code und muss vor Schmerz aufstöhnen.
Es wird teilweise Code generiert, Makros werden exzessiv verwendet und die Strukturen kommen mir höllisch kompliziert und fehleranfällig vor.
Interessant war, dass alle Entities Namensstrings und mitunter einen kleinen Kommentar für die API-Doku bekommen können. Diese werden dann für Debugging oder Introspection genutzt, z.B. kann ein GUI-Builder daraus Nutzen ziehen.
Neben privaten Membern kann man noch Properties definieren und diese mit Lese- und Schreibrechten versehen.
Das GInterface klingt wie Java Interfaces und funktioniert auch in etwa so. Es gibt Prerequisits, damit kann man definieren, dass ein Interface nur von Klassen implementiert werden darf, die von Klasse XYZ abgeleitet wurden.
Mit gtkmm steht die C++ Version des Frameworks bereit, das sollte ich mir auf jeden Fall ansehen.
21C3: SUN Bloody Daft Solaris Mechanisms
Archim hat in seinem Vortrag die Möglichkeiten vom Solaris-Debugger dtrace beleuchtet. Sehr interessant war, dass man damit belibige Funktionen und deren Parameter von Programmen im Userspace beschnüffeln kann. So auch die Signierfunktion von gpg: bösartige Roots oder Nutzern von Rootkits können damit elegant die Passphrasen der Nutzer abgreifen. Es ging außerdem um neuere Rootkit-Techniken und das Aufspüren solcher Angriffe.
21C3: Ciphire Mail
Ciphire Mail ist eine Lösung für sichere e-Mail Kommunikation mit dem Anspruch absolut DAU-tauglich zu sein und gleichzeitig dem kritischen Auge paranoider Sicherheitsexperten stand zu halten. „so easy to use that any user can use it, so secure that even the most paranoid guy would use it“
„21C3: Ciphire Mail“ weiterlesen
21C3: Gentoo Hardened Toolchain
Pappy, gekleidet wie ein Consultant 😉 stellt Gentoo Hardened als neues Projekt vor.
Gentoo Hardened möchte es dem User so einfach wie möglich machen, ihn also nicht mit den technischen Details belästigen, sondern konkrete Dokumentation zur Verfügung zu stellen, wie er Gentoo Hardened auf den verschiedenen Plattformen zum Laufen bekommt. Wenn er mehr über den technischen Hintergrund erfahren möchte, kann er in der Dokumentation nachsehen oder auf den Chaos Congress gehen 🙂
Das Problem: Features wie Stack Smash Protection (SSP) kosten Performance, besonders auf der x86 Architektur – dort etwa drei bis fünf Prozent. Nicht auf AMD64, da dort das entsprechende Register schon existiert, RISC-Plattformen sind auch etwas besser drann.
In Gentoo Hardened ist jetzt ziemlich neu, dass der Stack Smash Handler in glibc untergebracht wurde. Aufgrund einer Race-Condition kamen die GH-Leute mit OpenBSD-Leuten ins Gespräch, diese bringen den Handlercode in der libc unter, was für GH die Lösung des Problems war.
Der Handler wandert an eine zentrale, wartbare Stelle, und lungert nicht mehr in jedem Executable herum. Änderungen daran wirken sich dementsprechend ohne neucompilieren der Applikationen sofort aus.
Neben SSP wird noch PIC (position independend code) und PIE (position independent executables) eingesetzt, was auf x86 nochmal bis zu 20 Prozent Performance kostet.
Ich denke Gentoo Hardened macht viel Sinn auf produktiven Servern an exponierter Stelle. Auf dem Desktop werde ich es sicherlich nicht testen, auf meinem Server läuft Debian.
Günstigerweise wurde das noch junge Debian Hardened Projekt von Gentoo-Hardened inspiriert, ein Grund es sich in den nächsten Monaten genauer anzusehen.
21C3: Passive Covert Channels in the Linux Kernel
Gestiefelt und im ledernen Minirock war die polnische Sicherheitsexpertin Joanna Rutkowska wahrlich die meistfotografierte Vortragende. Diesen Titel hat sie sich aber wahrlich verdient, sie sieht sehr gut aus, trägt die komplexe Materie der Kernelprogrammierung locker und witzig vor und zieht mit ihrem Charme alle Zuschauer in ihren Bann 😉
Ich habe trotzdem versucht mich auf den Inhalt des Vortrages zu konzentrieren. Joanna hat eine Backdoor-Technologie entwickelt, die es ermöglicht, von einen angegriffenen Computer rein passiv Nachrichten abzusenden. Das könnten z.B. mitgesniffte Passwörter sein.
Rein passiv bedeutet, dass sie mit einem kernel-modul die Sequenznummern der ausgehenden Pakete manipuliert und diese als Datenträger mißbraucht. Wenn der User eine Webseite öffnet, sendet er gleichzeitig Daten an den Angreifer, der diesen Traffic natürlich noch mitsniffen muss, um an die Informationen in den Sequenznummern zu kommen.
Mit dieser Technik können 4 Bytes pro TCP/IP Connect übertragen werden, wobei 3 Bytes Nutzdaten sind und ein Byte als Control-Byte herhalten muss. Selbstverständlich werden die ausgehenden Daten verschlüsselt, damit die Sequenznummern dem Administrator immer noch zufällig vorkommen. Wenn man die Idee weiterdenkt, ist auch eine rein bidirektionale Übertragung mit dieser Technologie möglich.
21C3: Check the fucking fingerprints!
In Seth Hardy’s Vortrag „Learning OpenPGP by example„ ging es um Angriffe auf PGP Schlüssel und die Infrastruktur des Web of Tust. Er zeigte, wie es möglich ist, doppelte Key IDs zu erzeugen und was man damit machen kann. Daher der Spruch „check the fucking fingerprints„: die Leute sollen nicht nur Key ID und e-Mail Adresse von Schlüsseln überprüfen – der Fingerprint ist die wichtigste (und aufwändigste) Prüfung.
21C3: Weird Programming 2
Markus Schaber stellte ähnlich wie im letzten Jahr in Weird Programming 2 programmiertechnische Meisterwerke vor. Interessant war ein IOCCC-Beitrag der ein Betriebssystem, GUI und vi in gut 400 Zeilen C-Code unterbrachte. Je nachdem, welche makefile-Optionen man setzt, wird ein Teil des Systems erzeugt. Die Komponenten kann man dann zusammen packen und booten.
Es wurden Beispiele für meisterhaften Code gezeigt, die allesamt aus produktiven Sourcen stammten. Besonders hervorgetan hat sich OpenMDX, die Jungs haben verstanden, was es heisst objektorientiert zu programmieren 😉 Die Krönung war eine Funktion, die sich um Whitespace-Erzeugung für XML-Dateien kümmert:
private String spaces(int number) {
char[] indent = {' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',↵
' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',↵
' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',↵
' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',↵
' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' '};
return(new String(indent, 0, number));
}
Die Folien und weitere Links finden sich auf Schabis WP2 Page, da sollte der geneigte Programmierer unbedingt reinsehen. Als weitere Reisetipps wurden noch thedailywtf.com empfohlen. Schönes Zitat aus dem Vortrag: „Three lines of code and 30 minutes to recover from„.
Auf geht’s
Ich bin heute und morgen auf dem 21C3 anzutreffen und werde, sofern das WLAN denn mal funktioniert, von dort berichten. Spitzen Sie Augen und Ohren 😉
Der 21C3-Weihnachtsmann
…hat die Crew reich beschenkt, die Bescherung wurde vom Wetterfrosch auf Zelluloid festgehalten (Quicktime 150MB) [ 21C3 Weblog ].
20C3 – Tag 3
Der Windows (In)security Vortrag drehte sich im Prinzip um Angriffe, die von der Windows-Architektur begünstigt werden. Hilfreich ist dabei, dass Windows ein nachrichtengesteuertes System ist und Techniken wie DDE, OLE, COM und diverse Abarten davon zur Verfügung stellt.
Es wurde der bekannte WM_TIMER Angriff erläutert, neu war für mich die Idee, den Code über die Nachricht WM_SETTEXT zu injezieren. Man kann damit den Code in jedes sichtbare und unsichtbare Control injezieren, dieser wird dann mit dem Function-Pointer der an WM_TIMER übergeben wird, angesprungen.
Als praktische Anwendung für diese Angriffe eignen sich personal firewalls hervorragend, da sie einem höheren Security Context laufen, als die User-Space Applikationen und es damit möglich ist, den gewünschten Code im Kontext der Firewall auszuführen.
DDE ist seit Windows 2.0 eine komfortablere Möglichkeit u.a. mit Window-Messages umzugehen, OLE ist der objekt-orientierte Oberbau des ganzen, OLE Automation ist der Autopilot für Hacker.
Man muss also nicht mehr wie wild Windows-Messages durch die Gegend schicken, sondern bemüht Methoden wie dde_execute (?). Das ganze lässt sich natürlich auch aus der Ferne auslösen, schliesslich gibt es die bombensichere RPC-Schnittstelle in Windows 😉
Eine nette Möglichkeit in einem mit Policies „abgesicherten“ Windows eine Shell zu bekommen wurde auch noch erläutert: einfach in $APPLIKATION ein OLE-Objekt „cmd.exe“ einfügen. Damit umgeht man sämtliche Policies…
Die weiteren Vorträge habe ich mir dann geklemmt, Bug Hunting war zu voll, Biological Weapons etwas langweilig und bis zum Vortrag von Jörg war es mir zu lang. Ich bin dann abgehauen und habe mein Schlafdefizit nachgeholt 🙂