public class DefaultKeyHandler extends KeyHandler
KeyHandler interface.
 It allows automatic transformation of software keys and parameters to corresponding PKCS#11
 versions (see setAutoConversion(boolean)).
 
 The automatic conversion imports the given software keys into the underlying PKCS#11 token. Such
 automatically imported keys always become session objects, and they are deleted automatically
 when the corresponding IAIKPKCS11Key object gets finalized
 (see IAIKPKCS11Key.setAutoDestroy(boolean)). 
 All private keys and secret keys are marked as sensitive and private objects in the PKCS#11
 token.
defaultProperties_, properties_| Constructor and Description | 
|---|
| DefaultKeyHandler()Default constructor. | 
| Modifier and Type | Method and Description | 
|---|---|
| iaik.pkcs.pkcs11.objects.SecretKey | getKeyGeneratorTemplate(java.lang.String algorithm,
                       java.security.spec.AlgorithmParameterSpec params)Get a secret key template object for the given key generation algorithm. | 
| iaik.pkcs.pkcs11.objects.SecretKey | getKeyGeneratorTemplate(java.lang.String algorithm,
                       int keySize)Get a secret key template object for the given key generation algorithm. | 
| iaik.pkcs.pkcs11.objects.KeyPair | getKeyPairGeneratorTemplate(java.lang.String algorithm,
                           java.security.spec.AlgorithmParameterSpec params)Get a private and a public key template object for the given key-pair generation algorithm. | 
| iaik.pkcs.pkcs11.objects.KeyPair | getKeyPairGeneratorTemplate(java.lang.String algorithm,
                           int keySize)Get a private and a public key template object for the given key-pair generation algorithm. | 
| java.security.Key | handleCipherKey(java.lang.String algorithm,
               int operationMode,
               java.security.Key key)If auto conversion is switched on and the given key is not a key of this provider, this
 implementation converts the key to a PKCS#11 key. | 
| java.security.Key | handleKeyAgreementKey(java.lang.String algorithm,
                     java.security.Key key,
                     java.security.spec.AlgorithmParameterSpec params)If auto conversion is switched on and the given key is not a key of this provider, this
 implementation converts the key to a PKCS#11 key. | 
| java.security.Key | handleKeyAgreementPhaseKey(java.lang.String algorithm,
                          java.security.Key key)If auto conversion is switched on and the given key is not a key of this provider, this
 implementation converts the key to a PKCS#11 key. | 
| java.security.spec.KeySpec | handleKeyFactoryGeneratePrivate(java.lang.String algorithm,
                               java.security.spec.KeySpec keySpec)If auto conversion is switched on and the given key spec is not a  PKCS11KeySpec, this
 implementation converts the key spec to aPKCS11KeySpecobject. | 
| java.security.spec.KeySpec | handleKeyFactoryGeneratePublic(java.lang.String algorithm,
                              java.security.spec.KeySpec keySpec)If auto conversion is switched on and the given key spec is not a  PKCS11KeySpec, this
 implementation converts the key spec to aPKCS11KeySpecobject. | 
| java.security.Key | handleKeyFactoryTranslateKey(java.lang.String algorithm,
                            java.security.Key key)If auto conversion is switched on and the given key is not a key of this provider, this
 implementation converts the key to a PKCS#11 key. | 
| java.security.Key | handleMacKey(java.lang.String algorithm,
            java.security.Key key)If auto conversion is switched on and the given key is not a key of this provider, this
 implementation converts the key to a PKCS#11 key. | 
| java.security.spec.KeySpec | handleSecretKeyFactoryGenerateSecret(java.lang.String algorithm,
                                    java.security.spec.KeySpec keySpec)If auto conversion is switched on and the given key spec is not a  PKCS11KeySpec, this
 implementation converts the key spec to aPKCS11KeySpecobject. | 
| javax.crypto.SecretKey | handleSecretKeyFactoryTranslateKey(java.lang.String algorithm,
                                  javax.crypto.SecretKey key)If auto conversion is switched on and the given key is not a key of this provider, this
 implementation converts the key to a PKCS#11 key. | 
| java.security.PrivateKey | handleSignatureKey(java.lang.String algorithm,
                  java.security.PrivateKey key)If auto conversion is switched on and the given key is not a key of this provider, this
 implementation converts the key to a PKCS#11 key. | 
| java.security.PublicKey | handleVerificationKey(java.lang.String algorithm,
                     java.security.PublicKey key)If auto conversion is switched on and the given key is not a key of this provider, this
 implementation converts the key to a PKCS#11 key. | 
