Win32 API 日本語リファレンス
ホームNetworking.Ldap › ldap_extended_operation_sA

ldap_extended_operation_sA

関数
OID指定のLDAP拡張操作を同期的に実行する(ANSI版)。
DLLWLDAP32.dll文字セットANSI (-A)呼出規約cdecl対応OSWindows Vista 以降

シグネチャ

// WLDAP32.dll  (ANSI / -A)
#include <windows.h>

DWORD ldap_extended_operation_sA(
    LDAP* ExternalHandle,
    LPSTR Oid,
    LDAP_BERVAL* Data,
    LDAPControlA** ServerControls,
    LDAPControlA** ClientControls,
    LPSTR* ReturnedOid,
    LDAP_BERVAL** ReturnedData
);

パラメーター

名前方向説明
ExternalHandleLDAP*inout対象のLDAPセッションハンドル。拡張操作を発行する接続を指す。
OidLPSTRin実行する拡張操作のOID文字列(ANSI)。操作種別を識別する。
DataLDAP_BERVAL*inout拡張操作に渡すリクエストデータ(berval)。不要ならNULL可。
ServerControlsLDAPControlA**inoutリクエストに付加するサーバサイドコントロール配列。NULL可。
ClientControlsLDAPControlA**inoutリクエストに付加するクライアントサイドコントロール配列。NULL可。
ReturnedOidLPSTR*out応答の拡張操作OID(ANSI)を受け取る出力先。ldap_memfreeで解放。NULL可。
ReturnedDataLDAP_BERVAL**inout応答の拡張操作データ(berval)を受け取る出力先。ber_bvfreeで解放。NULL可。

戻り値の型: DWORD

各言語での呼び出し定義

// WLDAP32.dll  (ANSI / -A)
#include <windows.h>

DWORD ldap_extended_operation_sA(
    LDAP* ExternalHandle,
    LPSTR Oid,
    LDAP_BERVAL* Data,
    LDAPControlA** ServerControls,
    LDAPControlA** ClientControls,
    LPSTR* ReturnedOid,
    LDAP_BERVAL** ReturnedData
);
[DllImport("WLDAP32.dll", CharSet = CharSet.Ansi, ExactSpelling = true, CallingConvention = CallingConvention.Cdecl)]
static extern uint ldap_extended_operation_sA(
    IntPtr ExternalHandle,   // LDAP* in/out
    [MarshalAs(UnmanagedType.LPStr)] string Oid,   // LPSTR
    IntPtr Data,   // LDAP_BERVAL* in/out
    IntPtr ServerControls,   // LDAPControlA** in/out
    IntPtr ClientControls,   // LDAPControlA** in/out
    IntPtr ReturnedOid,   // LPSTR* out
    IntPtr ReturnedData   // LDAP_BERVAL** in/out
);
<DllImport("WLDAP32.dll", CharSet:=CharSet.Ansi, ExactSpelling:=True, CallingConvention:=CallingConvention.Cdecl)>
Public Shared Function ldap_extended_operation_sA(
    ExternalHandle As IntPtr,   ' LDAP* in/out
    <MarshalAs(UnmanagedType.LPStr)> Oid As String,   ' LPSTR
    Data As IntPtr,   ' LDAP_BERVAL* in/out
    ServerControls As IntPtr,   ' LDAPControlA** in/out
    ClientControls As IntPtr,   ' LDAPControlA** in/out
    ReturnedOid As IntPtr,   ' LPSTR* out
    ReturnedData As IntPtr   ' LDAP_BERVAL** in/out
) As UInteger
End Function
' ExternalHandle : LDAP* in/out
' Oid : LPSTR
' Data : LDAP_BERVAL* in/out
' ServerControls : LDAPControlA** in/out
' ClientControls : LDAPControlA** in/out
' ReturnedOid : LPSTR* out
' ReturnedData : LDAP_BERVAL** in/out
Declare PtrSafe Function ldap_extended_operation_sA Lib "wldap32" ( _
    ByVal ExternalHandle As LongPtr, _
    ByVal Oid As String, _
    ByVal Data As LongPtr, _
    ByVal ServerControls As LongPtr, _
    ByVal ClientControls As LongPtr, _
    ByVal ReturnedOid As LongPtr, _
    ByVal ReturnedData As LongPtr) As Long
' VBA7前提(PtrSafe)。32bit Office では LongPtr→Long。Integer=16bit / Long=32bit / LongLong=64bit。
import ctypes
from ctypes import wintypes

