Win32 API 日本語リファレンス
ホームSecurity.Cryptography.Certificates › PstGetCertificateChain

PstGetCertificateChain

関数
指定証明書と信頼発行者から証明書チェーンを構築して取得する。
DLLcertpoleng.dll呼出規約winapi

シグネチャ

// certpoleng.dll
#include <windows.h>

NTSTATUS PstGetCertificateChain(
    const CERT_CONTEXT* pCert,
    SecPkgContext_IssuerListInfoEx* pTrustedIssuers,
    CERT_CHAIN_CONTEXT** ppCertChainContext
);

パラメーター

名前方向説明
pCertCERT_CONTEXT*inチェーンを構築する起点となる証明書のCERT_CONTEXTへのポインタ。
pTrustedIssuersSecPkgContext_IssuerListInfoEx*in信頼された発行者リストを示す構造体へのポインタ。チェーン構築の基準とする。
ppCertChainContextCERT_CHAIN_CONTEXT**out構築された証明書チェーンコンテキストへのポインタを受け取る出力ポインタ。

戻り値の型: NTSTATUS

各言語での呼び出し定義

// certpoleng.dll
#include <windows.h>

NTSTATUS PstGetCertificateChain(
    const CERT_CONTEXT* pCert,
    SecPkgContext_IssuerListInfoEx* pTrustedIssuers,
    CERT_CHAIN_CONTEXT** ppCertChainContext
);
[DllImport("certpoleng.dll", ExactSpelling = true)]
static extern int PstGetCertificateChain(
    IntPtr pCert,   // CERT_CONTEXT*
    IntPtr pTrustedIssuers,   // SecPkgContext_IssuerListInfoEx*
    IntPtr ppCertChainContext   // CERT_CHAIN_CONTEXT** out
);
<DllImport("certpoleng.dll", ExactSpelling:=True)>
Public Shared Function PstGetCertificateChain(
    pCert As IntPtr,   ' CERT_CONTEXT*
    pTrustedIssuers As IntPtr,   ' SecPkgContext_IssuerListInfoEx*
    ppCertChainContext As IntPtr   ' CERT_CHAIN_CONTEXT** out
) As Integer
End Function
' pCert : CERT_CONTEXT*
' pTrustedIssuers : SecPkgContext_IssuerListInfoEx*
' ppCertChainContext : CERT_CHAIN_CONTEXT** out
Declare PtrSafe Function PstGetCertificateChain Lib "certpoleng" ( _
    ByVal pCert As LongPtr, _
    ByVal pTrustedIssuers As LongPtr, _
    ByVal ppCertChainContext As LongPtr) As Long
' VBA7前提(PtrSafe)。32bit Office では LongPtr→Long。Integer=16bit / Long=32bit / LongLong=64bit。
import ctypes
from ctypes import wintypes

PstGetCertificateChain = ctypes.windll.certpoleng.PstGetCertificateChain
PstGetCertificateChain.restype = ctypes.c_int
PstGetCertificateChain.argtypes = [
    ctypes.c_void_p,  # pCert : CERT_CONTEXT*
    ctypes.c_void_p,  # pTrustedIssuers : SecPkgContext_IssuerListInfoEx*
    ctypes.c_void_p,  # ppCertChainContext : CERT_CHAIN_CONTEXT** out
]
require 'fiddle'
require 'fiddle/import'

lib = Fiddle.dlopen('certpoleng.dll')
PstGetCertificateChain = Fiddle::Function.new(
  lib['PstGetCertificateChain'],
  [
    Fiddle::TYPE_VOIDP,  # pCert : CERT_CONTEXT*
    Fiddle::TYPE_VOIDP,  # pTrustedIssuers : SecPkgContext_IssuerListInfoEx*
    Fiddle::TYPE_VOIDP,  # ppCertChainContext : CERT_CHAIN_CONTEXT** out
  ],
  Fiddle::TYPE_INT)
