Archiv des Autors: C.Baumann

Apple Push Notification – Server-Zertifikat erstellen

How to create (or renew) an Apple Certificate for APN (Apple Push Notification) Services … and prepare it in a way that it can be used by an APN Server (in this example a production server written in PHP)

1) Log in on Apple Developer Center

apn_certificate_step_1

2) Got to „Certificates, Identifiers & Profiles“

apn_certificate_step_2

3) Verify that the chosen App can be used with Push: Select „App IDs“ and check, if „Push Notifications“ is enabled in „Distribution“

apn_certificate_step_3

4) Generate the Certificate: Go to Certificates – Production and select „+“

apn_certificate_step_4

5) Choose Certificate type: in our case „Apple Push Notification SSL (Production)“ and „Continue“

apn_certificate_step_5

6) Select the desired App ID and „Continue“

apn_certificate_step_6

7) Create a CSR by following the description using Keychain („Schlüsselbundverwaltung“ on OSX), save the file (e.g. „ProjectName_Prod_APN_2015041.certSigningRequest“) and „Continue“

apn_certificate_step_7

8) Upload the CSR-File and „Generate“

apn_certificate_step_8

9) Download the generated Certificate (its default name is „aps_production.cer“)

apn_certificate_step_9

10) Open the Certificate with Keychain („Schlüsselbundverwaltung“), this imports the Certificate.

11) Export the Certificate and the private key as PKCS12 (.p12) File. Enter a protection password for the private key.

12) Convert the PKCS12 File to a .pem file using the following command:

openssl pkcs12 -in ProjectName_Prod_APN_20150415.p12 –out ProjectName_Prod_APN_20150115.pem -clcerts

You now have the certificate and encrypted private key in a pem file for use with your server:

apn_certificate_step_12_pem

13) You can check the new certificate (and validity) in the certificates list

apn_certificate_step_13_check

Uff … done 😉

Ubuntu Touch auf Nexus 4

Gestern las ich den Artikel „Das Schicke – Ubuntu für Smartphones und Tablets“ in der c’t 5/15. Sehr interessant! Und da ich ein derzeit beschäftigungsloses Nexus 4 herumliegen habe, war es klar: Da muss Ubuntu Touch drauf.

Die Installation geht mittels einer Ubuntu Desktop-Version ab 12.04, allerdings nicht unter VM-Ware. Also schnell per unetbootin eine Ubuntu 14.04_Live Version gezogen und einen bootfähigen USB-Stick erstellt.

Nach dem (wie gewohnt) problemlosen Start von Ubuntu am ThinkPad X121e ist zuerst das entsprechende Repository hinzuzufügen …

$ sudo add-apt-repository universe

… und zur Sicherheit ein Update zu machen.

$ sudo apt-get update

Dann werden noch die Android Debug Bridge, fastboot und das Ubuntu Device-Flash Paket installiert:

$ sudo apt-get install android-tools-adb android-tools-fastboot ubuntu-device-flash

Und Jetzt geht es zur Sache: Am Android Device muss natürlich USB-Debugging aktiviert sein, die hoffentlich erfolgreiche Verbindung kann man per adb prüfen. Nach einem Start in den Bootloader kann dieser mit …

$ sudo fastboot oem unlock

… entsperrt werden. Das war in meinem Fall nicht nötig, denn das Device hatte bereits CyanogenMod mit einem offenen Bootloader drauf.
Nach einem Neustart mit …

$ sudo fastboot reboot-bootloader

… kann das Flashen beginnen:

$ ubuntu-device-flash --channel=stable --bootstrap

Nach etwa 15 Minuten war das Flashen (aktuell „stable“ ist die Version 14.09) erledigt und das Gerät startete neu.

Erster Start nach erfolgreichem Flashen

Erster Start nach erfolgreichem Flashen.

Sprachauswahl, WLAN konfigurieren, Fertig!

Und jetzt? Jetzt muss ich mich an das Bedienkonzept gewöhnen: Alles geht mit Gesten, die auf Android üblichen Buttons gibt es nicht …

Und dann werde ich mal checken, was man sonst noch alles damit machen kann: ssh, apache, ev. node.js?

Terminal mit root access.

Terminal mit root access

Mal sehen …

Cheater ausgesperrt …

