| 1 | /*
|
|---|
| 2 | * secur32 private definitions.
|
|---|
| 3 | *
|
|---|
| 4 | * Copyright (C) 2004 Juan Lang
|
|---|
| 5 | *
|
|---|
| 6 | * This library is free software; you can redistribute it and/or
|
|---|
| 7 | * modify it under the terms of the GNU Lesser General Public
|
|---|
| 8 | * License as published by the Free Software Foundation; either
|
|---|
| 9 | * version 2.1 of the License, or (at your option) any later version.
|
|---|
| 10 | *
|
|---|
| 11 | * This library 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 GNU
|
|---|
| 14 | * Lesser General Public License for more details.
|
|---|
| 15 | *
|
|---|
| 16 | * You should have received a copy of the GNU Lesser General Public
|
|---|
| 17 | * License along with this library; if not, write to the Free Software
|
|---|
| 18 | * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
|
|---|
| 19 | */
|
|---|
| 20 |
|
|---|
| 21 | #ifndef __SECUR32_PRIV_H__
|
|---|
| 22 | #define __SECUR32_PRIV_H__
|
|---|
| 23 |
|
|---|
| 24 | #include <sys/types.h>
|
|---|
| 25 | #include "wine/list.h"
|
|---|
| 26 |
|
|---|
| 27 | typedef ULONG pid_t;
|
|---|
| 28 |
|
|---|
| 29 | typedef struct _SecureProvider
|
|---|
| 30 | {
|
|---|
| 31 | struct list entry;
|
|---|
| 32 | BOOL loaded;
|
|---|
| 33 | PWSTR moduleName;
|
|---|
| 34 | HMODULE lib;
|
|---|
| 35 | SecurityFunctionTableA fnTableA;
|
|---|
| 36 | SecurityFunctionTableW fnTableW;
|
|---|
| 37 | } SecureProvider;
|
|---|
| 38 |
|
|---|
| 39 | typedef struct _SecurePackage
|
|---|
| 40 | {
|
|---|
| 41 | struct list entry;
|
|---|
| 42 | SecPkgInfoW infoW;
|
|---|
| 43 | SecureProvider *provider;
|
|---|
| 44 | } SecurePackage;
|
|---|
| 45 |
|
|---|
| 46 | typedef enum _helper_mode {
|
|---|
| 47 | NTLM_SERVER,
|
|---|
| 48 | NTLM_CLIENT,
|
|---|
| 49 | NUM_HELPER_MODES
|
|---|
| 50 | } HelperMode;
|
|---|
| 51 |
|
|---|
| 52 | typedef struct tag_arc4_info {
|
|---|
| 53 | unsigned char x, y;
|
|---|
| 54 | unsigned char state[256];
|
|---|
| 55 | } arc4_info;
|
|---|
| 56 |
|
|---|
| 57 | typedef struct _NegoHelper {
|
|---|
| 58 | pid_t helper_pid;
|
|---|
| 59 | HelperMode mode;
|
|---|
| 60 | int pipe_in;
|
|---|
| 61 | int pipe_out;
|
|---|
| 62 | int major;
|
|---|
| 63 | int minor;
|
|---|
| 64 | int micro;
|
|---|
| 65 | char *com_buf;
|
|---|
| 66 | int com_buf_size;
|
|---|
| 67 | int com_buf_offset;
|
|---|
| 68 | BYTE *session_key;
|
|---|
| 69 | unsigned long neg_flags;
|
|---|
| 70 | struct {
|
|---|
| 71 | struct {
|
|---|
| 72 | ULONG seq_num;
|
|---|
| 73 | arc4_info *a4i;
|
|---|
| 74 | } ntlm;
|
|---|
| 75 | struct {
|
|---|
| 76 | BYTE *send_sign_key;
|
|---|
| 77 | BYTE *send_seal_key;
|
|---|
| 78 | BYTE *recv_sign_key;
|
|---|
| 79 | BYTE *recv_seal_key;
|
|---|
| 80 | ULONG send_seq_no;
|
|---|
| 81 | ULONG recv_seq_no;
|
|---|
| 82 | arc4_info *send_a4i;
|
|---|
| 83 | arc4_info *recv_a4i;
|
|---|
| 84 | } ntlm2;
|
|---|
| 85 | } crypt;
|
|---|
| 86 | } NegoHelper, *PNegoHelper;
|
|---|
| 87 |
|
|---|
| 88 | typedef enum _sign_direction {
|
|---|
| 89 | NTLM_SEND,
|
|---|
| 90 | NTLM_RECV
|
|---|
| 91 | } SignDirection;
|
|---|
| 92 |
|
|---|
| 93 | /* Allocates space for and initializes a new provider. If fnTableA or fnTableW
|
|---|
| 94 | * is non-NULL, assumes the provider is built-in, and if moduleName is non-NULL,
|
|---|
| 95 | * means must load the LSA/user mode functions tables from external SSP/AP module.
|
|---|
| 96 | * Otherwise moduleName must not be NULL.
|
|---|
| 97 | * Returns a pointer to the stored provider entry, for use adding packages.
|
|---|
| 98 | */
|
|---|
| 99 | SecureProvider *SECUR32_addProvider(const SecurityFunctionTableA *fnTableA,
|
|---|
| 100 | const SecurityFunctionTableW *fnTableW, PCWSTR moduleName);
|
|---|
| 101 |
|
|---|
| 102 | /* Allocates space for and adds toAdd packages with the given provider.
|
|---|
| 103 | * provider must not be NULL, and either infoA or infoW may be NULL, but not
|
|---|
| 104 | * both.
|
|---|
| 105 | */
|
|---|
| 106 | void SECUR32_addPackages(SecureProvider *provider, ULONG toAdd,
|
|---|
| 107 | const SecPkgInfoA *infoA, const SecPkgInfoW *infoW);
|
|---|
| 108 |
|
|---|
| 109 | /* Tries to find the package named packageName. If it finds it, implicitly
|
|---|
| 110 | * loads the package if it isn't already loaded.
|
|---|
| 111 | */
|
|---|
| 112 | SecurePackage *SECUR32_findPackageW(PCWSTR packageName);
|
|---|
| 113 |
|
|---|
| 114 | /* Tries to find the package named packageName. (Thunks to _findPackageW)
|
|---|
| 115 | */
|
|---|
| 116 | SecurePackage *SECUR32_findPackageA(PCSTR packageName);
|
|---|
| 117 |
|
|---|
| 118 | /* A few string helpers; will return NULL if str is NULL. Free return with
|
|---|
| 119 | * HeapFree */
|
|---|
| 120 | PWSTR SECUR32_strdupW(PCWSTR str);
|
|---|
| 121 | PWSTR SECUR32_AllocWideFromMultiByte(PCSTR str);
|
|---|
| 122 | PSTR SECUR32_AllocMultiByteFromWide(PCWSTR str);
|
|---|
| 123 |
|
|---|
| 124 | /* Initialization functions for built-in providers */
|
|---|
| 125 | void SECUR32_initSchannelSP(void);
|
|---|
| 126 | void SECUR32_initNegotiateSP(void);
|
|---|
| 127 | void SECUR32_initNTLMSP(void);
|
|---|
| 128 |
|
|---|
| 129 | /* Cleanup functions for built-in providers */
|
|---|
| 130 | void SECUR32_deinitSchannelSP(void);
|
|---|
| 131 |
|
|---|
| 132 | /* Functions from dispatcher.c used elsewhere in the code */
|
|---|
| 133 | SECURITY_STATUS fork_helper(PNegoHelper *new_helper, const char *prog,
|
|---|
| 134 | char * const argv[]);
|
|---|
| 135 |
|
|---|
| 136 | SECURITY_STATUS run_helper(PNegoHelper helper, char *buffer,
|
|---|
| 137 | unsigned int max_buflen, int *buflen);
|
|---|
| 138 |
|
|---|
| 139 | void cleanup_helper(PNegoHelper helper);
|
|---|
| 140 |
|
|---|
| 141 | void check_version(PNegoHelper helper);
|
|---|
| 142 |
|
|---|
| 143 | /* Functions from base64_codec.c used elsewhere */
|
|---|
| 144 | SECURITY_STATUS encodeBase64(PBYTE in_buf, int in_len, char* out_buf,
|
|---|
| 145 | int max_len, int *out_len);
|
|---|
| 146 |
|
|---|
| 147 | SECURITY_STATUS decodeBase64(char *in_buf, int in_len, BYTE *out_buf,
|
|---|
| 148 | int max_len, int *out_len);
|
|---|
| 149 |
|
|---|
| 150 | /* Functions from util.c */
|
|---|
| 151 | ULONG ComputeCrc32(const BYTE *pData, INT iLen, ULONG initial_crc);
|
|---|
| 152 | SECURITY_STATUS SECUR32_CreateNTLMv1SessionKey(PBYTE password, int len, PBYTE session_key);
|
|---|
| 153 | SECURITY_STATUS SECUR32_CreateNTLMv2SubKeys(PNegoHelper helper);
|
|---|
| 154 | arc4_info *SECUR32_arc4Alloc(void);
|
|---|
| 155 | void SECUR32_arc4Init(arc4_info *a4i, const BYTE *key, unsigned int keyLen);
|
|---|
| 156 | void SECUR32_arc4Process(arc4_info *a4i, BYTE *inoutString, unsigned int length);
|
|---|
| 157 | void SECUR32_arc4Cleanup(arc4_info *a4i);
|
|---|
| 158 |
|
|---|
| 159 | /* NTLMSSP flags indicating the negotiated features */
|
|---|
| 160 | #define NTLMSSP_NEGOTIATE_UNICODE 0x00000001
|
|---|
| 161 | #define NTLMSSP_NEGOTIATE_OEM 0x00000002
|
|---|
| 162 | #define NTLMSSP_REQUEST_TARGET 0x00000004
|
|---|
| 163 | #define NTLMSSP_NEGOTIATE_SIGN 0x00000010
|
|---|
| 164 | #define NTLMSSP_NEGOTIATE_SEAL 0x00000020
|
|---|
| 165 | #define NTLMSSP_NEGOTIATE_DATAGRAM_STYLE 0x00000040
|
|---|
| 166 | #define NTLMSSP_NEGOTIATE_LM_SESSION_KEY 0x00000080
|
|---|
| 167 | #define NTLMSSP_NEGOTIATE_NTLM 0x00000200
|
|---|
| 168 | #define NTLMSSP_NEGOTIATE_DOMAIN_SUPPLIED 0x00001000
|
|---|
| 169 | #define NTLMSSP_NEGOTIATE_WORKSTATION_SUPPLIED 0x00002000
|
|---|
| 170 | #define NTLMSSP_NEGOTIATE_LOCAL_CALL 0x00004000
|
|---|
| 171 | #define NTLMSSP_NEGOTIATE_ALWAYS_SIGN 0x00008000
|
|---|
| 172 | #define NTLMSSP_NEGOTIATE_TARGET_TYPE_DOMAIN 0x00010000
|
|---|
| 173 | #define NTLMSSP_NEGOTIATE_TARGET_TYPE_SERVER 0x00020000
|
|---|
| 174 | #define NTLMSSP_NEGOTIATE_NTLM2 0x00080000
|
|---|
| 175 | #define NTLMSSP_NEGOTIATE_TARGET_INFO 0x00800000
|
|---|
| 176 | #define NTLMSSP_NEGOTIATE_128 0x20000000
|
|---|
| 177 | #define NTLMSSP_NEGOTIATE_KEY_EXCHANGE 0x40000000
|
|---|
| 178 | #define NTLMSSP_NEGOTIATE_56 0x80000000
|
|---|
| 179 | #endif /* ndef __SECUR32_PRIV_H__ */
|
|---|