Package org.wildfly.security.auth.realm
Class FileSystemSecurityRealm.Identity
- java.lang.Object
- 
- org.wildfly.security.auth.realm.FileSystemSecurityRealm.Identity
 
- 
- All Implemented Interfaces:
- ModifiableRealmIdentity,- RealmIdentity
 - Enclosing class:
- FileSystemSecurityRealm
 
 static class FileSystemSecurityRealm.Identity extends Object implements ModifiableRealmIdentity 
- 
- 
Field SummaryFields Modifier and Type Field Description private static StringBASE64_FORMATprivate static StringENCRYPTION_FORMATprivate CharsethashCharsetprivate EncodinghashEncodingprivate static StringHEXprivate booleanintegrityEnabledprivate IdentitySharedExclusiveLock.IdentityLocklockprivate static StringMCF_FORMATprivate Stringnameprivate Pathpathprivate PrivateKeyprivateKeyprivate Supplier<Provider[]>providersprivate PublicKeypublicKeyprivate SecretKeysecretKeyprivate static StringX509_FORMAT- 
Fields inherited from interface org.wildfly.security.auth.server.ModifiableRealmIdentityNON_EXISTENT
 - 
Fields inherited from interface org.wildfly.security.auth.server.RealmIdentityANONYMOUS
 
- 
 - 
Constructor SummaryConstructors Constructor Description Identity(String name, Path path, IdentitySharedExclusiveLock.IdentityLock lock, Charset hashCharset, Encoding hashEncoding, Supplier<Provider[]> providers, SecretKey secretKey, PrivateKey privateKey, PublicKey publicKey, boolean integrityEnabled)
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description private voidconsumeContent(XMLStreamReader reader)voidcreate()Create this realm identity.private VoidcreatePrivileged()voiddelete()Delete this realm identity.private VoiddeletePrivileged()voiddispose()Dispose this realm identity after a completed authentication attempt.booleanexists()Determine if the identity exists in lieu of verifying or acquiring a credential.AttributesgetAttributes()Get the attributes for the realm identity.AuthorizationIdentitygetAuthorizationIdentity()Get an authorization identity for this pre-authenticated identity.<C extends Credential>
 CgetCredential(Class<C> credentialType)Acquire a credential of the given type.<C extends Credential>
 CgetCredential(Class<C> credentialType, String algorithmName)Acquire a credential of the given type and algorithm name.<C extends Credential>
 CgetCredential(Class<C> credentialType, String algorithmName, AlgorithmParameterSpec parameterSpec)Acquire a credential of the given type and algorithm name.SupportLevelgetCredentialAcquireSupport(Class<? extends Credential> credentialType, String algorithmName, AlgorithmParameterSpec parameterSpec)Determine whether a given credential type is definitely obtainable, possibly obtainable, or definitely not obtainable for this identity.SupportLevelgetEvidenceVerifySupport(Class<? extends Evidence> evidenceType, String algorithmName)Determine whether a given type of evidence is definitely verifiable, possibly verifiable, or definitely not verifiable.PrincipalgetRealmIdentityPrincipal()Get the principal that canonically identifies the identity within the realm.private FileSystemSecurityRealm.VersionidentifyVersion(XMLStreamReader streamReader)private booleanisIntegrityValid()(package private) List<Credential>loadCredentials()private FileSystemSecurityRealm.LoadedIdentityloadIdentity(boolean skipCredentials, boolean skipAttributes)protected FileSystemSecurityRealm.LoadedIdentityloadIdentityPrivileged(boolean skipCredentials, boolean skipAttributes)private voidparseAttribute(XMLStreamReader streamReader, Attributes attributes)private AttributesparseAttributes(XMLStreamReader streamReader, FileSystemSecurityRealm.Version version)private voidparseCertificate(List<Credential> credentials, XMLStreamReader streamReader)private voidparseCredential(XMLStreamReader streamReader, FileSystemSecurityRealm.CredentialParseFunction function)private List<Credential>parseCredentials(XMLStreamReader streamReader, FileSystemSecurityRealm.Version version)private FileSystemSecurityRealm.LoadedIdentityparseIdentity(XMLStreamReader streamReader, boolean skipCredentials, boolean skipAttributes)private FileSystemSecurityRealm.LoadedIdentityparseIdentityContents(XMLStreamReader streamReader, FileSystemSecurityRealm.Version version, boolean skipCredentials, boolean skipAttributes)private voidparseOtp(List<Credential> credentials, XMLStreamReader streamReader)private voidparsePassword(List<Credential> credentials, XMLStreamReader streamReader, FileSystemSecurityRealm.Version version)private voidparsePublicKey(List<Credential> credentials, XMLStreamReader streamReader)private voidreplaceIdentity(FileSystemSecurityRealm.LoadedIdentity newIdentity)private VoidreplaceIdentityPrivileged(FileSystemSecurityRealm.LoadedIdentity newIdentity)private FileSystemSecurityRealm.VersionrequiredVersion(FileSystemSecurityRealm.LoadedIdentity identityToWrite)voidsetAttributes(Attributes attributes)Modify the attributes collection of this identity.voidsetCredentials(Collection<? extends Credential> credentials)Set the credentials of this identity.private PathtempPath()private StringtempSuffix()private booleanvalidateDigitalSignature(Document doc)private booleanvalidatePrincipalName(Document doc)booleanverifyEvidence(Evidence evidence)Verify the given evidence against a credential of this identity.private voidwriteDigitalSignature(Path path, String name)private voidwriteIdentity(XMLStreamWriter streamWriter, FileSystemSecurityRealm.LoadedIdentity newIdentity)- 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface org.wildfly.security.auth.server.ModifiableRealmIdentityupdateCredential
 - 
