Digital Signatures
Why Verify Digital Signatures
  It might happen that a TrueCrypt installation package you download from our server was created or modified by an attacker. For example, the attacker could exploit a vulnerability in the server software we use and alter the installation packages stored on the server, or he/she could alter any of the files en route to you.
  
  Therefore, you should always verify the integrity and authenticity of each TrueCrypt distribution package you download or otherwise obtain from any source. In other words, you should always make sure that the file was created by us and it was not altered by an attacker. One way to do so is to verify so-called digital signature(s) of the file.
Types of Digital Signatures We Use
We currently use two types of digital signatures:
- PGP signatures (available for all binary and source code packages for all supported systems).
- X.509 signatures (available for binary packages for Windows).
Advantages of X.509 Signatures
X.509 signatures have the following advantages, in comparison to PGP signatures:
- It is much easier to verify that the key that signed the file is really ours (not attacker’s).
- You do not have to download or install any extra software to verify an X.509 signature (see below).
- You do not have to download and import our public key (it is embedded in the signed file).
- You do not have to download any separate signature file (the signature is embedded in the signed file).
Advantages of PGP Signatures
PGP signatures have the following advantages, in comparison to X.509 signatures:
- They do not depend on any certificate authority (which might be, e.g., infiltrated or controlled by an adversary, or be untrustworthy for other reasons).
How to Verify X.509 Signatures
Please note that X.509 signatures are currently available only for the TrueCrypt self-extracting installation packages for Windows. An X.509 digital signature is embedded in each of those files along with the digital certificate of the TrueCrypt Foundation issued by a public certification authority. To verify the integrity and authenticity of a self-extracting installation package for Windows, follow these steps:
- Download the TrueCrypt self-extracting installation package.
- In Windows Explorer, right-click the downloaded file (“TrueCrypt Setup.exe”) and select “Properties” from the context menu.
- In the Properties dialog window, select the “Digital Signatures” tab.
- On the “Digital Signatures” tab, in the “Signature list”, double-click the line saying “TrueCrypt Foundation”.
- 
    The “Digital Signature Details” dialog window should appear now. If you see the following sentence at the top of the dialog window, then the integrity and authenticity of the package have been successfully verified:
    
 “This digital signature is OK.”
 If you do not see the above sentence, the file is very likely corrupted.
 Note: On some obsolete versions of Windows, some of the necessary certificates are missing, which causes the signature verification to fail.
How to Verify PGP Signatures
To verify a PGP signature, follow these steps:
- Install any public-key encryption software that supports PGP signatures.
- Create a private key (for information on how to do so, please see the documentation for the public-key encryption software).
- Download our PGP public key from our server or from a trusted public key repository, and import the downloaded key to your keyring (for information on how to do so, please see the documentation for the public-key encryption software).
- 
    Sign the imported key with your private key to mark it as trusted (for information on how to do so, please see the documentation for the public-key encryption software).
    
 Note: If you skip this step and attempt to verify any of our PGP signatures, you will receive an error message stating that the signing key is invalid.
- Download the digital signature by clicking the PGP Signature button next to the file you want to verify (on one of the download pages).
- Verify the downloaded signature (for information on how to do so, please see the documentation for the public-key encryption software).
Advantages of X.509 Signatures
X.509 signatures have the following advantages, in comparison to PGP signatures:
- It is much easier to verify that the key that signed the file is really ours (not attacker’s).
- You do not have to download or install any extra software to verify an X.509 signature.
- You do not have to download and import our public key (it is embedded in the signed file).
- You do not have to download any separate signature file (the signature is embedded in the signed file).
Advantages of PGP Signatures
PGP signatures have the following advantages, in comparison to X.509 signatures:
- They do not depend on any certificate authority.
How to Verify X.509 Signatures
Please note that X.509 signatures are currently available only for the TrueCrypt self-extracting installation packages for Windows. An X.509 digital signature is embedded in each of those files along with the digital certificate of the TrueCrypt Foundation issued by a public certification authority. To verify the integrity and authenticity of a self-extracting installation package for Windows, follow these steps:
- Download the TrueCrypt self-extracting installation package.
- Right-click the downloaded file (“TrueCrypt Setup.exe”) and select “Properties”.
- In the Properties dialog, select the “Digital Signatures” tab.
- Double-click the line saying “TrueCrypt Foundation” in the signature list.
- The “Digital Signature Details” dialog should appear. If you see the sentence “This digital signature is OK.” at the top, then the package’s integrity and authenticity have been verified. Otherwise, the file is likely corrupted.
How to Verify PGP Signatures
To verify a PGP signature, follow these steps:
- Install public-key encryption software that supports PGP signatures.
- Create a private key (consult your software's documentation).
- Download our PGP public key and import it to your keyring.
- 
    Sign the imported key with your private key to mark it as trusted.
    
 Note: If you skip this step, verifying our PGP signatures will result in an error.
- Download the digital signature by clicking the PGP Signature button on the download pages.
- Verify the downloaded signature (consult your software's documentation).