Windows: Remove High Security Integrated Logon
[openafs.git] / src / WINNT / afsd / afslogon.h
1 /*
2
3 Copyright 2004 by the Massachusetts Institute of Technology
4
5 All rights reserved.
6
7 Permission to use, copy, modify, and distribute this software and its
8 documentation for any purpose and without fee is hereby granted,
9 provided that the above copyright notice appear in all copies and that
10 both that copyright notice and this permission notice appear in
11 supporting documentation, and that the name of the Massachusetts
12 Institute of Technology (M.I.T.) not be used in advertising or publicity
13 pertaining to distribution of the software without specific, written
14 prior permission.
15
16 M.I.T. DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING
17 ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL
18 M.I.T. BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR
19 ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
20 WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION,
21 ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS
22 SOFTWARE.
23
24 */
25
26 /* We only support VC 1200 and above anyway */
27 #pragma once
28
29 #include <objbase.h>
30 #include <npapi.h>
31 #if (_WIN32_WINNT < 0x0501)
32 #undef _WIN32_WINNT
33 #define _WIN32_WINNT 0x0501
34 #endif
35 #include <ntsecapi.h>
36 #include <tchar.h>
37 #include <strsafe.h>
38
39
40 #define REG_CLIENT_DOMAINS_SUBKEY       "Domain"
41 #define REG_CLIENT_RETRY_INTERVAL_PARM  "LoginRetryInterval"
42 #define REG_CLIENT_SLEEP_INTERVAL_PARM  "LoginSleepInterval"
43 #define REG_CLIENT_FAIL_SILENTLY_PARM   "FailLoginsSilently"
44 #define REG_CLIENT_TRACE_OPTION_PARM    "TraceOption"
45 #define REG_CLIENT_LOGON_OPTION_PARM    "LogonOptions"
46 #define REG_CLIENT_LOGON_SCRIPT_PARMW   L"LogonScript"
47 #define REG_CLIENT_DEBUG_PARM           "Debug"
48 #define REG_CLIENT_REALM_PARM           "Realm"
49 #define REG_CLIENT_THESE_CELLS_PARM     "TheseCells"
50 #define REG_CLIENT_LOGOFF_TOKENS_PARM   "LogoffPreserveTokens"
51 #define DEFAULT_RETRY_INTERVAL          60                        /* seconds*/
52 #define DEFAULT_FAIL_SILENTLY           FALSE
53 #define DEFAULT_SLEEP_INTERVAL          5                         /* seconds*/
54 #define DEFAULT_LOGON_OPTION                    1
55
56 #define TRACE_OPTION_EVENT 1
57
58 #define ISLOGONTRACE(v) ( ((v) & TRACE_OPTION_EVENT)==TRACE_OPTION_EVENT)
59
60 #define ISLOGONINTEGRATED(v) ( ((v) & LOGON_OPTION_INTEGRATED)==LOGON_OPTION_INTEGRATED)
61
62 #define ISREMOTE(v) ( ((v) & LOGON_FLAG_REMOTE)==LOGON_FLAG_REMOTE)
63 #define ISADREALM(v) ( ((v) & LOGON_FLAG_AD_REALM)==LOGON_FLAG_AD_REALM)
64 extern DWORD TraceOption;
65
66 #define LOGON_FLAG_LOCAL        0
67 #define LOGON_FLAG_REMOTE       1
68 #define LOGON_FLAG_AD_REALM 2
69
70 typedef struct LogonOptions_type {
71         DWORD   LogonOption;
72         BOOLEAN failSilently;
73         int     retryInterval;
74         int     sleepInterval;
75         char *  smbName;
76         LPWSTR  logonScript;
77         DWORD   flags; /* LOGON_FLAG_* */
78         char *  theseCells;
79         char *  realm;
80 } LogonOptions_t;
81
82 /* */
83 #define MAX_USERNAME_LENGTH 256
84 #define MAX_PASSWORD_LENGTH 256
85 #define MAX_DOMAIN_LENGTH 256
86
87 BOOLEAN APIENTRY DllEntryPoint(HANDLE dll, DWORD reason, PVOID reserved);
88
89 DWORD APIENTRY NPGetCaps(DWORD index);
90
91 DWORD APIENTRY NPLogonNotify(
92         PLUID lpLogonId,
93         LPCWSTR lpAuthentInfoType,
94         LPVOID lpAuthentInfo,
95         LPCWSTR lpPreviousAuthentInfoType,
96         LPVOID lpPreviousAuthentInfo,
97         LPWSTR lpStationName,
98         LPVOID StationHandle,
99         LPWSTR *lpLogonScript);
100
101 DWORD APIENTRY NPPasswordChangeNotify(
102         LPCWSTR lpAuthentInfoType,
103         LPVOID lpAuthentInfo,
104         LPCWSTR lpPreviousAuthentInfoType,
105         LPVOID lpPreviousAuthentInfo,
106         LPWSTR lpStationName,
107         LPVOID StationHandle,
108         DWORD dwChangeInfo);
109
110 #ifdef __cplusplus
111 extern "C" {
112 #endif
113
114 void DebugEvent0(char *a);
115 void DebugEvent(char *b,...);
116
117 CHAR *GenRandomName(CHAR *pbuf);
118
119 BOOLEAN AFSWillAutoStart(void);
120
121 DWORD MapAuthError(DWORD code);
122
123 BOOL IsServiceRunning (void);
124
125 static BOOL WINAPI UnicodeStringToANSI(UNICODE_STRING uInputString, LPSTR lpszOutputString, int nOutStringLen);
126
127 void GetDomainLogonOptions( PLUID lpLogonId, char * username, char * domain, LogonOptions_t *opt );
128 DWORD GetFileCellName(char * path, char * cell, size_t cellLen);
129 DWORD GetAdHomePath(char * homePath, size_t homePathLen, PLUID lpLogonId, LogonOptions_t * opt);
130 DWORD QueryAdHomePathFromSid(char * homePath, size_t homePathLen, PSID psid, PWSTR domain);
131 BOOL GetLocalShortDomain(PWSTR Domain, DWORD cbDomain);
132
133 void AFSCreatePAG(PLUID lpLogonId);
134
135 DWORD LogonSSP(PLUID lpLogonId, PCtxtHandle outCtx);
136
137 #ifdef __cplusplus
138 }
139 #endif