Methods inherited from interface org.wildfly.security.auth.server.RealmIdentityapplyToCredential, applyToCredential, applyToCredential, getCredentialAcquireSupport
 
- 
 
- 
- 
- 
Field Detail- 
ENCRYPTION_FORMATprivate static final String ENCRYPTION_FORMAT - See Also:
- Constant Field Values
 
 - 
BASE64_FORMATprivate static final String BASE64_FORMAT - See Also:
- Constant Field Values
 
 - 
MCF_FORMATprivate static final String MCF_FORMAT - See Also:
- Constant Field Values
 
 - 
X509_FORMATprivate static final String X509_FORMAT - See Also:
- Constant Field Values
 
 - 
HEXprivate static final String HEX - See Also:
- Constant Field Values
 
 - 
nameprivate final String name 
 - 
pathprivate final Path path 
 - 
lockprivate IdentitySharedExclusiveLock.IdentityLock lock 
 - 
hashCharsetprivate final Charset hashCharset 
 - 
hashEncodingprivate final Encoding hashEncoding 
 - 
secretKeyprivate final SecretKey secretKey 
 - 
privateKeyprivate final PrivateKey privateKey 
 - 
publicKeyprivate final PublicKey publicKey 
 - 
integrityEnabledprivate final boolean integrityEnabled 
 
- 
 - 
Constructor Detail- 
IdentityIdentity(String name, Path path, IdentitySharedExclusiveLock.IdentityLock lock, Charset hashCharset, Encoding hashEncoding, Supplier<Provider[]> providers, SecretKey secretKey, PrivateKey privateKey, PublicKey publicKey, boolean integrityEnabled) 
 
- 
 - 
Method Detail- 
getRealmIdentityPrincipalpublic Principal getRealmIdentityPrincipal() Description copied from interface:RealmIdentityGet the principal that canonically identifies the identity within the realm. This method may return the principal object which was passed in as a parameter toSecurityRealm.getRealmIdentity(Principal)(a.k.a. domain principal), but is not required to do so. Any existent realm identity (i.e. any identity which returnstrueon invocation ofRealmIdentity.exists()) must return a non-nullprincipal.- Specified by:
- getRealmIdentityPrincipalin interface- RealmIdentity
- Returns:
- the principal for this realm identity (may not be null)
 
 - 
