Note |
---|
Om review makkelijker te maken werden de wijzigingen tegenover ICRv2 als volgt in de tekst duidelijk gemaakt:
|
Wat is het?
Bij een penetratietest vraag je een tester om kwetsbaarheden van een bepaalde toepassing te onderzoeken. Dit gebeurt met een vooraf bepaalde scope: welk(e) (deel van een) toepassing moet de tester benaderen en met welke aanvalsvectoren. Deze testen gebeuren in principe altijd in de productieomgeving.
Het kan hierbij een toegevoegde waarde zijn om te werken met een gecertificeerde tester. Wat echter belangrijker is, is dat er duidelijke afspraken zijn over testscenario’s en de modaliteiten van de tets (scope, aanvalsvectoren, timing, etc.).
Een penetratietest is het strikte minimum dat je kunt en moet doen aan veiligheidstesten. Deze test gaat heel wat kwetsbaarheden opvangen die de hierboven beschreven testen ook identificeren. Het is geen 1-op-1 vervanging ervan en het is een kostelijkere manier om hetzelfde te bereiken. Hoe vroeger je kwetsbaarheden identificeert, hoe makkelijker en goedkoper je ze kunt oplossen. Dit doe je door security (en bij uitbreiding privacy) standaard in je design mee te nemen – algemeen heet dit Security/Privacy by Design. Dit concept en hoe je dit kunt meenemen in je levenscyclus, staat ook beschreven in het Beleidsdocument “Ontwikkeling en gebruik van toepassingen”.
In welke omgeving doe je penetratietesten?
Als de acceptatieomgeving op exact dezelfde manier is ingericht als de productieomgeving, kan een penetratietest gebeuren in de acceptatieomgeving vóór een gewijzigde toepassing live gaat. Dit geldt dan enkel voor testen in het kader van een wijziging
Penetratie testen doe je sowieso (ook) in de productieomgeving. Om de mogelijke impact te beperken, kun je de timing wel zo voorzien dat het niet conflicteert met piekmomenten (bijvoorbeeld in een weekend, niet bij een maandafsluiting).
Wat te doen?
Er zijn drie soorten tests die je kunt doen:
“White box”: hierbij heeft de tester informatie over de manier waarop de toepassing is geïmplementeerd en over de interne werking van de organisatie (architectuur, organigram, etc.)
“Black box”: hierbij heeft de tester in principe geen, of bijna geen informatie over de toepassing of de organisatie
“Grey box”: hierbij krijgt de tester een deel van de informatie, maar niet zoveel als bij een white box
Bij het testen houd je rekening met een bepaalde scope. In het zoeken naar mogelijke kwetsbaarheden, moet de penetration tester minstens rekening houden met deze aanvalsvectoren, kwetsbaarheden en technieken:
De OWASP top 10 kwetsbaarheden
(D)DoS paraatheid - distributed reflective denial-of-service (DRDoS)
Brute force attacks (credential stuffing, password spraying, multi-factor authentication bypass)
Memory management flaw attacks (use after free, race conditions, buffer overflow)
Check tegen gekende CVE reports
Credential hunting (default passwoorden, hardgecodeerde gebruikersnamen of wachtwoorden, API key hunting, hardgecodeerde tokens)
Downgrade attacks (gebruik maken van verouderde protocollen)
Exploit servers
Input validation
Privilege escalation
Zoeken naar niet-ondersteunde versies van programma’s of systemen
Supply chain attacks
Dit is een overzicht van de verschillende termijnen die je moet respecteren voor het uitvoeren van de tests en het remediëren van ontdekte kwetsbaarheden. Het zegt ook welk soort test je kunt uitvoeren in de gegeven context.
Hoedanigheid/ | Frequentie | Kritische, Significante | Gemiddelde en | Kleine risico kwetsbaar-heden oplossen binnen | Soort test |
---|---|---|---|---|---|
Toepassingen die | Bij de release van een | 2 werkweken | 4 werkweken | Opnemen in een volgende release | Black box |
Klasse 3, 4 en 5 (Vertrouwelijkheid en/of | Bij de release van een | 2 werkweken | 4 werkweken | Opnemen in een volgende release | Black box |
Klasse 1 en 2 | Minstens 1 keer per jaar | 4 werkweken | 6 werkweken | Opnemen in een volgende release | Grey box |
Je maakt een risico-afweging van de gevonden kwetsbaarheden. Hierbij hou je rekening met het feit of een toepassing naar het internet ontsloten is. Als deze toepassingen kwetsbaarheden hebben, los je deze altijd prioritair op en dit ongeacht hun informatieclassificatie. De gegeven termijnen zijn maxima. Je kunt dus bijvoorbeeld een “fix” in een volgende release van je toepassing integreren, zolang deze binnen de verwachte oplostermijn past. Het streefdoel is dat je zoveel mogelijk kwetsbaarheden oplost in de mate van hetfinancieel/projectmatig haalbare volgens het hierboven beschreven schema. Als er na de remediëring nog rest-risico’s zijn, moet de toepassingsbeheerder deze formeel laten aanvaarden door het top management, zoals beschreven staat in https://vlaamseoverheid.atlassian.net/wiki/x/R5MHpwE . Na het oplossen van kwetsbaarheden, moet je altijd een nieuwe test doen om er zeker van te zijn dat de kwetsbaarheden in productie opgelost zijn
Welke tools?
Bij voorkeur gebeurt deze test door een gecertifieerd tester. Deze tester kan zelf bepalen welke tools nodig zijn om het gewenste resultaat te behalen
Dit is een dienst die de Vlaamse overheid op dit moment alleen inkoopt en waarvoor geen interne medewerkers voorzien zijn
Dit is een dienst die je kunt afnemen binnen het raamcontract
Scope?
Alle online toepassingen
Alle websites
Alle intern ontsloten toepassingen (enkel toegankelijk voor geauthenticeerde gebruikers op het Vlaamse overheid-netwerk)
Dit kan gaan om toepassingen of websites in eigen beheer, die van de centrale dienstverlening,of die bij een leverancier
Opgelegde beperkingen?
Penetratietesten dienen net zoals de vulnerability scans zorgvuldig te worden uitgevoerd om de veiligheid van systemen te testen zonder de operationele werking in gevaar te brengen. Deze testen mogen op geen enkel moment de primaire systeemfuncties verstoren. De stabiliteit, beschikbaarheid en prestaties van de systemen moeten te allen tijde gewaarborgd blijven.
Bij penetratietesten, die standaard op afstand worden uitgevoerd, moeten de nodige voorzorgsmaatregelen worden getroffen om datalekken te voorkomen, met name wanneer er gevoelige gegevens worden verwerkt. Dit houdt in dat:
Alle gegevens die tijdens de test worden verwerkt, versleuteld moeten zijn.
Toegang tot systemen en gevoelige informatie strikt beperkt wordt tot geautoriseerde testers.
Log- en monitoringsystemen ingezet worden om ongeautoriseerde toegang te detecteren en te voorkomen.
Penetratietesten buiten piekuren plaatsvinden om de impact op de operationele continuïteit te minimaliseren.
De resultaten van penetratietesten moeten vertrouwelijk worden behandeld, en er moet een duidelijke follow-upstrategie zijn voor het aanpakken van gedetecteerde kwetsbaarheden zonder de dagelijkse werking van het systeem te verstoren.