Das Problem beschäftigte Betreiber von (sha256 und quark) Mining Portalen monatelang: Die „fake hash vulnerability“. Damit konnte jemand, der einigermassen erfahren mit Kryptowährungen, Linux, Python, Stratum-Mining etc. ist, Mining Portale, die mit der gängigsten Software Version arbeiteten, betrügen. D.h. Shares uploaden, die nur durch Software generiert wurden und eine extrem hohe „Difficulty“ vorspiegeln. Eine Difficulty, die ausschliesslich mit spezieller Hardware erreicht werden kann.

Nach ein paar nächtlichen Recherchen, Debug Sessions und Tests an einigen Echtsystemen konnte ich den (eigentlich recht banalen) Fehler finden …

Und natürlich auch beheben und die Community informieren: https://github.com/Crypto-Expert/stratum-mining/issues/353

Recht interessant, wie ein „kleiner“ Bug in ein System einen Fehlerfaktor von 65535 hineinbringt. Traurig hat mich aber gemacht, dass der Entwickler sich mit „… habe ich eh gewusst … sah aber keinen Grund, das zu fixen …“ äusserte. Tja.

Jedenfalls können durch diesen Fix Cheater, die Kryptowährungen in unbekannter Höhe abgegriffen haben von den Stratum Servern automatisch erkannt und ausgesperrt werden.

Wie geht es weiter? Der Nachfolger von stratum-mining ist UNOMP. Schaue ich mir auch mal an. UNOMP bzw. die Vorgängerversion NOMP und diverse Forks davon werden weltweit x 100 oder 1000 mal eingesetzt.

Uiiii … der nächste Kandidat.

C2coin – Windows Wallet

Das C2coin Netz läuft jetzt seit einigen Tagen problemlos. Es wurde also Zeit, dass ich mich auch um eine Windows-Version der Software kümmere.

Diverse Recherchen im Web ergaben, dass das Compilieren der Binaries für Windows eine ziemliche Herausforderung darstellen soll. Und so war es auch …

Es dauerte mehrere Stunden, bis ich mich mit den beteiligten Komponenten halbwegs anfreunden konnte:

  • Die „Toolchain“ (Entwicklungsumgebung): MinGW, MSYS und Qt mit qmake, mingw32-make, G++ C-Compiler usw.
  • Die „Dependencies“ (notwendige Libraries): Berkeley-DB, Openssl und die Boost-Library.

Einige Stunden (und Fehlversuche) später war es dann soweit: Sowohl die „headless“ Version (c2coind.exe), als auch die GUI-Version (c2coin-qt.exe) wurden fehlerfrei übersetzt.

C2coin Windows Wallet

C2coin Windows Wallet

War jedenfalls eine interessante Herausforderung …

Downloads: Wallet für WindowsCoindeamon für Windows
Installation/Konfiguration: Readme
Kurzanleitung Mining mit Grafikkarten: Mining with GPUs

C2coin – meine eigene Kryptowährung

Mit Kryptowährungen beschäftige ich mich ja schon einige Zeit, irgendwann ist die Idee aufgekommen, auch eine „eigene“ zu entwerfen. Und es sollte natürlich wirklich eine eigene Coin werden und nicht nur ein Plagiat aus einem Altcoingenerator …

Also ging es ans Festlegen der Parameter, das Klonen des Litecoin Codes, Aufsetzen der Entwicklungsumgebung, Bearbeiten des Sourcecodes und schließlich ans Generieren des „Merkle-Hashes“, die Basis für das Erstellen (Mining) des „Genesis-Blocks“ – der Anfang einer neuen Blockchain.

In den Genesis-Block wird üblicherweise eine Information eingetragen, die am Tag der „Geburt“ eines Coins in den Medien zu finden war. Ich fand diese Meldung der Tageszeitung „Der Standard“ interessant:

Ausschnitt aus dem Genesis-Block

Ausschnitt aus dem Genesis-Block

Das Erstellen der Binaries unter Linux ging dann recht problemlos von der Hand, die Binaries unter Windows zu compilieren ist eine andere Geschichte, davon werde ich noch berichten …

GUI-Wallet unter Linux

GUI-Wallet unter Linux

Wozu das Ganze? Einerseits wollte ich einfach wissen, ob ich es kann. Darüber hinaus sehe ich es als Plattform für zukünftige Entwicklungen (z.B. proof-of-concepts) für Module im „Cryptocoin Ökosystem“ …

Der Code des Projektes ist auf Github zu finden.

