Class ADtoDBHybridAuthenticator
- java.lang.Object
- 
- com.inductiveautomation.ignition.gateway.user.UserSourceProfileKernelWrapper
- 
- com.inductiveautomation.ignition.gateway.user.AbstractUserSourceProfile
- 
- com.inductiveautomation.ignition.gateway.authentication.impl.DatabaseExpertUserSource
- 
- com.inductiveautomation.ignition.gateway.authentication.impl.ADtoDBHybridAuthenticator
 
 
 
 
- 
- All Implemented Interfaces:
- SSOCompatibleADUserSource,- UserSourceProfile,- UserSourceProfileKernel
 
 public class ADtoDBHybridAuthenticator extends DatabaseExpertUserSource implements SSOCompatibleADUserSource 
- 
- 
Field Summary- 
Fields inherited from interface com.inductiveautomation.ignition.gateway.user.UserSourceProfilePWD_EXPIRATION_BYPASS
 
- 
 - 
Constructor SummaryConstructors Constructor Description ADtoDBHybridAuthenticator(UserSourceProfileKernel kernel)
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description AuthenticatedUserauthenticate(AuthChallenge challenge)Called to both verify authentication for a given username/password pair, and to find the security roles for that user.AuthenticatedUserauthenticateAD(AuthChallenge challenge)Callback to the standard, non-SSO version of this user source's auth logicUserfindSSOUser(java.lang.String uname)Used by the SSO helper in order to search for a user with a given username.java.util.Optional<User>getUser(java.lang.String userName)Fetch aUserwith the given user name.java.util.Collection<User>getUsers()Retrieve all users from this profile.protected LoggerExnewLogger()voidsetAllowAnon(boolean anon)voidsetLdapHost(java.lang.String ldapHost)voidsetLdapPort(java.lang.String ldapPort)voidsetListUsersFromAD(boolean listUsersFromAD)voidsetPageSize(int size)voidsetProfilePassword(java.lang.String profilePassword)voidsetProfileUsername(java.lang.String profileUsername)voidsetReadTimeOut(java.lang.Long readTimeOut)voidsetReferral(LDAPHelper.ReferralType referral)voidsetSaslConfig(SASLConfig saslConfig)voidsetSecondaryLdapHost(java.lang.String secondaryLdapHost)voidsetSecondaryLdapPort(java.lang.String secondaryLdapPort)voidsetSecurityAuthentication(LDAPHelper.AuthType securityAuthentication)voidsetSecurityProtocol(LDAPHelper.ProtocolType securityProtocol)voidsetSSODomain(java.lang.String ssoDomain)voidsetSSOEnabled(boolean enabled)voidsetUsePrefixAndSuffixForGatewayUser(boolean usePrefixAndSuffixForGatewayUser)voidsetUserListFilter(java.lang.String userListFilter)voidsetUserNameAttribute(java.lang.String userNameAttribute)voidsetUsernamePrefix(java.lang.String usernamePrefix)voidsetUsernameSuffix(java.lang.String usernameSuffix)voidsetUserPropsQuery(java.lang.String userPropsQuery)voidsetUserSearchBase(java.lang.String userSearchBase)voidsetUserSearchFilter(java.lang.String userSearchFilter)voidsetUseSSL(boolean useSsl)voidstartup(UserSourceManager manager)Called when the user source is created before it is used.java.lang.StringtoString()- 
Methods inherited from class com.inductiveautomation.ignition.gateway.authentication.impl.DatabaseExpertUserSourcefindContactInfo, findExtraProps, findRoles, findScheduleAdjustment, getConnection, getEditFlags, getRoles, set, setAuthenticateBadgeQuery, setAuthenticateQuery, setDatasource, setFindUserQuery, setListContactInfoQuery, setListExtraPropsQuery, setListRolesQuery, setListScheduleAdjustmentsQuery, setListUserRolesQuery, setListUsersQuery
 - 
Methods inherited from class com.inductiveautomation.ignition.gateway.user.AbstractUserSourceProfileaddRole, addUser, alterPassword, alterUser, getName, getRoles, getUser, getUsers, removeRole, removeUser, renameRole
 - 
Methods inherited from class com.inductiveautomation.ignition.gateway.user.UserSourceProfileKernelWrappergetCacheValidationTimeout, getContext, getManager, getProfileId, getProfileName, isLockedOut, notifyFailedAttempt, shutdown
 - 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
 - 
Methods inherited from interface com.inductiveautomation.ignition.gateway.user.UserSourceProfilegetCacheValidationTimeout, getProfileId, shutdown, validatePassword
 
- 
 
- 
- 
- 
Constructor Detail- 
ADtoDBHybridAuthenticatorpublic ADtoDBHybridAuthenticator(UserSourceProfileKernel kernel) 
 
- 
 - 
Method Detail- 
startuppublic void startup(UserSourceManager manager) Description copied from interface:UserSourceProfileKernelCalled when the user source is created before it is used.- Specified by:
- startupin interface- UserSourceProfile
- Specified by:
- startupin interface- UserSourceProfileKernel
- Overrides:
- startupin class- UserSourceProfileKernelWrapper
 
 - 
newLoggerprotected LoggerEx newLogger() - Overrides:
- newLoggerin class- DatabaseExpertUserSource
 
 - 
