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 }