auth/kerberos: Create common helper to get the verified PAC from GSSAPI
[samba.git] / auth / common_auth.h
1 /*
2    Unix SMB/CIFS implementation.
3    Standardised Authentication types
4    Copyright (C) Andrew Bartlett 2001-2010
5
6    This program is free software; you can redistribute it and/or modify
7    it under the terms of the GNU General Public License as published by
8    the Free Software Foundation; either version 3 of the License, or
9    (at your option) any later version.
10
11    This program is distributed in the hope that it will be useful,
12    but WITHOUT ANY WARRANTY; without even the implied warranty of
13    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14    GNU General Public License for more details.
15
16    You should have received a copy of the GNU General Public License
17    along with this program.  If not, see <http://www.gnu.org/licenses/>.
18 */
19
20 #define USER_INFO_CASE_INSENSITIVE_USERNAME 0x01 /* username may be in any case */
21 #define USER_INFO_CASE_INSENSITIVE_PASSWORD 0x02 /* password may be in any case */
22 #define USER_INFO_DONT_CHECK_UNIX_ACCOUNT   0x04 /* don't check unix account status */
23 #define USER_INFO_INTERACTIVE_LOGON         0x08 /* don't check unix account status */
24
25 enum auth_password_state {
26         AUTH_PASSWORD_PLAIN = 1,
27         AUTH_PASSWORD_HASH = 2,
28         AUTH_PASSWORD_RESPONSE = 3
29 };
30
31 struct auth_usersupplied_info
32 {
33         const char *workstation_name;
34         const struct tsocket_address *remote_host;
35
36         uint32_t logon_parameters;
37
38         bool mapped_state;
39         bool was_mapped;
40         /* the values the client gives us */
41         struct {
42                 const char *account_name;
43                 const char *domain_name;
44         } client, mapped;
45
46         enum auth_password_state password_state;
47
48         struct {
49                 struct {
50                         DATA_BLOB lanman;
51                         DATA_BLOB nt;
52                 } response;
53                 struct {
54                         struct samr_Password *lanman;
55                         struct samr_Password *nt;
56                 } hash;
57
58                 char *plaintext;
59         } password;
60         uint32_t flags;
61 };