diff options
author | Andrew Bartlett <abartlet@samba.org> | 2010-05-04 16:44:08 +1000 |
---|---|---|
committer | Andrew Bartlett <abartlet@samba.org> | 2010-08-14 11:58:13 +1000 |
commit | 272e49e85c47d88ef0a84bce88e6f8d984f2eae4 (patch) | |
tree | 2a4bc4aef47de12de144edc35a4d5c5c75304649 /auth | |
parent | 61930f50cbace4741500d8b53fc11a4ef3e0d4f8 (diff) | |
download | samba-272e49e85c47d88ef0a84bce88e6f8d984f2eae4.tar.gz samba-272e49e85c47d88ef0a84bce88e6f8d984f2eae4.tar.xz samba-272e49e85c47d88ef0a84bce88e6f8d984f2eae4.zip |
s4:auth Move struct auth_usersupplied_info to a common location
This also changes the calling convention slightly - we should always
allocate this with talloc_zero() to allow some elements to be
optional. Some elements may only make sense in Samba3, which I hope
will use this common structure.
Andrew Bartlett
Diffstat (limited to 'auth')
-rw-r--r-- | auth/common_auth.h | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/auth/common_auth.h b/auth/common_auth.h new file mode 100644 index 00000000000..5bade6915f0 --- /dev/null +++ b/auth/common_auth.h @@ -0,0 +1,63 @@ +/* + Unix SMB/CIFS implementation. + Standardised Authentication types + Copyright (C) Andrew Bartlett 2001-2010 + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 3 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program. If not, see <http://www.gnu.org/licenses/>. +*/ + +#include "librpc/gen_ndr/krb5pac.h" + +#define USER_INFO_CASE_INSENSITIVE_USERNAME 0x01 /* username may be in any case */ +#define USER_INFO_CASE_INSENSITIVE_PASSWORD 0x02 /* password may be in any case */ +#define USER_INFO_DONT_CHECK_UNIX_ACCOUNT 0x04 /* don't check unix account status */ +#define USER_INFO_INTERACTIVE_LOGON 0x08 /* don't check unix account status */ + +enum auth_password_state { + AUTH_PASSWORD_RESPONSE, + AUTH_PASSWORD_HASH, + AUTH_PASSWORD_PLAIN +}; + +struct auth_usersupplied_info +{ + const char *workstation_name; + const struct tsocket_address *remote_host; + + uint32_t logon_parameters; + + bool mapped_state; + bool was_mapped; + /* the values the client gives us */ + struct { + const char *account_name; + const char *domain_name; + } client, mapped; + + enum auth_password_state password_state; + + struct { + struct { + DATA_BLOB lanman; + DATA_BLOB nt; + } response; + struct { + struct samr_Password *lanman; + struct samr_Password *nt; + } hash; + + char *plaintext; + } password; + uint32_t flags; +}; |