PowerShellを使用して現在のAdvanced Security Audit Policyを取得します。私はauditpol.exe
を使うことができましたが、その出力はOS言語ごとに異なり、解析が困難です。PowerShellでWindows API AuditEnumerateCategories関数を使用するには?
settingsは、HKEY_Local_Machine\Security\Policy\PolAdtEv
のREG_NONE値に格納されます。私はthat unofficial structure tableの助けを借りて値を解析しようとする可能性があります。しかし、私の考えているアプローチは、Windows API関数AuditQuerySystemPolicy
をadvapi32.dll
にすることです。
thisの大きな助けを得て、PowerShellでTypeを次のように作成しました。
$MemberDefinition = @'
[DllImport("advapi32.dll", SetLastError = true)]
public static extern bool AuditEnumerateCategories(
out IntPtr ppAuditCategoriesArray,
out uint pCountReturned);
[DllImport("advapi32.dll", SetLastError = true)]
public static extern bool AuditLookupCategoryName(
ref Guid pAuditCategoryGuid,
out StringBuilder ppszCategoryName);
[DllImport("advapi32.dll", SetLastError = true)]
private static extern bool AuditEnumerateSubCategories(
ref Guid pAuditCategoryGuid,
bool bRetrieveAllSubCategories,
out IntPtr ppAuditSubCategoriesArray,
out uint pCountReturned);
[DllImport("advapi32.dll", SetLastError = true)]
public static extern bool AuditLookupSubCategoryName(
ref Guid pAuditSubCategoryGuid,
out StringBuilder ppszSubCategoryName);
[DllImport("advapi32.dll")]
public static extern void AuditFree(
IntPtr buffer);
[DllImport("advapi32.dll", SetLastError = true)]
public static extern bool AuditQuerySystemPolicy(
Guid pSubCategoryGuids,
uint PolicyCount,
out IntPtr ppAuditPolicy);
'@
$Advapi32 = Add-Type -MemberDefinition $MemberDefinition -Name 'Advapi32' -Namespace 'Win32' -UsingNamespace System.Text -PassThru
タイプはsuccessfuly作成されますが、私は最初の段階で失敗している - すべての監査カテゴリのGUIDを取得します。私はさまざまな種類の問題があります。私はまた、IntPtr
からGuid
にAuditEnumerateCategories
精細出力を変更しようとした例えば
$guid = [Guid].MakeByRefType()
$count = [IntPtr]::Zero
[Win32.Advapi32]::AuditEnumerateCategories([ref]$guid, [ref]$count)
# Exception calling "AuditEnumerateCategories" with 2 Arguments: "The value "System.Guid&" of the type "System.RuntimeType" cannot be coverted to "System.IntPtr".
を試してみました。 ppAuditCategoriesArray
の出力は
GUID構造体へのポインタの配列と構造体自体の両方を含む単一のバッファへのポインタです。
残念ながら、私は残念ながら、PowerShellでこれをどのように処理するかについてはわかりません。
と、 $ count = [System.Int64] 0'の場合、 'AuditEnumerateCategories'メソッドはそれぞれ(' $ MemberDefinition'で宣言されているように) 'IntPtr'と' Int32'の値を返します。 – JosefZ
あなたはこれを解決しましたか? –
さて、@ JosefZの助けを借りて、私は今、 '$ count'に正しいカウント番号を、' $ guid'にいくつかの番号を持っています。しかし、私はまだこれからGUIDを取得することはできませんでした。 – vrdse