1178825Sdfr/*
2233294Sstas * Copyright (c) 2006 Kungliga Tekniska H��gskolan
3233294Sstas * (Royal Institute of Technology, Stockholm, Sweden).
4233294Sstas * All rights reserved.
5178825Sdfr *
6233294Sstas * Redistribution and use in source and binary forms, with or without
7233294Sstas * modification, are permitted provided that the following conditions
8233294Sstas * are met:
9178825Sdfr *
10233294Sstas * 1. Redistributions of source code must retain the above copyright
11233294Sstas *    notice, this list of conditions and the following disclaimer.
12178825Sdfr *
13233294Sstas * 2. Redistributions in binary form must reproduce the above copyright
14233294Sstas *    notice, this list of conditions and the following disclaimer in the
15233294Sstas *    documentation and/or other materials provided with the distribution.
16178825Sdfr *
17233294Sstas * 3. Neither the name of the Institute nor the names of its contributors
18233294Sstas *    may be used to endorse or promote products derived from this software
19233294Sstas *    without specific prior written permission.
20178825Sdfr *
21233294Sstas * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
22233294Sstas * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23233294Sstas * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24233294Sstas * ARE DISCLAIMED.  IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
25233294Sstas * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
26233294Sstas * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
27233294Sstas * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28233294Sstas * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29233294Sstas * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
30233294Sstas * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31233294Sstas * SUCH DAMAGE.
32178825Sdfr */
33178825Sdfr
34233294Sstas#include "ntlm.h"
35178825Sdfr
36233294SstasOM_uint32 GSSAPI_CALLCONV
37233294Sstas_gss_ntlm_inquire_context (
38178825Sdfr            OM_uint32 * minor_status,
39178825Sdfr            const gss_ctx_id_t context_handle,
40178825Sdfr            gss_name_t * src_name,
41178825Sdfr            gss_name_t * targ_name,
42178825Sdfr            OM_uint32 * lifetime_rec,
43178825Sdfr            gss_OID * mech_type,
44178825Sdfr            OM_uint32 * ctx_flags,
45178825Sdfr            int * locally_initiated,
46178825Sdfr            int * open_context
47178825Sdfr           )
48178825Sdfr{
49178825Sdfr    ntlm_ctx ctx = (ntlm_ctx)context_handle;
50178825Sdfr
51178825Sdfr    *minor_status = 0;
52178825Sdfr    if (src_name)
53178825Sdfr	*src_name = GSS_C_NO_NAME;
54178825Sdfr    if (targ_name)
55178825Sdfr	*targ_name = GSS_C_NO_NAME;
56178825Sdfr    if (lifetime_rec)
57178825Sdfr	*lifetime_rec = GSS_C_INDEFINITE;
58178825Sdfr    if (mech_type)
59178825Sdfr	*mech_type = GSS_NTLM_MECHANISM;
60178825Sdfr    if (ctx_flags)
61178825Sdfr	*ctx_flags = ctx->gssflags;
62178825Sdfr    if (locally_initiated)
63178825Sdfr	*locally_initiated = (ctx->status & STATUS_CLIENT) ? 1 : 0;
64178825Sdfr    if (open_context)
65178825Sdfr	*open_context = (ctx->status & STATUS_OPEN) ? 1 : 0;
66178825Sdfr
67178825Sdfr    return GSS_S_COMPLETE;
68178825Sdfr}
69