Online QR-Code Generator

Die Open Source Library PHP QR Code hatte ich schon in einigen Projekten in Verwendung. Jetzt habe ich sie mit einem GUI ausgestattet, mit dem man folgende Parameter setzen kann:

  • Level der Fehlerkorrektur (Rekonstruktion von 7% bis 30% beschädigter Daten)
  • Größe des QR-Codes in „Pixels per Point“ (Point entspricht einem Punkt des QR-Codes)
  • Größe des Rahmens in Points
  • Transparenz des Hintergrundes
Screenshot QR-Generator

Screenshot QR-Generator

Der QR-Code wird in PNG-Format generiert, zusätzlich werden die Rohdaten („Points“) in Textform ausgegeben.

Der Generator ist unter http://multidec.web-lab.at/qr/ zu erreichen, mein Fork ist auf GitHub.

Für weitere Projekte (Online- oder Offline Generierung von QR-Codes, Integration in Applikationen etc.) stehe ich gerne zur Verfügung.

Bitcoin Zahlungen über Coinbase

Seit 11.9.2014 ist die in den USA populäre Bitcoin-Plattform Coinbase auch in 13 europäischen Ländern, darunter auch Österreich, verfügbar (die Futurezone berichtete darüber).

Das habe ich zum Anlass genommen, mir die Möglichkeiten der Integration des Payment-APIs von Coinbase anzusehen und praktisch auszuprobieren (visit link).

coinbase_demo

Ich werde noch weitere Varianten erproben und in das Demo aufnehmen.

Stay tuned!

„MoWi“ – MObile WalletInfo

Ein Tool für alle, die mehrere Cryptocoin-Wallets (Bitcoin, Litecoin etc.) am Laufen haben und die Übersicht behalten wollen … und zwar immer und überall.

Funktionsweise: Ein Serverscript (PHP) verbindet sich zu den (im LAN erreichbaren) konfigurierten Wallets, frägt über die RPC API-Calls „getinfo“ und „getmininginfo“ die Daten ab und stellt sie auf einer mobilen Webseite (mit jQuery Mobile) zur Verfügung.

Screenshot_2014-09-30-12-26-17 Screenshot_2014-09-30-12-26-26

Der Zugriff auf diese Daten kann z.B. mit https und Userauthentifizierung geschützt werden. Das Tool ist im derzeit im Testbetrieb.

Offline Wallet für eMark

Gemeinsam mit den Entwicklern der Cryptowährung DEM (Deutsche eMark) wurde ein Offline-Wallet erstellt („geforkt“), welches ich unter coinz.at/emark-offlinewallet/ betreibe.

dem-offlinewallet

Damit können e-Mark Adressen und deren private Schlüssel sicher (weil clientbasiert) generiert und als QR-Codes ausgedruckt werden, eine Voraussetzung für die sichere Aufbewahrung von Cryptocoins („cold storage“). Auch die Erstellung der Schlüsselpaare aus Passwörtern („Brainwallet“) ist damit möglich.

Liebe Grüße an die eMark Community an dieser Stelle 🙂

ÖRAG Immobilien App jetzt mit POIs aus data.gv.at

Die „ÖRAG Immobiliensuche“ ist als App für Android und iOS seit letztem Jahr erfolgreich auf dem Markt.
In der neuen Release wurde die Darstellung von POIs integriert, d.h. ein Immobiliensuchender kann sich komfortabel über die Umgebung seiner (zukünftigen) Immobilie informieren.

Die POIs stammen aus „data.gv.at – offene Daten Österreichs“ – http://www.data.gv.at/.
Sie umfassen: Öffentlicher Verkehr, Schulen, Kindergärten, Universitäten, Krankenhäuser, Parks, Märkte, Polizeistationen etc.

OGD-POIs_Android

Die Daten werden periodisch von den OGD-Servern geladen, vorverarbeitet und für die Apps auf einem eigenen Server zur Verfügung gestellt.

Das Projekt wurde für die ÖRAG Österreichische Realitäten-AG in Zusammenarbeit mit Artware Multimedia GmbH und Christoph Lederer abgewickelt.

Das App gibt es im Apple App Store und im Google Play Store.

Update 11/2016: Die App ist übrigens auch als Anwendung am Portal „data.gv.at – offene Daten Österreichs“ verlinkt:  https://www.data.gv.at/anwendungen/oerag-immobiliensuche/