Package waffle.windows.auth.impl
Class WindowsAuthProviderImpl
java.lang.Object
waffle.windows.auth.impl.WindowsAuthProviderImpl
- All Implemented Interfaces:
IWindowsAuthProvider
Windows Auth Provider.
-
Field Summary
Modifier and TypeFieldDescriptionstatic final int
The Continue Context Timeout. -
Constructor Summary
ConstructorDescriptionInstantiates a new windows auth provider impl.WindowsAuthProviderImpl
(int continueContextsTimeout) A Windows authentication provider. -
Method Summary
Modifier and TypeMethodDescriptionacceptSecurityToken
(String connectionId, byte[] token, String securityPackage) Attempts to validate the user using an SSPI token.int
Number of elements in the continue contexts map.Retrieve the current computer information.Retrieve a list of domains (Active Directory) on the local server.logonDomainUser
(String username, String domain, String password) The LogonDomainUser function attempts to log a user on to the local computer using a network logon type and the default authentication provider.logonDomainUserEx
(String username, String domain, String password, int logonType, int logonProvider) The LogonDomainUserEx function attempts to log a user on to the local computer.The LogonUser function attempts to log a user on to the local computer using a network logon type and the default authentication provider.lookupAccount
(String username) Retrieve a security identifier (SID) for the account and the name of the domain or local computer on which the account was found.void
resetSecurityToken
(String connectionId) Reset a previously saved continuation security token for a given connection id.
-
Field Details
-
CONTINUE_CONTEXT_TIMEOUT
public static final int CONTINUE_CONTEXT_TIMEOUTThe Continue Context Timeout.- See Also:
-
-
Constructor Details
-
WindowsAuthProviderImpl
public WindowsAuthProviderImpl()Instantiates a new windows auth provider impl. -
WindowsAuthProviderImpl
public WindowsAuthProviderImpl(int continueContextsTimeout) A Windows authentication provider.- Parameters:
continueContextsTimeout
- Timeout for security contexts in seconds.
-
-
Method Details
-
acceptSecurityToken
public IWindowsSecurityContext acceptSecurityToken(String connectionId, byte[] token, String securityPackage) Description copied from interface:IWindowsAuthProvider
Attempts to validate the user using an SSPI token. This token is generated by the client via the InitializeSecurityContext(package) method described in https://msdn.microsoft.com/en-us/library/aa375509(VS.85).aspx- Specified by:
acceptSecurityToken
in interfaceIWindowsAuthProvider
- Parameters:
connectionId
- A unique connection id.token
- The security token generated by the client wishing to logon.securityPackage
- The name of the security package to use. Can be any security package supported by both the client and the server. This is usually set to "Negotiate" which will use SPNEGO to determine which security package to use. Other common values are "Kerberos" and "NTLM".- Returns:
- Windows account.
-
getCurrentComputer
Description copied from interface:IWindowsAuthProvider
Retrieve the current computer information.- Specified by:
getCurrentComputer
in interfaceIWindowsAuthProvider
- Returns:
- Current computer information.
-
getDomains
Description copied from interface:IWindowsAuthProvider
Retrieve a list of domains (Active Directory) on the local server.- Specified by:
getDomains
in interfaceIWindowsAuthProvider
- Returns:
- A list of domains.
-
logonDomainUser
Description copied from interface:IWindowsAuthProvider
The LogonDomainUser function attempts to log a user on to the local computer using a network logon type and the default authentication provider.- Specified by:
logonDomainUser
in interfaceIWindowsAuthProvider
- Parameters:
username
- A string that specifies the name of the user. This is the name of the user account to log on to. If you use the user principal name (UPN) format, user@DNS_domain_name, the domain parameter must be NULL.domain
- A string that specifies the name of the domain or server whose account database contains the username account. If this parameter is NULL, the user name must be specified in UPN format. If this parameter is ".", the function validates the account by using only the local account database.password
- A string that specifies the plaintext password for the user account specified by username.- Returns:
- Windows identity.
-
logonDomainUserEx
public IWindowsIdentity logonDomainUserEx(String username, String domain, String password, int logonType, int logonProvider) Description copied from interface:IWindowsAuthProvider
The LogonDomainUserEx function attempts to log a user on to the local computer. The local computer is the computer from which LogonUser was called. You cannot use LogonUser to log on to a remote computer. You specify the user with a user name and domain and authenticate the user with a plaintext password.- Specified by:
logonDomainUserEx
in interfaceIWindowsAuthProvider
- Parameters:
username
- A string that specifies the name of the user. This is the name of the user account to log on to. If you use the user principal name (UPN) format, user@DNS_domain_name, the domain parameter must be NULL.domain
- A string that specifies the name of the domain or server whose account database contains the username account. If this parameter is NULL, the user name must be specified in UPN format. If this parameter is ".", the function validates the account by using only the local account database.password
- A string that specifies the plaintext password for the user account specified by username.logonType
- The type of logon operation to perform.logonProvider
- Specifies the logon provider.- Returns:
- Windows identity.
-
logonUser
Description copied from interface:IWindowsAuthProvider
The LogonUser function attempts to log a user on to the local computer using a network logon type and the default authentication provider.- Specified by:
logonUser
in interfaceIWindowsAuthProvider
- Parameters:
username
- A string that specifies the name of the user in the UPN format.password
- A string that specifies the plaintext password for the user account specified by username.- Returns:
- Windows identity.
-
lookupAccount
Description copied from interface:IWindowsAuthProvider
Retrieve a security identifier (SID) for the account and the name of the domain or local computer on which the account was found.- Specified by:
lookupAccount
in interfaceIWindowsAuthProvider
- Parameters:
username
- Fully qualified or partial username.- Returns:
- Windows account.
-
resetSecurityToken
Description copied from interface:IWindowsAuthProvider
Reset a previously saved continuation security token for a given connection id.- Specified by:
resetSecurityToken
in interfaceIWindowsAuthProvider
- Parameters:
connectionId
- Connection id.
-
getContinueContextsSize
public int getContinueContextsSize()Number of elements in the continue contexts map.- Returns:
- Number of elements in the hash map.
-