ldap_extended_operation_sA = ctypes.cdll.wldap32.ldap_extended_operation_sA
ldap_extended_operation_sA.restype = wintypes.DWORD
ldap_extended_operation_sA.argtypes = [
    ctypes.c_void_p,  # ExternalHandle : LDAP* in/out
    wintypes.LPCSTR,  # Oid : LPSTR
    ctypes.c_void_p,  # Data : LDAP_BERVAL* in/out
    ctypes.c_void_p,  # ServerControls : LDAPControlA** in/out
    ctypes.c_void_p,  # ClientControls : LDAPControlA** in/out
    ctypes.c_void_p,  # ReturnedOid : LPSTR* out
    ctypes.c_void_p,  # ReturnedData : LDAP_BERVAL** in/out
]
require 'fiddle'
require 'fiddle/import'

lib = Fiddle.dlopen('WLDAP32.dll')
ldap_extended_operation_sA = Fiddle::Function.new(
  lib['ldap_extended_operation_sA'],
  [
    Fiddle::TYPE_VOIDP,  # ExternalHandle : LDAP* in/out
    Fiddle::TYPE_VOIDP,  # Oid : LPSTR
    Fiddle::TYPE_VOIDP,  # Data : LDAP_BERVAL* in/out
    Fiddle::TYPE_VOIDP,  # ServerControls : LDAPControlA** in/out
    Fiddle::TYPE_VOIDP,  # ClientControls : LDAPControlA** in/out
    Fiddle::TYPE_VOIDP,  # ReturnedOid : LPSTR* out
    Fiddle::TYPE_VOIDP,  # ReturnedData : LDAP_BERVAL** in/out
  ],
  -Fiddle::TYPE_INT, Fiddle::Function::CDECL)
#[link(name = "wldap32")]
extern "C" {
    fn ldap_extended_operation_sA(
        ExternalHandle: *mut LDAP,  // LDAP* in/out
        Oid: *mut u8,  // LPSTR
        Data: *mut LDAP_BERVAL,  // LDAP_BERVAL* in/out
        ServerControls: *mut *mut LDAPControlA,  // LDAPControlA** in/out
        ClientControls: *mut *mut LDAPControlA,  // LDAPControlA** in/out
        ReturnedOid: *mut *mut u8,  // LPSTR* out
        ReturnedData: *mut *mut LDAP_BERVAL  // LDAP_BERVAL** in/out
    ) -> u32;
}
// crates: windows-sys provides ready-made bindings for this API.
$sig = @"
[DllImport("WLDAP32.dll", CharSet = CharSet.Ansi, CallingConvention = CallingConvention.Cdecl)]
public static extern uint ldap_extended_operation_sA(IntPtr ExternalHandle, [MarshalAs(UnmanagedType.LPStr)] string Oid, IntPtr Data, IntPtr ServerControls, IntPtr ClientControls, IntPtr ReturnedOid, IntPtr ReturnedData);
"@
$api = Add-Type -MemberDefinition $sig -Name 'WLDAP32_ldap_extended_operation_sA' -Namespace Win32 -PassThru
# $api::ldap_extended_operation_sA(ExternalHandle, Oid, Data, ServerControls, ClientControls, ReturnedOid, ReturnedData)
#uselib "WLDAP32.dll"
#func global ldap_extended_operation_sA "ldap_extended_operation_sA" sptr, sptr, sptr, sptr, sptr, sptr, sptr
; ldap_extended_operation_sA varptr(ExternalHandle), Oid, varptr(Data), varptr(ServerControls), varptr(ClientControls), varptr(ReturnedOid), varptr(ReturnedData)   ; 戻り値は stat
; ExternalHandle : LDAP* in/out -> "sptr"
; Oid : LPSTR -> "sptr"
; Data : LDAP_BERVAL* in/out -> "sptr"
; ServerControls : LDAPControlA** in/out -> "sptr"
; ClientControls : LDAPControlA** in/out -> "sptr"
; ReturnedOid : LPSTR* out -> "sptr"
; ReturnedData : LDAP_BERVAL** in/out -> "sptr"
; ※HSP3.7は #func のため戻り値はシステム変数 stat に格納されます。
出力引数:
#uselib "WLDAP32.dll"
#cfunc global ldap_extended_operation_sA "ldap_extended_operation_sA" var, str, var, var, var, var, var
; res = ldap_extended_operation_sA(ExternalHandle, Oid, Data, ServerControls, ClientControls, ReturnedOid, ReturnedData)
; ExternalHandle : LDAP* in/out -> "var"
; Oid : LPSTR -> "str"
; Data : LDAP_BERVAL* in/out -> "var"
; ServerControls : LDAPControlA** in/out -> "var"
; ClientControls : LDAPControlA** in/out -> "var"
; ReturnedOid : LPSTR* out -> "var"
; ReturnedData : LDAP_BERVAL** in/out -> "var"
; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。
出力引数:
; DWORD ldap_extended_operation_sA(LDAP* ExternalHandle, LPSTR Oid, LDAP_BERVAL* Data, LDAPControlA** ServerControls, LDAPControlA** ClientControls, LPSTR* ReturnedOid, LDAP_BERVAL** ReturnedData)
#uselib "WLDAP32.dll"
#cfunc global ldap_extended_operation_sA "ldap_extended_operation_sA" var, str, var, var, var, var, var
; res = ldap_extended_operation_sA(ExternalHandle, Oid, Data, ServerControls, ClientControls, ReturnedOid, ReturnedData)
; ExternalHandle : LDAP* in/out -> "var"
; Oid : LPSTR -> "str"
; Data : LDAP_BERVAL* in/out -> "var"
; ServerControls : LDAPControlA** in/out -> "var"
; ClientControls : LDAPControlA** in/out -> "var"
; ReturnedOid : LPSTR* out -> "var"
; ReturnedData : LDAP_BERVAL** in/out -> "var"
; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。
import (
	"golang.org/x/sys/windows"
	"unsafe"
)