getCredentialAcquireSupportpublic SupportLevel getCredentialAcquireSupport(Class<? extends Credential> credentialType, String algorithmName, AlgorithmParameterSpec parameterSpec) throws RealmUnavailableException Description copied from interface:RealmIdentityDetermine whether a given credential type is definitely obtainable, possibly obtainable, or definitely not obtainable for this identity.- Specified by:
- getCredentialAcquireSupportin interface- RealmIdentity
- Parameters:
- credentialType- the exact credential type (must not be- null)
- algorithmName- the algorithm name, or- nullif any algorithm is acceptable or the credential type does not support algorithm names
- parameterSpec- the algorithm parameters to match, or- nullif any parameters are acceptable or the credential type does not support algorithm parameters
- Returns:
- the level of support for this credential type (may not be null)
- Throws:
- RealmUnavailableException- if the realm is not able to handle requests for any reason
 
 - 
getCredentialpublic <C extends Credential> C getCredential(Class<C> credentialType) throws RealmUnavailableException Description copied from interface:RealmIdentityAcquire a credential of the given type.- Specified by:
- getCredentialin interface- RealmIdentity
- Type Parameters:
- C- the credential type
- Parameters:
- credentialType- the credential type class (must not be- null)
- Returns:
- the credential, or nullif no such credential exists
- Throws:
- RealmUnavailableException- if the realm is not able to handle requests for any reason
 
 - 
getCredentialpublic <C extends Credential> C getCredential(Class<C> credentialType, String algorithmName) throws RealmUnavailableException Description copied from interface:RealmIdentityAcquire a credential of the given type and algorithm name. Realms which support more than one credential of a given type must override this method.- Specified by:
- getCredentialin interface- RealmIdentity
- Type Parameters:
- C- the credential type
- Parameters:
- credentialType- the credential type class (must not be- null)
- algorithmName- the algorithm name, or- nullif any algorithm is acceptable or the credential type does not support algorithm names
- Returns:
- the credential, or nullif no such credential exists
- Throws:
- RealmUnavailableException- if the realm is not able to handle requests for any reason
 
 - 
getCredentialpublic <C extends Credential> C getCredential(Class<C> credentialType, String algorithmName, AlgorithmParameterSpec parameterSpec) throws RealmUnavailableException Description copied from interface:RealmIdentityAcquire a credential of the given type and algorithm name. Realms which support more than one credential of a given type and algorithm must override this method.- Specified by:
- getCredentialin interface- RealmIdentity
- Type Parameters:
- C- the credential type
- Parameters:
- credentialType- the credential type class (must not be- null)
- algorithmName- the algorithm name, or- nullif any algorithm is acceptable or the credential type does not support algorithm names
- parameterSpec- the algorithm parameters to match, or- nullif any parameters are acceptable or the credential type does not support algorithm parameters
- Returns:
- the credential, or nullif no such credential exists
- Throws:
- RealmUnavailableException- if the realm is not able to handle requests for any reason
 
 - 
getEvidenceVerifySupportpublic SupportLevel getEvidenceVerifySupport(Class<? extends Evidence> evidenceType, String algorithmName) throws RealmUnavailableException Description copied from interface:RealmIdentityDetermine whether a given type of evidence is definitely verifiable, possibly verifiable, or definitely not verifiable.- Specified by:
- getEvidenceVerifySupportin interface- RealmIdentity
- Parameters:
- evidenceType- the type of evidence to be verified (must not be- null)
- algorithmName- the algorithm name, or- nullif any algorithm is acceptable or the evidence type does not support algorithm names
- Returns:
- the level of support for this evidence type
- Throws:
- RealmUnavailableException- if the realm is not able to handle requests for any reason
 
 - 
verifyEvidencepublic boolean verifyEvidence(Evidence evidence) throws RealmUnavailableException Description copied from interface:RealmIdentityVerify the given evidence against a credential of this identity. The credential to be used is selected based on the evidence type.- Specified by:
- verifyEvidencein interface- RealmIdentity
- Parameters:
- evidence- the evidence to verify
- Returns:
- trueif verification was successful,- falseotherwise
- Throws:
- RealmUnavailableException- if the realm is not able to handle requests for any reason
 
 - 