| boolean | isAutoConversion() | 
| protected void | propertiesChanged()Read properties. | 
| void | setAutoConversion(boolean on)Switch the automatic conversion feature on or off. | 
addProperties, getProperties, setPropertiespublic DefaultKeyHandler()
protected void propertiesChanged()
propertiesChanged in class Configurablepublic java.security.Key handleCipherKey(java.lang.String algorithm,
                                         int operationMode,
                                         java.security.Key key)
                                  throws java.security.InvalidKeyException
 During conversion, this method will set the encrypt, decrypt, wrap or unwrap flags of the
 PKCS#11 object denpending on the specified operationMode.
handleCipherKey in class KeyHandleralgorithm - The JCE name of the cipher algorithm; e.g. RSA or DESede.
          Note that this is not the complete transformation string like
          DESese/CBC/PKCS5Padding.operationMode - The mode as passed to the cipher's init method; e.g.
          Cipher.ENCRYPT_MODE.key - The key.java.security.InvalidKeyException - If the given key is invalid for this algorithm or mode.isAutoConversion()public java.security.Key handleMacKey(java.lang.String algorithm,
                                      java.security.Key key)
                               throws java.security.InvalidKeyException
During conversion, this method will set the sign flag of the PKCS#11 object.
handleMacKey in class KeyHandleralgorithm - The JCE name of the MAC algorithm; e.g. HmacSHA1.key - The key.java.security.InvalidKeyException - If the given key is invalid for this algorithm.public java.security.PrivateKey handleSignatureKey(java.lang.String algorithm,
                                                   java.security.PrivateKey key)
                                            throws java.security.InvalidKeyException
During conversion, this method will set the sign flag of the PKCS#11 object.
handleSignatureKey in class KeyHandleralgorithm - The JCA name of the signature algorithm; e.g. SHA1withRSA.key - The signature key.java.security.InvalidKeyException - If the given key is invalid for this algorithm or mode.public java.security.PublicKey handleVerificationKey(java.lang.String algorithm,
                                                     java.security.PublicKey key)
                                              throws java.security.InvalidKeyException
During conversion, this method will set the verify flag of the PKCS#11 object.
handleVerificationKey in class KeyHandleralgorithm - The JCA name of the signature algorithm; e.g. SHA1withRSA.key - The verification key.java.security.InvalidKeyException - If the given key is invalid for this algorithm or mode.public java.security.Key handleKeyAgreementKey(java.lang.String algorithm,
                                               java.security.Key key,
                                               java.security.spec.AlgorithmParameterSpec params)
                                        throws java.security.InvalidKeyException
During conversion, this method will set the derive flag of the PKCS#11 object.
handleKeyAgreementKey in class KeyHandleralgorithm - The JCE name of the key agreement algorithm; e.g. DH.key - The private key for key agreement.params - The algorithm parameters passed to the init metod of the key agreement
          object.java.security.InvalidKeyException - If the given key is invalid for this algorithm or mode.public java.security.Key handleKeyAgreementPhaseKey(java.lang.String algorithm,
                                                    java.security.Key key)
                                             throws java.security.InvalidKeyException
During conversion, this method will set the derive flag of the PKCS#11 object.
handleKeyAgreementPhaseKey in class KeyHandleralgorithm - The JCE name of the key agreement algorithm; e.g. DH.key - The public phase key.java.security.InvalidKeyException - If the given key is invalid for this algorithm or mode.public java.security.spec.KeySpec handleKeyFactoryGeneratePublic(java.lang.String algorithm,
                                                                 java.security.spec.KeySpec keySpec)
                                                          throws java.security.spec.InvalidKeySpecException
PKCS11KeySpec, this
 implementation converts the key spec to a PKCS11KeySpec object. This new key spec will
 result in a session key with the default crypto operation flags.
 Otherwise, this method returns the key spec without touching it.
handleKeyFactoryGeneratePublic in class KeyHandleralgorithm - The algorithm name of the key factory; e.g. RSA.keySpec - The key spec which the application passed to the generatePublic(KeySpec)
          method of the key factory.keySpec object.java.security.spec.InvalidKeySpecException - If the given key spec is invalid in this context.public java.security.spec.KeySpec handleKeyFactoryGeneratePrivate(java.lang.String algorithm,
                                                                  java.security.spec.KeySpec keySpec)
                                                           throws java.security.spec.InvalidKeySpecException
PKCS11KeySpec, this
 implementation converts the key spec to a PKCS11KeySpec object. This new key spec will
 result in a session key with the default crypto operation flags.
 Otherwise, this method returns the key spec without touching it.
handleKeyFactoryGeneratePrivate in class KeyHandleralgorithm - The algorithm name of the key factory; e.g. RSA.keySpec - The key spec which the application passed to the generatePrivate(KeySpec)
          method of the key factory.keySpec object.java.security.spec.InvalidKeySpecException - If the given key spec is invalid in this context.public java.security.Key handleKeyFactoryTranslateKey(java.lang.String algorithm,
                                                      java.security.Key key)
                                               throws java.security.InvalidKeyException
