Add copyright comment headers to appropriate files
[gssweb.git] / json_gssapi / test / command_mocks / InitSecContextMock.cpp
1 /*
2  * Copyright (c) 2014, 2015 JANET(UK)
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  *
9  * 1. Redistributions of source code must retain the above copyright
10  *    notice, this list of conditions and the following disclaimer.
11  *
12  * 2. Redistributions in binary form must reproduce the above copyright
13  *    notice, this list of conditions and the following disclaimer in the
14  *    documentation and/or other materials provided with the distribution.
15  *
16  * 3. Neither the name of JANET(UK) nor the names of its contributors
17  *    may be used to endorse or promote products derived from this software
18  *    without specific prior written permission.
19  *
20  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
23  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
24  * COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
25  * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
26  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
27  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
29  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
30  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
31  * OF THE POSSIBILITY OF SUCH DAMAGE.
32  *
33  */
34
35 #include "InitSecContextMock.h"
36 #include <stdio.h>
37
38 OM_uint32 InitSecContextMock::retVal = 0;
39 OM_uint32 InitSecContextMock::minor_status = 0;
40 OM_uint32 InitSecContextMock::req_flags = 0;
41 OM_uint32 InitSecContextMock::time_req = 0;
42 OM_uint32 InitSecContextMock::ret_flags = 0;
43 OM_uint32 InitSecContextMock::time_rec = 0;
44
45 bool InitSecContextMock::visited = false;
46 bool InitSecContextMock::invalidContextHandle = false;
47
48 gss_cred_id_t InitSecContextMock::claimant_cred_handle = NULL;
49 gss_ctx_id_t  InitSecContextMock::context_handle = NULL;
50 gss_name_t    InitSecContextMock::target_name = NULL;
51 gss_OID       InitSecContextMock::mech_type = NULL;
52 gss_channel_bindings_t InitSecContextMock::input_chan_bindings = NULL;
53 gss_buffer_desc  InitSecContextMock::input_token;
54 gss_OID       InitSecContextMock::actual_mech_type = NULL;
55 gss_buffer_desc  InitSecContextMock::output_token;
56
57 void InitSecContextMock::reset()
58 {
59   retVal = 0;
60   minor_status = 0;
61   nullify(claimant_cred_handle);
62   nullify(context_handle);
63   nullify(target_name);
64   // Our current handling of OIDs means attempting to free one
65   // will often result in a double-free or an attempt to free
66   // a constant OID. For now, it is better to occasionally leak.
67   // We should revisit this -Kevin
68   mech_type = GSS_C_NO_OID;
69   req_flags = 0;
70   time_req = 0;
71   nullify(input_chan_bindings);
72   input_token.length = 0;
73   input_token.value = NULL;
74   actual_mech_type = GSS_C_NO_OID;
75   output_token.length = 0;
76   output_token.value = 0;
77   ret_flags = 0;
78   time_rec = 0;
79   visited = false;
80   invalidContextHandle = false;
81
82 }