[RESOLU] Paquets d'audit pour LUKS et FileVault

Questions about WAPT Packaging / Requêtes et aides autour des paquets Wapt.
Règles du forum
Règles du forum communautaire
* English support on www.reddit.com/r/wapt
* Le support communautaire en français se fait sur ce forum
* Merci de préfixer le titre du topic par [RESOLU] s'il est résolu.
* Merci de ne pas modifier un topic qui est taggé [RESOLU]. Ouvrez un nouveau topic en référençant l'ancien
* Préciser version de WAPT installée, version complète ET numéro de build (2.2.1.11957 / 2.2.2.12337 / etc.) AINSI QUE l'édition Enterprise / Discovery
* Les versions 1.8.2 et antérieures ne sont plus maintenues. Les seules questions acceptées vis à vis de la version 1.8.2 sont liés à la mise à jour vers une version supportée (2.1, 2.2, etc.)
* Préciser OS du serveur (Linux / Windows) et version (Debian Buster/Bullseye - CentOS 7 - Windows Server 2012/2016/2019)
* Préciser OS de la machine d'administration/création des paquets et de la machine avec l'agent qui pose problème le cas échéant (Windows 7 / 10 / 11 / Debian 11 / etc.)
* Eviter de poser plusieurs questions lors de l'ouverture de topic, sinon il risque d'être ignorer. Si plusieurs sujet, ouvrir plusieurs topic, et de préférence les uns après les autres et pas tous en même temps (ie ne pas spammer le forum).
* Inclure directement les morceaux de code, les captures d'écran et autres images directement dans le post. Les liens vers les pastebin, les bitly et autres sites tierces seront systématiquement supprimés.
* Comme tout forum communautaire, le support est fait bénévolement par les membres. Si vous avez besoin d'un support commercial, vous pouvez contacter le service commercial Tranquil IT au 02.40.97.57.55
bastien30
Messages : 35
Inscription : 08 mars 2024 - 15:21

07 janv. 2026 - 12:50

Bonjour,

Voici des paquets pour auditer le chiffrement des postes Linux avec LUKS et des postes MacOS avec FileVault.

LUKS :

Code : Tout sélectionner

# -*- coding: utf-8 -*-
from setuphelpers import *

def install():
    pass

def audit():
    audit_result = "OK"

    # Check existing LUKS partitions
    luks_partitions = run(r"lsblk -e7 -n -f -r -o NAME,FSTYPE | grep LUKS | awk '{print $1}'").strip().split("\n")

    if any(luks_partitions):
        # Ensure system partition is encrypted
        system_partition = None
        for luks_partition in luks_partitions:
            try:
                run(r"lsblk /dev/%s -l -o MOUNTPOINTS | grep '^/$'" % luks_partition)
            except:
                pass
            else:
                system_partition = luks_partition
                break

        if not system_partition:
            print(r'Error, system partition is not encrypted !')
            audit_result = "ERROR"
        else:
            # Ensure system partition is valid LUKS partition
            try:
                run(r'cryptsetup isLuks /dev/%s' % luks_partition)
            except:
                print(r'Error, system partition seems encrypted but is not a valid LUKS partition !')
                audit_result = "ERROR"
            else:
                print(r'System partition is encrypted and is a valid LUKS partition')
    else:
        print(r'Error, cannot find any LUKS partition !')
        audit_result = "ERROR"

    return audit_result

FileVault :

Code : Tout sélectionner

# -*- coding: utf-8 -*-
from setuphelpers import *

def install():
    pass

def audit():
    audit_result = "OK"

    filevault_status = run(r'sudo fdesetup status')
    if r'FileVault is On' in filevault_status:
        if r'Encryption in progress' in filevault_status:
            print(r'FileVault is enabled and encryption is in progress.')
        else:
            print(r'FileVault is enabled and disks are fully encrypted.')
    elif r'FileVault is Off' in filevault_status:
        if r'Decryption in progress' in filevault_status:
            print(r'FileVault is not enabled and decryption is in progress !')
        else:
            print(r'FileVault is not enabled and disks are not encrypted !')
        audit_result = "ERROR"
    else:
        print(r'Cannot get FileVault status !')
        audit_result = "ERROR"

    return audit_result
Répondre