...
The configuration is divided into entries for descriptors and keys. Each descriptor handles one distinct use case and references uses one of the key-entries.
Below is an example of the XML configuration.
...
language | xml |
---|
...
Descriptor names
IDM references descriptors by their name: for each use case there is a known descriptor name. Most names are fixed (e.g. ConfigZipEncrypter
is always used for encrypting configuration files) and a few can be named arbitrarily (e.g. descriptors for PIN blob decryption).
Descriptor versioning
Some descriptors support multiple versions. For example, you can replace the key of the ObjectHistorySigner
by adding a descriptor of this name with a newer version, and leaving the existing descriptor with the old version configured. This will cause any new signatures to be created with the new key, but you can still verify signatures made with the old one.
See the following example:
Code Block | ||
---|---|---|
| ||
<?xml version="1.0" encoding="UTF-8"?> <engineSignEncrypt> <descriptors> <descriptor name="ObjectHistorySigner" version="2"> <type asymCipher="RSA/None/OAEPWithSHA384AndMGF1Padding"algorithm="SHA-256" key="newHistorySigner" /> </descriptor> <descriptor name="ConfigZipEncrypterObjectHistorySigner" version="1"> <type algorithm="AES/CBC/PKCS7Padding" size="SHA-256" key="configZipEncrypterCertoldHistorySigner" /> </descriptor> asymCipher="RSA/None/OAEPWithSHA384AndMGF1Padding"/> </descriptor>!-- others descriptors --> </descriptors> <descriptor name="ConfigZipSigner" version="1"> <keys> <key name="newHistorySigner"> <type algorithmname="SHA-256pkcs12" keylocationValue="configZipSignerCertclasspath:sign_new.p12" pin="1234"/> </descriptor>key> <descriptor<key name="ObjectHistorySigner" version="1oldHistorySigner"> <type algorithmname="SHA-256pkcs12" keylocationValue="objectHistorySignerCertclasspath:sign_old.p12" pin="1234"/> </descriptor>key> <descriptor name="SignEmailDescriptor" version="1"<!-- other keys --> <type algorithm="SHA256withRSA" key="emailSigningCert" /> </descriptor> </keys> </engineSignEncrypt> |
There are also descriptors which cannot be versioned, e.g. EncryptedFields
. For those the version always needs to be set to 1.
Descriptor
See the tables below the example for more information on the different possible attributes of a descriptor/-type.
Descriptor example
Code Block | ||
---|---|---|
| ||
<descriptor name="hermodDeviceEncObjectHistorySigner" version="1"> <type algorithm="SHA256withRSASHA-256" key="serverCertobjectHistorySignerCert" /> </descriptor> <descriptor name="SelfServiceJWTSigner" version="1"> <type algorithm="RSA" key="selfServiceJWTSignerCert" /> </descriptor> <descriptor name="ContentProviderJWSSigner" version="1"> <type algorithm="RSA" key="contentProviderJWSSignerCert" /> </descriptor> <descriptor name="att_external-attestation-1" version="1"> <type algorithm="SHA256withRSA" key="attestationKey_mobile_1" /> </descriptor> <descriptor name="att_external-attestation-2" version="1"> <type algorithm="SHA256withRSA" key="attestationKey_mobile_2" /> </descriptor> <descriptor name="att_external-attestation-3" version="1"> <type algorithm="SHA256withRSA" key="attestationKey_mobile_3" /> </descriptor> <descriptor name="att_external-attestation-4" version="1"> <type algorithm="SHA256withRSA" key="attestationKey_mobile_4" /> </descriptor> <descriptor name="att_ATTESTATION" version="1"> <type algorithm="SHA256withRSA" key="attestationKey_mobile_pda_def" /> </descriptor> </descriptors> <keys> <key name="encCert"> <type name="pkcs12" locationValue="classpath:hybridEncKeypair.p12" pin="1234"/> </key> <key name="configZipEncrypterCert"> <type name="pkcs12" locationValue="classpath:encryptConfig.p12" pin="1234"/> </key> <key name="configZipSignerCert"> |
| Description |
---|---|
name | Used by Identity Manager to refer to this descriptor. There might be different descriptors with the same name but with different versions. |
version | A numeric value that denotes the descriptor's version. This is only needed for the |
Attribute of the | Description |
---|---|
algorithm | For For For For For |
size | For |
result | For |
key | The descriptor’s key. Refers to a key defined in the same document. |
asymCipher | For When used with an HSM, you need to adjust the cipher format to be compatible with the JCE provider |
initVector | Only needed for migrating For other descriptors, omit this attribute in order to use randomly generated IVs. |
Key
See the tables below the example for more information about the key/-type.
Key example
Code Block | ||
---|---|---|
| ||
<key name="objectHistorySignerCert">
<type name="pkcs12" locationValue="classpath:sign.p12" pin="1234"/>
</key> |
| Description |
---|---|
name | Used by descriptors' key attribute to reference this key. |
Attribute of the | Description |
---|---|
name | Type of storage: |
locationValue |
|
pin | PIN for the keystore or HSM. To avoid having clear text PINs in this file, the pin should be scrambled. For WAR deployments the pin will then be scrambled on the next (re-)start of Tomcat. For Docker deployments you need to scramble the pins with a dedicated tool while IDM Admin / IDM Operator containers are not running. |
Example configuration file
Below is an example of the XML configuration.
Code Block | ||
---|---|---|
| ||
<?xml version="1.0" encoding="UTF-8"?> <engineSignEncrypt> <descriptors> <type<descriptor name="pkcs12EncryptedFields" locationValueversion="classpath:signConfig.p12" pin="1234"/1"> </key> <type algorithm="AES/CBC/PKCS7Padding" size="256" <key nameresult="NX02" key="objectHistorySignerCert">encCert" <type nameasymCipher="pkcs12" locationValue="classpath:sign.p12" pin="1234"RSA/None/OAEPWithSHA384AndMGF1Padding"/> </key>descriptor> <key<descriptor name="ConfigZipEncrypter" version="selfServiceJWTSignerCert1"> <type namealgorithm="pkcs12AES/CBC/PKCS7Padding" locationValuesize="classpath:signJWT.p12256" pinkey="1234configZipEncrypterCert"/> </key> <key nameasymCipher="contentProviderJWSSignerCertRSA/None/OAEPWithSHA384AndMGF1Padding"/> </descriptor> <type <descriptor name="pkcs12ConfigZipSigner" locationValueversion="classpath:signJWS.p12" pin="1234"/1"> </key> <type <key name="emailSigningCert"algorithm="SHA-256" key="configZipSignerCert" /> </descriptor> <type <descriptor name="pkcs12ObjectHistorySigner" locationValueversion="classpath:emailSigning.p12" pin="1234"/> 1"> </key> <type <key namealgorithm="SHA-256" key="serverCertobjectHistorySignerCert" /> </descriptor> <type name="pkcs12" locationValue="classpath:deviceEncCA.p12" pin="1234"/ <descriptor name="SignEmailDescriptor" version="1"> </key> <type algorithm="SHA256withRSA" key="emailSigningCert" /> <key name="attestationKey_mobile_1"> </descriptor> <type<descriptor name="pkcs12hermodDeviceEnc" locationValue="classpath:attKeyMobile1.p12" pin="936584967"version="1"> <type algorithm="SHA256withRSA" key="serverCert" /> </key>descriptor> <key<descriptor name="attestationKey_mobile_2"SelfServiceJWTSigner" version="1"> <type namealgorithm="pkcs12RSA" locationValuekey="classpath:attKeyMobile2.p12selfServiceJWTSignerCert" pin="873145568"/> </key>descriptor> <key<descriptor name="attestationKey_mobile_3"ContentProviderJWSSigner" version="1"> <type namealgorithm="pkcs12RSA" locationValuekey="classpath:attKeyMobile3.p12contentProviderJWSSignerCert" pin="8564789632"/> </key>descriptor> <key<descriptor name="attestationKey_mobile_4att_external-attestation-1" version="1"> <type namealgorithm="pkcs12SHA256withRSA" locationValuekey="classpath:attKeyMobile4.p12attestationKey_mobile_1" pin="9263564893"/> </key>descriptor> <key<descriptor name="attestationKey_mobile_pda_defatt_external-attestation-2" version="1"> <type namealgorithm="pkcs12SHA256withRSA" locationValuekey="classpath:attKeyMobileDef.p12attestationKey_mobile_2" pin="2586453793"/> </key>descriptor> </keys> </engineSignEncrypt> |
Descriptor names
IDM references descriptors by their name. Most names are fixed (e.g. ConfigZipEncrypter
is always used for encrypting configuration files) and a few can be named arbitrarily (e.g. descriptors for PIN blob decryption).
Descriptor versioning
Some descriptors support multiple versions. For example, you can replace the key of the ObjectHistorySigner
by adding a descriptor of this name with a newer version, and leaving the existing descriptor with the old version configured. This will cause any new signatures to be created with the new key, but you can still verify signatures made with the old one.
See the following example:
Code Block | ||
---|---|---|
| ||
<?xml version="1.0" encoding="UTF-8"?> <engineSignEncrypt> <descriptors><descriptor name="att_external-attestation-3" version="1"> <type algorithm="SHA256withRSA" key="attestationKey_mobile_3" /> </descriptor> <descriptor name="att_external-attestation-4" version="1"> <type algorithm="SHA256withRSA" key="attestationKey_mobile_4" /> </descriptor> <descriptor name="ObjectHistorySigneratt_ATTESTATION" version="21"> <type algorithm="SHA-256SHA256withRSA" key="newHistorySignerattestationKey_mobile_pda_def" /> </descriptor> </descriptors> <keys> <descriptor<key name="ObjectHistorySigner" version="1"encCert"> <type algorithmname="SHA-256pkcs12" keylocationValue="oldHistorySigner" /> </descriptor> <!-- others descriptors --> classpath:hybridEncKeypair.p12" pin="1234"/> </descriptors>key> <keys> <key name="newHistorySignerconfigZipEncrypterCert"> <type name="pkcs12" locationValue="classpath:sign_newencryptConfig.p12" pin="1234"/> </key> <key name="oldHistorySignerconfigZipSignerCert"> <type name="pkcs12" locationValue="classpath:sign_old.signConfig.p12" pin="1234"/> </key> <!-- other keys --><key name="objectHistorySignerCert"> <type name="pkcs12" locationValue="classpath:sign.p12" pin="1234"/> </keys> </engineSignEncrypt> |
There are also descriptors which cannot be versioned, e.g. EncryptedFields
. For those the version always needs to be set to 1.
Configuration elements
Descriptor
See the tables below the example for more information on the different possible attributes of a descriptor/-type.
Descriptor example
Code Block | ||
---|---|---|
| ||
<descriptor name="ObjectHistorySigner" version="1"> </key> <key name="selfServiceJWTSignerCert"> <type name="pkcs12" locationValue="classpath:signJWT.p12" pin="1234"/> </key> <key name="contentProviderJWSSignerCert"> <type algorithmname="SHA-256pkcs12" keylocationValue="objectHistorySignerCertclasspath:signJWS.p12" pin="1234"/> </descriptor> |
...
descriptor
element attribute
...
Description
...
name
...
Used by Identity Manager to refer to this descriptor. There might be different descriptors with the same name but with different versions.
...
version
...
A numeric value that denotes the descriptor's version. This is only needed for the ObjectHistorySigner
.
A new version of a descriptor is needed, for example, when an old key needs to be replaced.
The descriptor with the highest version number is used. Verification of Object History entries will automatically select the right descriptor version.
...
Attribute of the type
element inside descriptor
...
Description
...
algorithm
...
For EncryptedFields
/ConfigZipEncrypter
: symmetric algorithm to be used, usually AES/CBC/PKCS7Padding
.
For SelfServiceJWTSigner
/ContentProviderJWSSigner
: always RSA
.
For ConfigZipSigner
/ObjectHistorySigner
: hashing algorithm to be used (for example, SHA-256
).
For SignEmailDescriptor
/hermodDeviceEnc
/att_*
and pin-blob decryption descriptors:
signature algorithm to be used (for example, SHA256withRSA
).
For idopteAuthentication
: always NoneWithRSA
.
...
size
...
For EncryptedFields
/ConfigZipEncrypter
only.
Size of the symmetric key, either 128
or 256
(recommended).
...
result
...
For EncryptedFields
only.
Output format, currently always NX02
.
...
key
...
The descriptor’s key. Refers to a key defined in the same document.
...
asymCipher
...
For EncryptedFields
/ConfigZipEncrypter
only.
Cipher definition, e.g. RSA/None/OAEPWithSHA384AndMGF1Padding
.
When used with an HSM, you need to adjust the cipher format to be compatible with the JCE provider
used for HSM access.
For example, instead of the above cipher definition, specify RSA/ECB/OAEPWithSHA-384AndMGF1Padding
(ECB
instead of None
and SHA-384
instead of SHA384
).
...
initVector
...
Only needed for migrating EncryptedFields
from SmartAct or ProAct. A fixed Initialization Vector (IV).
For other descriptors, omit this attribute in order to use randomly generated IVs.
Key
See the tables below the example for more information about the key/-type.
Key example
Code Block | ||
---|---|---|
| ||
<key name="objectHistorySignerCert"> </key> <key name="emailSigningCert"> <type name="pkcs12" locationValue="classpath:emailSigning.p12" pin="1234"/> </key> <key name="serverCert"> <type name="pkcs12" locationValue="classpath:deviceEncCA.p12" pin="1234"/> </key> <key name="attestationKey_mobile_1"> <type name="pkcs12" locationValue="classpath:attKeyMobile1.p12" pin="936584967"/> </key> <key name="attestationKey_mobile_2"> <type name="pkcs12" locationValue="classpath:signattKeyMobile2.p12" pin="1234873145568"/> </key> |
...
key
element attribute
...
Description
...
name
...
Used by descriptors' key attribute to reference this key.
...
Attribute of the type
element inside key
...
Description
...
name
...
Type of storage: pkcs12
or HSM
.
...
locationValue
...
For docker:
For a software keystore (pkcs12): place the keystore under docker/compose/certs before creating the container with docker compose. Then set its location as absolute path, prefixed with
file:
pointing to the mounted file in/certs
,
for example:locationValue="file:/certs/keystore.p12"
.
Note: Default attestation keys are referenced from theclasspath
, e.g.locationValue="classpath:attKeyMobileDef.p12"
. Change this only if you need your own keys.For an HSM: ensure the PKCS11 library is mounted into the container, then use the container’s path of the PKCS11 library, without filename extension, for example:
locationValue="/usr/local/lib/libpkcs11hsm"
For WAR file deployment:
For a software keystore: place the keystore under WEB-INF/classes and set its location, prefixed with
classpath:
,
for example:locationValue="classpath:keystore.p12"
For an HSM: use the path of the PKCS11 library, without filename extension,
for example:locationValue="/usr/local/lib/libpkcs11hsm"
...
pin
PIN for the keystore or HSM.
To avoid having clear text PINs in this file, the pin should be scrambled.
That can be achieved by setting it with pin.encrypted="1234"
instead of pin="1234"
.
For WAR deployments the pin will then be scrambled on the next (re-)start of Tomcat.
...
</key>
<key name="attestationKey_mobile_3">
<type name="pkcs12" locationValue="classpath:attKeyMobile3.p12" pin="8564789632"/>
</key>
<key name="attestationKey_mobile_4">
<type name="pkcs12" locationValue="classpath:attKeyMobile4.p12" pin="9263564893"/>
</key>
<key name="attestationKey_mobile_pda_def">
<type name="pkcs12" locationValue="classpath:attKeyMobileDef.p12" pin="2586453793"/>
</key>
</keys>
</engineSignEncrypt> |