loadCredentialsList<Credential> loadCredentials() throws RealmUnavailableException - Throws:
- RealmUnavailableException
 
 - 
existspublic boolean exists() throws RealmUnavailableExceptionDescription copied from interface:RealmIdentityDetermine if the identity exists in lieu of verifying or acquiring a credential. This method is intended to be used to verify an identity for non-authentication purposes only. Implementations of this method should returnfalseup until the point it is known that a call toRealmIdentity.getAuthorizationIdentity()can successfully return an identity. If a realm can load an identity independently of credential acquisition and evidence verification if not already loaded it should be loaded at the time of this call to return an accurate result.- Specified by:
- existsin interface- RealmIdentity
- Returns:
- trueif the identity exists in this realm,- falseotherwise
- Throws:
- RealmUnavailableException- if the realm is not able to handle requests for any reason
 
 - 
deletepublic void delete() throws RealmUnavailableExceptionDescription copied from interface:ModifiableRealmIdentityDelete this realm identity. After this call,RealmIdentity.exists()will returnfalse. If the identity does not exist, an exception is thrown.- Specified by:
- deletein interface- ModifiableRealmIdentity
- Throws:
- RealmUnavailableException- if deletion fails for some reason
 
 - 
deletePrivilegedprivate Void deletePrivileged() throws RealmUnavailableException - Throws:
- RealmUnavailableException
 
 - 
tempSuffixprivate String tempSuffix() 
 - 
tempPathprivate Path tempPath() 
 - 
createpublic void create() throws RealmUnavailableExceptionDescription copied from interface:ModifiableRealmIdentityCreate this realm identity. After this call,RealmIdentity.exists()will returntrueand the credentials and role sets will be empty. If the identity already exists, an exception is thrown.- Specified by:
- createin interface- ModifiableRealmIdentity
- Throws:
- RealmUnavailableException- if creation fails for some reason
 
 - 
createPrivilegedprivate Void createPrivileged() throws RealmUnavailableException - Throws:
- RealmUnavailableException
 
 - 
setCredentialspublic void setCredentials(Collection<? extends Credential> credentials) throws RealmUnavailableException Description copied from interface:ModifiableRealmIdentitySet the credentials of this identity. If the identity does not exist, an exception is thrown. Any existing credential(s) are replaced/updated with the new value (in a possibly realm-specific manner).- Specified by:
- setCredentialsin interface- ModifiableRealmIdentity
- Parameters:
- credentials- the new credentials to set
- Throws:
- RealmUnavailableException- if updating the credentials fails for some reason
 
 - 
setAttributespublic void setAttributes(Attributes attributes) throws RealmUnavailableException Description copied from interface:ModifiableRealmIdentityModify the attributes collection of this identity. If the identity does not exist, an exception is thrown.- Specified by:
- setAttributesin interface- ModifiableRealmIdentity
- Parameters:
- attributes- the new attributes collection
- Throws:
- RealmUnavailableException- if updating the attributes collection fails for some reason
 
 - 
getAttributespublic Attributes getAttributes() throws RealmUnavailableException Description copied from interface:RealmIdentityGet the attributes for the realm identity.- Specified by:
- getAttributesin interface- RealmIdentity
- Returns:
- the attributes, or nullif the implementing class does not support getting attributes
- Throws:
- RealmUnavailableException- if accessing the attributes fails for some reason
 
 - 
replaceIdentityprivate void replaceIdentity(FileSystemSecurityRealm.LoadedIdentity newIdentity) throws RealmUnavailableException - Throws:
- RealmUnavailableException
 
 - 
replaceIdentityPrivilegedprivate Void replaceIdentityPrivileged(FileSystemSecurityRealm.LoadedIdentity newIdentity) throws RealmUnavailableException - Throws:
- RealmUnavailableException
 
 - 
requiredVersionprivate FileSystemSecurityRealm.Version requiredVersion(FileSystemSecurityRealm.LoadedIdentity identityToWrite) 
 - 
