De root van het probleem/certificaat
2024/09/01
Jeroen Hermans
Certificaten… Een mooie technologie om identiteit vast te stellen en om betrouwbare encryptie tussen twee partijen op te zetten. Maar het blijkt in de praktijk keer op keer een moeilijk onderwerp te zijn.
“Jeroen, ik denk dat je eens met mij mee moet kijken.”. Het is een conculega van mij die mij op een regenachtige middag in april 2023 belt. Het zijn juist deze telefoontjes waar je vooraf niet van weet waar het op uit gaat lopen. En juist dit telefoontje blijkt uiteindelijk te leiden tot een CVE met een cvss van 9.8!
De man die mij belt is actief bij de lokale tennisvereniging en is in die hoedanigheid ook betrokken bij de installatie
van een nieuw toegangssysteem, compleet met pasjes. Tijdens het installeren van dit systeem is het de bedoeling dat
er beheerssoftware voor het systeem geïnstalleerd wordt op de computer van diegene die verantwoordelijk is voor
de beveiliging. Het lijkt een logische stap te zijn, maar…ook een gevoelige plek om software te installeren.
We hebben in de afgelopen jaren verschillende gevallen gezien waar supplychain attacks gevoelige plekken blootstelden
aan onnodige gevaren. In dit geval gaat het om een gebouwtoegangssysteem van
Paxton
.
Paxton is een firma die zichzelf omschrijft als een “toonaangevende fabrikant van elektronische toegangscontrole, video management en deurintercom systemen”, waarbij zij “een optimale beveiliging van uw gebouwen, medewerkers en bezittingen” leveren. Dat klinkt als een mooie ambitie. En die ambitie maken zij waar bij klanten die ik toch wel onder gevoelige objecten reken. Denk hierbij aan
- Lake County Jail, Ohio, USA (offline gehaald voor onbekende reden)
- Cannabis facility, Michigan, USA
- Gelredome
- Old Trafford stadium Manchester
- Internet Provider Trined
- KNVB Campus
- Brandweer Midden- en West-Brabant
- SBS Broadcasting
- Studio’s Aalsmeer
- Endemol Producties Londen
- Sky Deutschland
- Loodswezen
- Cherbourg Airport
- DHL
- Mariaziekenhuis Overpelt
Het zou natuurlijk bijzonder ongewenst zijn als een beveiligingsprobleem zou optreden in een van deze lokaties. Het zijn
juist deze mooie referenties die mij doen besluiten om eens goed naar het
NET2
systeem van Paxton te gaan kijken.
De software die de beveiligingsbeheerder moet installeren vraagt om een certificaat te installeren.
Nadere inpectie van dit scherm laat zien dat het gaat om een root-certificaat van Paxton wat in de trust-store van de
pc geïnstalleerd wordt.
Echter wat blijkt: Paxton heeft dit certificaat al in de truststore geïnstalleerd, om de installatie zo “eenvoudig”
mogelijk te maken. We zitten nu in de situatie waar een third-party een root certificaat heeft geïnstalleerd zonder
het de beheerder van deze (vertrouwelijke?) pc te vertellen.
En dit certificaat is nog een kleine 20 jaar geldig. Niet ideaal…ook niet netjes…ook niet industrie standaard.
Ik heb eerder gepubliceerd over certificaten in het artikel over Let’s Encrypt
Het zou veel erger zijn als dit certificaat nu gebruikt
zou kunnen worden om zelf Man In The Middle (MITM) aanvallen uit te voeren. Op deze manier zou het eenvoudig zijn om
(gevoelige) gegevens in te zien die verstuurd worden vanaf de pc van de persoon die verantwoordelijk is voor de
fysieke beveiliging van de eerder genoemde objecten.
Maar: hier is een private key voor nodig. En die hoort ten alle tijden geheim te blijven. Een korte inspectie van
C:\Program Files (x86)\Paxton Access\Access Control\openssl laat de volgende twee bestanden zien:
- Paxton-CA.crt
- Paxton-CA.key
Het probleem begint zich nu wel een beetje af te tekenen. Het zal toch niet…?
Maar: de private key in Paxton-CA.key is versleuteld en kan dus niet direct gebruikt worden om zelf certificaten
uit te geven. Maar wacht eens even. Waarom kan createdevicecert.bat dat eigenlijk wel dan? Ik besluit de volgende regel
toe te voegen aan dit batch bestand:
echo %2 > private.pass
Het klinkt te eenvoudig voor woorden, maar: na het opnieuw aanmaken van een certificaat voor de Net2 software heb ik een bestand private.pass met als inhoud: “COpKEyfArEs*****” (gecensureerd). Het is nu inmiddels wel duidelijk dat we hier een serieus probleem hebben en ik neem contact op met Paxton in de UK. Nog voordat ik mijn verhaal heb kunnen doen, ben ik gegoogled en word ik naar de Nederlandse tak van Paxton verwezen. Ik leg mijn bevindingen uit aan de medewerker in Nederland en hij geeft aan dat Paxton Nederland alleen een sales-tak is en dat ik bij Paxton UK moet zijn waar de ontwikkelaars zitten. Ik word teruggestuurd naar Paxton UK en leg mijn bevindingen daar neer. Ik krijg van de technische afdeling echter het teleurstellende antwoord dat het geen security probleem is, omdat het certificaat alleen in interne netwerken gebruikt kan worden. Ik besluit te antwoorden met een eenvoudige vraag: Kunnen jullie uitleggen hoe jullie voorkomen dat het certificaat niet gebruikt wordt voor een ip-adres buiten het interne netwerk?
Het antwoord laat heel even op zich wachten, waarna het kwartje in de UK ook gevallen lijkt te zijn:
Paxton were not aware of the extent of this vulnerability, thank you for bringing this to our attention.
We would very much like to discuss our plan of actions with you directly and would welcome your input/feedback on how to resolve this issue.
Kijk… dit had natuurlijk nooit mogen gebeuren, maar deze firma graaft zich zelf niet vast in dit gebeuren. En inderdaad: na wat telefoontjes en overleggen wordt een concreet mitigatieplan opgesteld en krijg ik inderdaad elke paar weken een update van de vorderingen hiervan. Door de grote userbase duurt dit proces vrij lang, maar het wordt wel heel serieus opgepikt.
Als goed burger besluit ik ook het
National Cyber Security Centre (NCSC)
te contacteren. Ik krijg een net mailtje terug dat het
wellicht goed is om met PGP te gaan communiceren en of ik een PGP sleutel heb. Uiteraard heb ik die en ik stuur mijn
publieke sleutel naar het NCSC op.
Ik krijg een email terug dat het NCSC geen elliptic curve sleutels kan importeren en of ik een nieuwe RSA sleutel wil
maken. Aangezien mijn sleutel gepubliceerd is bedank ik vriendelijk en besluit ik om verdere communicatie dan maar
zonder PGP te gaan voeren.
Het heeft wederom even wat overredingskracht nodig om de ernst van dit probleem duidelijk te maken. Om het probleem iets
duidelijker te maken maak ik een (geldig) *.rijksoverheid.nl certificaat aan wat ondertekend is met het, vertrouwde,
Paxton root certificaat.
Nu het een Rijksoverheid probleem is gebeurt er ineens van alles. Er wordt communicatie met Paxton UK gevoerd en een CVE nummer wordt gereserveerd. Ik beloof plechtig aan het NCSC om het wildcard certificaat voor rijksoverheid.nl niet te misbruiken of door te sturen.
In de communicatie met het NCSC heeft Paxton aan dat zij het geen heel belangrijke vulnerability vinden.
In my opinion I think it is a medium vulnerability. My rationale or view point is that it is widely documented how to add a root certificate to your local trusted store and how to spoof certificates. There are documented case studies of this happening at country level, one of which was in the Netherlands and the other was in China.
Maar als de CVE een tijdje later gepubliceerd wordt is duidelijk dat het toonaangevende Amerikaanse NIST het hier niet mee eens is. Zij kennen dan ook een CVSS van 9.8 (critical) aan de vulnerability toe.
Dit probleem leek zo eenvoudig: er is een geheime sleutel meegeleverd met een kritisch stuk software wat zelfs in gevangenissen gebruikt wordt. Maar het blijkt in de praktijk dan toch nog heel lastig te zijn om de betrokken partijen hiervan te overtuigen. Dit bleek in dit geval een proces van maanden. Maar wel een proces met een hele fijne uitkomst, waar de fabrikant uiteindelijk een beter en veiliger product heeft gemaakt. Uiteraard heb ik een aantal maanden later hun software weer onder de loupe genomen. Ook dit keer kwam hier een interessante bevinding uit, maar daar ga ik een volgende keer over schrijven. Tot dan!