authenticatepublic AuthenticatedUser authenticate(AuthChallenge challenge) throws java.lang.Exception Description copied from interface:UserSourceProfileCalled to both verify authentication for a given username/password pair, and to find the security roles for that user.- Specified by:
- authenticatein interface- UserSourceProfile
- Overrides:
- authenticatein class- DatabaseExpertUserSource
- Returns:
- An AuthenticatedUser that contains the user's roles if authentication succeeded, or null if it did not.
- Throws:
- PasswordExpiredException- if the user's password has expired and must be reset
- java.lang.Exception- if there was an unexpected problem encountered during authentication
 
 - 
authenticateADpublic AuthenticatedUser authenticateAD(AuthChallenge challenge) throws java.lang.Exception Description copied from interface:SSOCompatibleADUserSourceCallback to the standard, non-SSO version of this user source's auth logic- Specified by:
- authenticateADin interface- SSOCompatibleADUserSource
- Throws:
- java.lang.Exception
 
 - 
getUsers@Nonnull public java.util.Collection<User> getUsers() throws java.lang.Exception Description copied from interface:UserSourceProfileRetrieve all users from this profile. This can execute slowly (block) if need be. It will be called periodically by the manager and the results will be cached. Users from failover sources will be returned if hard failover is configured and triggered.- Specified by:
- getUsersin interface- UserSourceProfile
- Overrides:
- getUsersin class- DatabaseExpertUserSource
- Throws:
- java.lang.Exception
 
 - 
getUser@Nonnull public java.util.Optional<User> getUser(java.lang.String userName) throws java.lang.Exception Description copied from interface:UserSourceProfileFetch aUserwith the given user name. If more than one user exists with the given user name, the first user returned from the underlying data source is returned. Failover sources will be queried if hard failover is configured and the primary sources are unable to fetch the user due to an error. Failover sources will also be queried if soft failover is configured and the user is not found in the primary sources.- Specified by:
- getUserin interface- UserSourceProfile
- Overrides:
- getUserin class- DatabaseExpertUserSource
- Parameters:
- userName- the user name of the- Userto fetch
- Returns:
- an OptionalUserwith the given user name. the user may be from a failover user source (checkUser.getProfileName()to confirm)
- Throws:
- java.lang.Exception- if there is an unexpected problem fetching the user with the given user name
- See Also:
- UserSourceProfile.getUser(String, String)
 
 - 
toStringpublic java.lang.String toString() - Overrides:
- toStringin class- DatabaseExpertUserSource
 
 - 
setListUsersFromADpublic void setListUsersFromAD(boolean listUsersFromAD) 
 - 
setUserPropsQuerypublic void setUserPropsQuery(java.lang.String userPropsQuery) 
 - 
setLdapHostpublic void setLdapHost(java.lang.String ldapHost) 
 - 
setLdapPortpublic void setLdapPort(java.lang.String ldapPort) 
 - 
setSecondaryLdapHostpublic void setSecondaryLdapHost(java.lang.String secondaryLdapHost) 
 - 
setSecondaryLdapPortpublic void setSecondaryLdapPort(java.lang.String secondaryLdapPort) 
 - 
setUsernamePrefixpublic void setUsernamePrefix(java.lang.String usernamePrefix) 
 - 
setUsernameSuffixpublic void setUsernameSuffix(java.lang.String usernameSuffix) 
 - 
setProfileUsernamepublic void setProfileUsername(java.lang.String profileUsername) 
 - 
setReadTimeOutpublic void setReadTimeOut(java.lang.Long readTimeOut) 
 - 
setProfilePasswordpublic void setProfilePassword(java.lang.String profilePassword) 
 - 
setUsePrefixAndSuffixForGatewayUserpublic void setUsePrefixAndSuffixForGatewayUser(boolean usePrefixAndSuffixForGatewayUser) 
 - 
setUseSSLpublic void setUseSSL(boolean useSsl) 
 - 
setAllowAnonpublic void setAllowAnon(boolean anon) 
 - 
setSecurityAuthenticationpublic void setSecurityAuthentication(LDAPHelper.AuthType securityAuthentication) 
 - 
setSecurityProtocolpublic void setSecurityProtocol(LDAPHelper.ProtocolType securityProtocol) 
 - 
setUserSearchBasepublic void setUserSearchBase(java.lang.String userSearchBase) 
 - 
setUserSearchFilterpublic void setUserSearchFilter(java.lang.String userSearchFilter) 
 - 
setUserListFilterpublic void setUserListFilter(java.lang.String userListFilter) 
 - 
setUserNameAttributepublic void setUserNameAttribute(java.lang.String userNameAttribute) 
 - 
setPageSizepublic void setPageSize(int size) 
 - 
setSSOEnabledpublic void setSSOEnabled(boolean enabled) 
 - 
setSSODomainpublic void setSSODomain(java.lang.String ssoDomain) 
 - 
setSaslConfigpublic void setSaslConfig(SASLConfig saslConfig) 
 - 
setReferralpublic void setReferral(LDAPHelper.ReferralType referral) 
 - 
findSSOUserpublic User findSSOUser(java.lang.String uname) throws java.lang.Exception Description copied from interface:SSOCompatibleADUserSourceUsed by the SSO helper in order to search for a user with a given username. Return null if no user with this username is found.- Specified by:
- findSSOUserin interface- SSOCompatibleADUserSource
- Throws:
- java.lang.Exception
 
 
- 
 
-