handleKeyFactoryTranslateKey in class KeyHandleralgorithm - The algorithm name of the key factory; e.g. RSA.key - The key which the application passed to the translateKey(Key) method of
          the key factory.key argument.java.security.InvalidKeyException - If the given key is invalid in this context.public java.security.spec.KeySpec handleSecretKeyFactoryGenerateSecret(java.lang.String algorithm,
                                                                       java.security.spec.KeySpec keySpec)
                                                                throws java.security.spec.InvalidKeySpecException
PKCS11KeySpec, this
 implementation converts the key spec to a PKCS11KeySpec object. This new key spec will
 result in a session key with the default crypto operation flags.
 Otherwise, this method returns the key spec without touching it.
handleSecretKeyFactoryGenerateSecret in class KeyHandleralgorithm - The algorithm name of the key factory; e.g. DESede or AES.keySpec - The key spec which the application passed to the generateSecret(KeySpec)
          method of the secret key factory.keySpec argument.java.security.spec.InvalidKeySpecException - If the given key spec is invalid in this context.public javax.crypto.SecretKey handleSecretKeyFactoryTranslateKey(java.lang.String algorithm,
                                                                 javax.crypto.SecretKey key)
                                                          throws java.security.InvalidKeyException
handleSecretKeyFactoryTranslateKey in class KeyHandleralgorithm - The algorithm name of the key factory; e.g. DESede or AES.key - The key which the application passed to the translateKey(SecretKey)
          method of the secret key factory.key argument.java.security.InvalidKeyException - If the given key is invalid in this context.public iaik.pkcs.pkcs11.objects.KeyPair getKeyPairGeneratorTemplate(java.lang.String algorithm,
                                                                    int keySize)
                                                             throws java.security.InvalidParameterException
getKeyPairGeneratorTemplate in class KeyHandleralgorithm - The key-pair generation algorithm; e.g. RSA.keySize - The key size in bits; e.g. 1024.java.security.InvalidParameterException - If the key size is invalid.public iaik.pkcs.pkcs11.objects.KeyPair getKeyPairGeneratorTemplate(java.lang.String algorithm,
                                                                    java.security.spec.AlgorithmParameterSpec params)
                                                             throws java.security.InvalidAlgorithmParameterException
 This method only gets parameters which are not of type
 PKCS11KeyPairGenerationSpec.
 
 The key-pair generators handle such parameter directly. For example, they will get the values
 from the parameters object enclosed by the PKCS11KeyPairGenerationSpec object and put the
 values into the key template. For instance, if the application provides a
 PKCS11KeyPairGenerationSpec object with an enclosed
 javax.crypto.spec.DHParameterSpec object to a DH key-pair generator, the generator
 will itself put the P and G value into the public key template and the L value into the private
 key template.
getKeyPairGeneratorTemplate in class KeyHandleralgorithm - The key-pair generation algorithm; e.g. RSA.params - The algorithm parameters; e.g. javax.crypto.spec.DHParameterSpec.java.security.InvalidAlgorithmParameterException - If the parameters are invalid for this algorithm.public iaik.pkcs.pkcs11.objects.SecretKey getKeyGeneratorTemplate(java.lang.String algorithm,
                                                                  int keySize)
                                                           throws java.security.InvalidParameterException
getKeyGeneratorTemplate in class KeyHandleralgorithm - The key generation algorithm; e.g. AES.keySize - The key size in bits; e.g. 128. Use -1 to use the default key size.java.security.InvalidParameterException - If the key size is invalid.public iaik.pkcs.pkcs11.objects.SecretKey getKeyGeneratorTemplate(java.lang.String algorithm,
                                                                  java.security.spec.AlgorithmParameterSpec params)
                                                           throws java.security.InvalidAlgorithmParameterException
 This method only gets parameters which are not of type
 PKCS11KeyGenerationSpec.
 
The key generators handle such parameter directly. For example, they will get the values from the parameters object enclosed by the PKCS11KeyGenerationSpec object and put the values into the key template.
getKeyGeneratorTemplate in class KeyHandleralgorithm - The key generation algorithm; e.g. AES.params - The algorithm parameters>.java.security.InvalidAlgorithmParameterException - If the parameters are invalid for this algorithm.public void setAutoConversion(boolean on)
on - true, to switch it on.public boolean isAutoConversion()
true, if automatic conversion is switched on.IAIK JavaSecurity Website https://jce.iaik.tugraz.at/
                             
 IAIK at Graz University of Technology, Austria, Europe                             
 Copyright 2001-2023 IAIK, Graz University of Technology, Inffeldgasse 16a, 8010 Graz, Austria. All Rights Reserved.                                                      Version 1.9.4