#[link(name = "certpoleng")]
extern "system" {
    fn PstGetCertificateChain(
        pCert: *const CERT_CONTEXT,  // CERT_CONTEXT*
        pTrustedIssuers: *mut SecPkgContext_IssuerListInfoEx,  // SecPkgContext_IssuerListInfoEx*
        ppCertChainContext: *mut *mut CERT_CHAIN_CONTEXT  // CERT_CHAIN_CONTEXT** out
    ) -> i32;
}
// crates: windows-sys provides ready-made bindings for this API.
$sig = @"
[DllImport("certpoleng.dll")]
public static extern int PstGetCertificateChain(IntPtr pCert, IntPtr pTrustedIssuers, IntPtr ppCertChainContext);
"@
$api = Add-Type -MemberDefinition $sig -Name 'certpoleng_PstGetCertificateChain' -Namespace Win32 -PassThru
# $api::PstGetCertificateChain(pCert, pTrustedIssuers, ppCertChainContext)
#uselib "certpoleng.dll"
#func global PstGetCertificateChain "PstGetCertificateChain" sptr, sptr, sptr
; PstGetCertificateChain varptr(pCert), varptr(pTrustedIssuers), varptr(ppCertChainContext)   ; 戻り値は stat
; pCert : CERT_CONTEXT* -> "sptr"
; pTrustedIssuers : SecPkgContext_IssuerListInfoEx* -> "sptr"
; ppCertChainContext : CERT_CHAIN_CONTEXT** out -> "sptr"
; ※HSP3.7は #func のため戻り値はシステム変数 stat に格納されます。
出力引数:
#uselib "certpoleng.dll"
#cfunc global PstGetCertificateChain "PstGetCertificateChain" var, var, var
; res = PstGetCertificateChain(pCert, pTrustedIssuers, ppCertChainContext)
; pCert : CERT_CONTEXT* -> "var"
; pTrustedIssuers : SecPkgContext_IssuerListInfoEx* -> "var"
; ppCertChainContext : CERT_CHAIN_CONTEXT** out -> "var"
; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。
出力引数:
; NTSTATUS PstGetCertificateChain(CERT_CONTEXT* pCert, SecPkgContext_IssuerListInfoEx* pTrustedIssuers, CERT_CHAIN_CONTEXT** ppCertChainContext)
#uselib "certpoleng.dll"
#cfunc global PstGetCertificateChain "PstGetCertificateChain" var, var, var
; res = PstGetCertificateChain(pCert, pTrustedIssuers, ppCertChainContext)
; pCert : CERT_CONTEXT* -> "var"
; pTrustedIssuers : SecPkgContext_IssuerListInfoEx* -> "var"
; ppCertChainContext : CERT_CHAIN_CONTEXT** out -> "var"
; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。
import (
	"golang.org/x/sys/windows"
	"unsafe"
)

var (
	certpoleng = windows.NewLazySystemDLL("certpoleng.dll")
	procPstGetCertificateChain = certpoleng.NewProc("PstGetCertificateChain")
)

// pCert (CERT_CONTEXT*), pTrustedIssuers (SecPkgContext_IssuerListInfoEx*), ppCertChainContext (CERT_CHAIN_CONTEXT** out)
r1, _, err := procPstGetCertificateChain.Call(
	uintptr(pCert),
	uintptr(pTrustedIssuers),
	uintptr(ppCertChainContext),
)
_ = err  // syscall.Errno (valid when the call sets last-error)
_ = r1   // NTSTATUS
function PstGetCertificateChain(
  pCert: Pointer;   // CERT_CONTEXT*
  pTrustedIssuers: Pointer;   // SecPkgContext_IssuerListInfoEx*
  ppCertChainContext: Pointer   // CERT_CHAIN_CONTEXT** out
): Integer; stdcall;
  external 'certpoleng.dll' name 'PstGetCertificateChain';
result := DllCall("certpoleng\PstGetCertificateChain"
    , "Ptr", pCert   ; CERT_CONTEXT*
    , "Ptr", pTrustedIssuers   ; SecPkgContext_IssuerListInfoEx*
    , "Ptr", ppCertChainContext   ; CERT_CHAIN_CONTEXT** out
    , "Int")   ; return: NTSTATUS
●PstGetCertificateChain(pCert, pTrustedIssuers, ppCertChainContext) = DLL("certpoleng.dll", "int PstGetCertificateChain(void*, void*, void*)")
# 呼び出し: PstGetCertificateChain(pCert, pTrustedIssuers, ppCertChainContext)
# pCert : CERT_CONTEXT* -> "void*"
# pTrustedIssuers : SecPkgContext_IssuerListInfoEx* -> "void*"
# ppCertChainContext : CERT_CHAIN_CONTEXT** out -> "void*"
# なでしこ1は32bit・ANSI(Shift_JIS)。文字列=char*(ANSI)、ポインタ/ハンドル=void*(4byte)。