SignTool
INFO
This documentation is for FAKE version 5.0 or later. The old documentation can be found here.
This module is a wrapper around the signtool.exe tool, a command-line tool that digitally signs files, verifies signatures in files, or time stamps files.
The 3 supported functions are:
- SignTool.sign: digitally signing files
- SignTool.timeStamp: time stamping previously signed files
- SignTool.verify: verify signed files
Additional information:
- Common options: options common to all supported functions
- Certificates: notes and how to get one
- SHA1/SHA256: differences and when to use which
API Reference:
- SignTool: The SignTool tool is a command-line tool that digitally signs files, verifies signatures in files, or time stamps files.
- CertificateFromFile: Specifies parameters to use when using a certificate from a file.
- CertificateFromStore: Specifies parameters to use when using a certificate from a certificate store.
- SignCertificate: Specifies what type of certificate to use.
- SignOptions: Sign command options
- TimeStampOption: Specifies the URL of the time stamp server and the digest algorithm used by the RFC 3161 time stamp server.
- TimeStampOptions: Timestamp command options
- VerifyOptions: Verify command options
Open namespace
| 1: 
 |  | 
Signing
Digitally signing files.
A certificate is needed to do this.
When the certificate is located in a .pfx file
Only PFX files are supported by signtool.exe.
| 1: 2: 3: 4: 5: 6: 7: 8: 9: 10: 11: 12: |  | 
Only a subset of options is shown in the example, see API Reference for all available options: CertificateFromFile, SignOptions.
When the certificate is located in a certificate store
All options are optional, and any combination may be used, depending on specific needs.
If no StoreName is specified, the "My" store is opened.
| 1: 2: 3: 4: 5: 6: 7: 8: 9: 10: 11: 12: 13: |  | 
Only a subset of options is shown in the example, see API Reference for all available options: CertificateFromStore, SignOptions.
Custom signing options
Use SHA256 (see SHA1/SHA256) to create file signatures.
| 1: 2: 3: 4: 5: 6: 7: 8: 9: 10: |  | 
Only a subset of options is shown in the example, see API Reference for all available options: SignOptions.
Adding a time stamp
Time stamp at the same time as signing.
There is a separate function signWithTimeStamp that, compared to sign, has 2 additional parameters to set time stamping options.
If you want to time stamp previously signed files, use the Time stamping function.
For more information about time stamping see Time stamping.
| 1: 2: 3: 4: 5: 6: 7: 8: 9: 10: 11: 12: 13: |  | 
Only a subset of options is shown in the example, see API Reference for all available options: SignOptions, TimeStampOption.
Custom time stamp options
Use SHA256 (see SHA1/SHA256).
| 1: 2: 3: 4: 5: 6: 7: 8: 9: 10: 11: 12: 13: 14: |  | 
Only a subset of options is shown in the example, see API Reference for all available options: SignOptions, TimeStampOption.
Time stamping
Time stamping previously signed files.
When signing a file, the signature is valid only as long as the certificate used to create it is valid. The moment the certificate expires, the signature becomes invalid. Time stamping is used to extend the validity of the signature. A time stamp proves that the signature was created while the certificate was still valid and effectively extends the signature's validity indefinitely.
Default options
Time stamp server does not have to be from the same CA as the certificate.
| 1: 2: 3: 4: 5: 6: 7: 8: 9: |  | 
Only a subset of options is shown in the example, see API Reference for all available options: TimeStampOptions.
Custom options
Use SHA256 (see SHA1/SHA256).
| 1: 2: 3: 4: 5: 6: 7: 8: 9: 10: |  | 
Only a subset of options is shown in the example, see API Reference for all available options: TimeStampOption, TimeStampOptions.
Verifying
Verify signed files.
The verify command determines whether the signing certificate was issued by a trusted authority, whether the signing certificate has been revoked, and, optionally, whether the signing certificate is valid for a specific policy.
Default options
| 1: 2: 3: 4: 5: 6: 7: |  | 
Only a subset of options is shown in the example, see API Reference for all available options: VerifyOptions.
Custom options
| 1: 2: 3: 4: 5: 6: 7: 8: 9: 10: 11: |  | 
Only a subset of options is shown in the example, see API Reference for all available options: VerifyOptions.
Common options
All functions share some common options.
Tool options - path to signtool.exe, execution timeout, working directory. These options are not set by default.
| 1: 2: 3: 4: 5: 6: 7: 8: 9: 10: |  | 
Debug - displays debugging information (signtool option: /debug). This option is not set by default.
| 1: 2: 3: 4: 5: 6: 7: 8: 9: |  | 
Verbosity - output verbosity (signtool options: /q, /v). This option is not set by default.
| 1: 2: 3: 4: 5: 6: 7: 8: 9: |  | 
API Reference: SignOptions, TimeStampOptions, VerifyOptions, Verbosity.
Certificates
The SignTool needs a certificate to sign files.
Prod / release
For production / release purposes a proper publically trusted code signing certificate may be purchased from many CA's.
Dev / test
For dev and testing purposes a certificate can be created using the New-SelfSignedCertificate PowerShell cmdlet:
| 1: 2: 3: 4: 5: 6: 7: 8: |  | 
This creates the certificate under "Certificates - Current User" -> "Personal" -> "Certificates" and prints the certificate Thumbprint. The certificate can be used as-is using the CertificateFromStore option.
If you want to export the certificate to a file, use the Export-PfxCertificate PowerShell cmdlet. Replace "{Thumbprint}" with the value from New-SelfSignedCertificate output:
| 1: 2: |  | 
Now the certificate can be used with the CertificateFromFile option.
This certificate should not be used for prod / release purposes as it is self-signed and not trusted.
SHA1/SHA256
If the signed binaries are run on Windows 7 or newer, using SHA256 only is fine - this is also the default value for DigestAlgorithm (/fd and /td options).
If the signed binaries are run on Windows older than Windows 7, SHA1 should be used.
If the signed binaries are run on newer and older versions of Windows, then dual signing is probably the way to go. This means signing all binaries twice - first using SHA1, and then SHA256. Make sure to set AppendSignature to true when signing the second time, otherwise the first signature will be replaced. More information about dual signing.