2020-09-30 16:53:55 +02:00

244 lines
6.8 KiB
C++

/*++
Copyright (c) 1996 Microsoft Corporation
Module Name:
spluginx.hxx
Abstract:
This file contains headers for the WININET
HTTP Authentication Plug In Model.
Contents:
AuthenticateUser
PreAuthenticateUser
UnloadAuthenticateUser
AuthenticateUserUI
Author:
Arthur Bierer (arthurbi) 04-Apr-1996
Revision History:
04-Apr-1996 arthurbi
Created
--*/
//
// Macros and Defines for Authentication UI
//
#define MAX_FIELD_LENGTH MAX_PATH
typedef enum tagAuthType
{
REALM_AUTH = 0,
NTLM_AUTH = 1,
} AuthType;
typedef struct tagInvalidPassType
{
LPSTR lpszRealm;
LPSTR lpszUsername;
LPSTR lpszPassword;
LPSTR lpszHost;
ULONG ulMaxField;
BOOL fIsProxy;
AuthType eAuthType;
} InvalidPassType;
#ifdef __cplusplus
extern "C" {
#endif
//
// AuthenticateUser - Called on recept of a 401 or 407 status code
// from the Web Server. This function should attempt to
// validate the Server's 401/407 response, and generate
// ERROR_SUCCESS if it accepts this Server for authentication
// Otherwise this function should returns an appropriate
// error found in wininet.h, or winerror.h
//
// lppvContext - pointer to Context pointer that will be passed on
// every unquie conversation with the Server. Will be a pointer to a
// NULL the first time this function is called for a unquie session.
// Its the Function's responsiblity to allocate or generate a unquie context
// value that will be passed on future calls.
//
// lpszServerName - Host Name of Web server.
// lpszScheme - Name of Authentication Scheme being used, ie Basic, NTLM..
// dwFlags - Flags.
// lpszUserName - Possible UserName if availble.
// lpszPassword - Possible Password if availble.
//
// RETURNS:
// ERROR_SUCCESS - Means it accepts this connection as valid, and
// asks for the authentication to continue by restarting
// the HTTP connection, and calling PreAuthenticateUser BEFORE
// that new HTTP connection is opened.
//
// ERROR_WINHTTP_INCORRECT_PASSWORD - Means we do not understand this
// username and/or password that is passed to us. Will
// return to User or Application for new username and password.
//
// ERROR_WINHTTP_FORCE_RETRY - An additional 401/407 response may
// need to be generated from the server. Forces PreAuthenticateUser
// to be recalled, and new HTTP connection/request. The difference
// is WININET will expect a 401/407 to be generated from this request.
//
#if defined(unix) && defined(__cplusplus)
extern "C"
#endif
DWORD
WINAPI
AuthenticateUser(
IN OUT LPVOID* lppvContext,
IN LPSTR lpszServerName,
IN LPSTR lpszScheme,
IN BOOL fCanUseLogon,
IN LPSTR lpszParsedAuthHeader,
IN DWORD dwcbParsedAuthHeader,
IN LPSTR lpszUserName,
IN LPSTR lpszPassword,
OUT SECURITY_STATUS *pssResult
);
//
// PreAuthenticateUser - Called on BEFORE doing a GET or POST
// to a Web Server. This function is called only if there
// has been a previous connection with the server using the
// passed in Scheme.
//
// This function will attempt to Generate a proper set of
// encoded bytes that can be sent to the server on a HTTP
// header. If lpdwOutBufferLength is not large enough
// ERROR_INSUFFICENT_BUFFER can be returned with the correct
// size stored in lpdwOutBufferLength.
//
// lppvContext - pointer to Context pointer that will be passed on
// every unquie conversation with the Server.
// lpszServerName - Host Name of Web server.
// lpszScheme - Name of Authentication Scheme being used, ie Basic, NTLM..
// fCanUseLogon - whether zone policy allows ntlm to use logon credential
// lpOutBuffer - Pointer to Buffer that will contain output encoded header bytes.
// lpdwOutBufferLength - Size of Buffer Above, will contain size of buffer above,
// on return will contain bytes actually stored.
// lpszUserName - Possible UserName if availble.
// lpszPassword - Possible Password if availble.
//
//
#if defined(unix) && defined(__cplusplus)
extern "C"
#endif
DWORD
WINAPI
PreAuthenticateUser(
IN OUT LPVOID* lppvContext,
IN LPSTR lpszServerName,
IN LPSTR lpszScheme,
IN BOOL fCanUseLogon,
IN DWORD dwFlags,
OUT LPSTR lpOutBuffer,
IN OUT LPDWORD lpdwOutBufferLength,
IN LPSTR lpszUserName,
IN LPSTR lpszPassword,
OUT SECURITY_STATUS *pssResult
);
//
// UnloadAuthenticateUser - Called after HTTP authentication
// has been completed, and the authentication process is
// no longer needed.
//
// Its intended for cleanup of context memory that was allocated.
// NOTE: For certain schemes these context values may live
// until shutdown.
//
#if defined(unix) && defined(__cplusplus)
extern "C"
#endif
VOID
WINAPI
UnloadAuthenticateUser(
IN OUT LPVOID* lppvContext,
IN LPSTR lpszScheme,
IN LPSTR lpszHost
);
#if defined(unix) && defined(__cplusplus)
extern "C"
#endif
#ifdef __cplusplus
} // end extern "C"
#endif
//
// Registry Flags Used for Defining what kind of authentication a
// plugin may support.
//
//
// Each TCP/IP Socket will contain a different Context.
// Otherwise a new context will be passed for each Realm
// or block URL template (http://www.foo.com/directory/*).
//
#define PLUGIN_AUTH_FLAGS_UNIQUE_CONTEXT_PER_TCPIP 0x01
//
// This PlugIn Can handle doing it's own UI. So call it
// when UI is needed.
//
#define PLUGIN_AUTH_FLAGS_CAN_HANDLE_UI 0x02
//
// This PlugIn may be capible of doing an Authentication
// without prompting the User for a Password. If this
// is not the case AuthenticateUser should return
// ERROR_WINHTTP_INCORRECT_PASSWORD
//
#define PLUGIN_AUTH_FLAGS_CAN_HANDLE_NO_PASSWD 0x04
//
// This PlugIn does not use a standard HTTP Realm
// string. Any data that appears to be a realm
// is scheme specific data.
//
#define PLUGIN_AUTH_FLAGS_NO_REALM 0x08
//
// This PlugIn doesn't need a persistent connection for challenge-response.
//
#define PLUGIN_AUTH_FLAGS_KEEP_ALIVE_NOT_REQUIRED 0x10
//
// Registry Values
// To Register a Security PlugIn called FOO, place a key in
// HKLM\Software\Microsoft\Internet Explorer\Security\FOO
// In Foo Create the following values:
// Flags 0x00000000 ( see above for Registry Flags )
//