Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 19 Next »

This article is valid for Smart ID Identity Manager 24.R1 or later.

Here you can find information on common error scenarios related to the sign and encrypt engine and how to solve them.

Before doing any repair procedures, a backup of the IDM applications, config files and database is recommended.

Error Message(s) Logged On Startup: Compromised key detected ...

Upon startup of IDM you might see one or more error messages like the one below:

Compromised key detected: Descriptor [SelfServiceJWTSigner (version: 1)] in engineSignEncrypt config xml. This is a SECURITY RISK on productive systems. It is ESSENTIAL to replace it with a new secure key.

This means that one or more demo keys (considered compromised and unfit for productive use) are still in use. Each message indicates the offending descriptor and version from the config XML.

For replacing these keys see Bootstrapping the sign and encrypt engine.

Replacing the EncryptedFields descriptor's key requires re-encryption of existing secrets via the batch_secretfieldstore_change_encryption_key tool.
See Change Encryption key of secret field store .

Replacing the ObjectHistorySigner descriptor's key requires re-signing existing history entries via the batch_re-sign_history tool.

Replacing the ConfigZipSigner descriptor's key means any previously exported encrypted config ZIP files cannot be decrypted anymore (versioning to enable decryption with historical keys is not yet supported here).

Startup Fails With Exception Message: Aborting deployment! Unable to verify the last Object History entry ...

Startup of IDM might fail with an exception message like this in the log:

Aborting deployment! Unable to verify the last Object History entry of the chain [PRIME1]. There appears to be an error in the engineSignEncrypt configuration of the descriptor [ObjectHistorySigner (version: 2)]. The referenced key is probably wrong. Another possible explanation for this error is that the ObjectHistory entry was manipulated. Offending entry id: [4711]. Please check the engineSignEncrypt config xml and the referenced keys! If the configured key is correct, the entry might be corrupted. This can be worked around by starting a new chain.

Some potential causes:

  1. The key configured for the ObjectHistorySigner descriptor in the current version (2 in the example error message above) is wrong, maybe you configured the wrong P12 file.

  2. The object history got corrupted (by accident or deliberate manipulation - forensic analysis may be advisable).
    A quick workaround to get the application to start again would be switching to a new chain name for idm-operator (history verification will still fail, though):

    Tomcat deployment: set chain name in system.properties

    ... etc. ...
    commonHistoryService.chainName=NEW_CHAIN_NAME_GOES_HERE
    ... etc. ...


    Docker-deployment: set chain name in docker-compose.yml

    ... etc. ...
        environment:
    ... etc. ...
          - 'SYSTEM_PROPERTIES={
              "commonHistoryService.chainName": "NEW_CHAIN_NAME_GOES_HERE",
    ... etc. ...


    You can solve this properly by re-signing the history entries via the batch_re-sign_history tool.

Startup Fails With Exception Message: Error accessing the sign and encrypt engine ( There's no keystore ...

Startup of IDM might fail with an exception message like this in the log:

Error accessing the sign and encrypt engine ( There's no keystore at classpath:hybridEncKeypair.p12)

This means that the config XML for the sign and encrypt engine references a file that does not exist at the given location.

All files referenced via the location classpath: usually need to be inside the WEB-INF\classes\ folder of the web application.

In IDM versions before 24.R1 that folder did contain all demo keys, which were since removed. Furthermore, the engineSignEncryptConfig.xml shipped in WAR files of 24.R1 and above references additional P12 files not used or not bootstrapped previously (by default we use a dedicated P12 file per descriptor, instead of sharing them).

Refer to Bootstrapping the sign and encrypt engine to bootstrap any missing keys/certificates.

  • No labels