var (
	wldap32 = windows.NewLazySystemDLL("WLDAP32.dll")
	procldap_extended_operation_sA = wldap32.NewProc("ldap_extended_operation_sA")
)

// ExternalHandle (LDAP* in/out), Oid (LPSTR), Data (LDAP_BERVAL* in/out), ServerControls (LDAPControlA** in/out), ClientControls (LDAPControlA** in/out), ReturnedOid (LPSTR* out), ReturnedData (LDAP_BERVAL** in/out)
r1, _, err := procldap_extended_operation_sA.Call(
	uintptr(ExternalHandle),
	uintptr(unsafe.Pointer(windows.BytePtrFromString(Oid))),
	uintptr(Data),
	uintptr(ServerControls),
	uintptr(ClientControls),
	uintptr(ReturnedOid),
	uintptr(ReturnedData),
)
_ = err  // syscall.Errno (valid when the call sets last-error)
_ = r1   // DWORD
function ldap_extended_operation_sA(
  ExternalHandle: Pointer;   // LDAP* in/out
  Oid: PAnsiChar;   // LPSTR
  Data: Pointer;   // LDAP_BERVAL* in/out
  ServerControls: Pointer;   // LDAPControlA** in/out
  ClientControls: Pointer;   // LDAPControlA** in/out
  ReturnedOid: PPAnsiChar;   // LPSTR* out
  ReturnedData: Pointer   // LDAP_BERVAL** in/out
): DWORD; cdecl;
  external 'WLDAP32.dll' name 'ldap_extended_operation_sA';
result := DllCall("WLDAP32\ldap_extended_operation_sA"
    , "Ptr", ExternalHandle   ; LDAP* in/out
    , "AStr", Oid   ; LPSTR
    , "Ptr", Data   ; LDAP_BERVAL* in/out
    , "Ptr", ServerControls   ; LDAPControlA** in/out
    , "Ptr", ClientControls   ; LDAPControlA** in/out
    , "Ptr", ReturnedOid   ; LPSTR* out
    , "Ptr", ReturnedData   ; LDAP_BERVAL** in/out
    , "Cdecl UInt")   ; return: DWORD
●ldap_extended_operation_sA(ExternalHandle, Oid, Data, ServerControls, ClientControls, ReturnedOid, ReturnedData) = DLL("WLDAP32.dll", "dword ldap_extended_operation_sA(void*, char*, void*, void*, void*, void*, void*)")
# 呼び出し: ldap_extended_operation_sA(ExternalHandle, Oid, Data, ServerControls, ClientControls, ReturnedOid, ReturnedData)
# ExternalHandle : LDAP* in/out -> "void*"
# Oid : LPSTR -> "char*"
# Data : LDAP_BERVAL* in/out -> "void*"
# ServerControls : LDAPControlA** in/out -> "void*"
# ClientControls : LDAPControlA** in/out -> "void*"
# ReturnedOid : LPSTR* out -> "void*"
# ReturnedData : LDAP_BERVAL** in/out -> "void*"
# なでしこ1は32bit・ANSI(Shift_JIS)。文字列=char*(ANSI)、ポインタ/ハンドル=void*(4byte)。
# ※cdecl関数。DLL()宣言はstdcall前提。cdeclは EXEC_PTR(`cdecl`,…) を使用。