github.com/iDigitalFlame/xmt@v0.5.4/examples/example_drivers.go (about)

     1  //go:build windows
     2  // +build windows
     3  
     4  // Copyright (C) 2020 - 2023 iDigitalFlame
     5  //
     6  // This program is free software: you can redistribute it and/or modify
     7  // it under the terms of the GNU General Public License as published by
     8  // the Free Software Foundation, either version 3 of the License, or
     9  // any later version.
    10  //
    11  // This program is distributed in the hope that it will be useful,
    12  // but WITHOUT ANY WARRANTY; without even the implied warranty of
    13  // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    14  // GNU General Public License for more details.
    15  //
    16  // You should have received a copy of the GNU General Public License
    17  // along with this program.  If not, see <https://www.gnu.org/licenses/>.
    18  //
    19  
    20  package main
    21  
    22  import (
    23  	"fmt"
    24  
    25  	"github.com/iDigitalFlame/xmt/device/winapi"
    26  )
    27  
    28  func exampleSignedDrivers() {
    29  	err := winapi.EnumDrivers(func(h uintptr, s string) error {
    30  		v, err := winapi.FileSigningIssuerName(s)
    31  		if err != nil || len(v) == 0 {
    32  			return nil
    33  		}
    34  		switch winapi.FnvHash(v) {
    35  		case 0x1FB166BC: // Microsoft Windows
    36  			fallthrough
    37  		case 0x4C18C11F: // Microsoft Windows Hardware Abstraction Layer Publisher
    38  			return nil
    39  		}
    40  		fmt.Printf("Unsigned/non-MS: 0x%X: %s [%s]\n", h, s, v)
    41  		return nil
    42  	})
    43  	if err != nil {
    44  		panic(err)
    45  	}
    46  
    47  	fmt.Println(winapi.IsSecureBootEnabled())
    48  	fmt.Println(winapi.GetCodeIntegrityState())
    49  }