writeIdentityprivate void writeIdentity(XMLStreamWriter streamWriter, FileSystemSecurityRealm.LoadedIdentity newIdentity) throws XMLStreamException, InvalidKeySpecException, NoSuchAlgorithmException, GeneralSecurityException 
 - 
disposepublic void dispose() Description copied from interface:RealmIdentityDispose this realm identity after a completed authentication attempt.- Specified by:
- disposein interface- RealmIdentity
 
 - 
getAuthorizationIdentitypublic AuthorizationIdentity getAuthorizationIdentity() throws RealmUnavailableException Description copied from interface:RealmIdentityGet an authorization identity for this pre-authenticated identity.- Specified by:
- getAuthorizationIdentityin interface- RealmIdentity
- Returns:
- the authorization identity (may not be null)
- Throws:
- RealmUnavailableException- if the realm is not able to handle requests for any reason
 
 - 
loadIdentityprivate FileSystemSecurityRealm.LoadedIdentity loadIdentity(boolean skipCredentials, boolean skipAttributes) throws RealmUnavailableException - Throws:
- RealmUnavailableException
 
 - 
loadIdentityPrivilegedprotected FileSystemSecurityRealm.LoadedIdentity loadIdentityPrivileged(boolean skipCredentials, boolean skipAttributes) throws RealmUnavailableException - Throws:
- RealmUnavailableException
 
 - 
parseIdentityprivate FileSystemSecurityRealm.LoadedIdentity parseIdentity(XMLStreamReader streamReader, boolean skipCredentials, boolean skipAttributes) throws RealmUnavailableException, XMLStreamException 
 - 
identifyVersionprivate FileSystemSecurityRealm.Version identifyVersion(XMLStreamReader streamReader) 
 - 
parseIdentityContentsprivate FileSystemSecurityRealm.LoadedIdentity parseIdentityContents(XMLStreamReader streamReader, FileSystemSecurityRealm.Version version, boolean skipCredentials, boolean skipAttributes) throws RealmUnavailableException, XMLStreamException 
 - 
parseCredentialsprivate List<Credential> parseCredentials(XMLStreamReader streamReader, FileSystemSecurityRealm.Version version) throws RealmUnavailableException, XMLStreamException 
 - 
parseCredentialprivate void parseCredential(XMLStreamReader streamReader, FileSystemSecurityRealm.CredentialParseFunction function) throws RealmUnavailableException, XMLStreamException 
 - 
parseCertificateprivate void parseCertificate(List<Credential> credentials, XMLStreamReader streamReader) throws RealmUnavailableException, XMLStreamException 
 - 
parsePublicKeyprivate void parsePublicKey(List<Credential> credentials, XMLStreamReader streamReader) throws RealmUnavailableException, XMLStreamException 
 - 
parsePasswordprivate void parsePassword(List<Credential> credentials, XMLStreamReader streamReader, FileSystemSecurityRealm.Version version) throws XMLStreamException, RealmUnavailableException 
 - 
parseOtpprivate void parseOtp(List<Credential> credentials, XMLStreamReader streamReader) throws XMLStreamException, RealmUnavailableException 
 - 
parseAttributesprivate Attributes parseAttributes(XMLStreamReader streamReader, FileSystemSecurityRealm.Version version) throws RealmUnavailableException, XMLStreamException 
 - 
parseAttributeprivate void parseAttribute(XMLStreamReader streamReader, Attributes attributes) throws XMLStreamException, RealmUnavailableException 
 - 
consumeContentprivate void consumeContent(XMLStreamReader reader) throws XMLStreamException - Throws:
- XMLStreamException
 
 - 
isIntegrityValidprivate boolean isIntegrityValid() 
 - 
validateDigitalSignatureprivate boolean validateDigitalSignature(Document doc) 
 - 
validatePrincipalNameprivate boolean validatePrincipalName(Document doc) 
 - 
writeDigitalSignatureprivate void writeDigitalSignature(Path path, String name) throws RealmUnavailableException - Throws:
- RealmUnavailableException
 
 
- 
 
-