SpExchangeMetaDataFn コールバック関数 (ntsecpkg.h)
セキュリティ サポート プロバイダーにメタデータを送信します。 この関数によって送信されるメタデータは、 SpQueryMetaDataFn 関数の以前の呼び出しによって取得されます。
構文
SpExchangeMetaDataFn Spexchangemetadatafn;
NTSTATUS Spexchangemetadatafn(
[in] LSA_SEC_HANDLE CredentialHandle,
[in, optional] PUNICODE_STRING TargetName,
[in] ULONG ContextRequirements,
[in] ULONG MetaDataLength,
[in] PUCHAR MetaData,
[in, out] PLSA_SEC_HANDLE ContextHandle
)
{...}
パラメーター
[in] CredentialHandle
セキュリティ コンテキストに使用する 資格情報 のハンドル。 ContextHandle パラメーターが入力時に NULL を指している場合、この関数は、このパラメーターの値を使用してセキュリティ コンテキストを作成します。
ContextHandle パラメーターが入力時に NULL を指している場合、このパラメーターの値を NULL にすることはできません。
[in, optional] TargetName
コンテキストのターゲットの名前を含む UNICODE_STRING へのポインター。
[in] ContextRequirements
クライアントに必要なコンテキスト属性を示すフラグ。
有効な値は次のとおりです。 論理 OR 演算を使用して値を結合できます。
値 | 意味 |
---|---|
|
サーバーはクライアントの権限を借用できます。 |
|
ID を証明するには、クライアントとサーバーの両方が必要です。 |
|
セキュリティ コンテキストは、再生されたパケットの検出をサポートします。 |
|
セキュリティ コンテキストは、順序が整ったメッセージの検出をサポートします。 |
|
新しい セッション キー をネゴシエートする必要があります。 |
|
クライアントが対話型ユーザーの場合、パッケージは可能であれば、ユーザーに適切な資格情報の入力を求める必要があります。 |
|
入力バッファーには、接続の認証に使用する必要があるパッケージ固有の資格情報が含まれています。 |
|
パッケージはメモリを割り当てる必要があります。 呼び出し元は、最終的に FreeContextBuffer 関数を呼び出して、パッケージによって割り当てられたメモリを解放する必要があります。 |
|
呼び出し元は、3 段階の相互認証トランザクションを想定しています。 |
|
データグラム型の通信チャネルを使用する必要があります。 詳細については、「 データグラム コンテキスト」を参照してください。 |
|
接続タイプの通信チャネルを使用する必要があります。 詳細については、「 接続指向コンテキスト」を参照してください。 |
|
コンテキストが失敗した場合は、エラー応答メッセージを生成してクライアントに送り返します。 |
|
ストリーム型の通信チャネルを使用する必要があります。 詳細については、「Stream コンテキスト」を参照してください。 |
|
バッファーの整合性が検証されます。ただし、再生されたメッセージとシーケンス外のメッセージは検出されません。 |
[in] MetaDataLength
MetaData バッファーのサイズ (文字数)。
[in] MetaData
送信するメタデータ。
[in, out] ContextHandle
使用するセキュリティ ハンドルのハンドル。 このパラメーターが入力時に NULL を指している場合、この関数は CredentialHandle パラメーターと TargetName パラメーターの値を使用してセキュリティ コンテキストを割り当てて初期化します。
このパラメーターが入力時に NULL を指している場合、 CredentialHandle を NULL にすることはできません。
戻り値
関数が成功した場合は、 STATUS_SUCCESSまたは情報状態コードを返します。
関数が失敗した場合は、失敗した理由を示す NTSTATUS エラー コードを返します。 詳細については、「解説」を参照してください。
注釈
SpExchangeMetaDataFn 関数へのポインターは、SpLsaModeInitialize 関数から受信したSECPKG_FUNCTION_TABLE構造体で使用できます。
要件
要件 | 値 |
---|---|
サポートされている最小のクライアント | Windows 7 [デスクトップ アプリのみ] |
サポートされている最小のサーバー | Windows Server 2008 R2 [デスクトップ アプリのみ] |
対象プラットフォーム | Windows |
ヘッダー | ntsecpkg.h |