Overview
Gnu Privacy Guard, also known as GPG or GnuPG, is an Open Source implementation of the OpenPGP standard. This section provides information about using GPG with SignPath, as well as some code signing tools that build on GPG.
Using GnuPG with PKCS #11
GnuPG does not directly support the PKCS #11/Cryptoki interface. The gnupg-pkcs11-scd project adds this capability as a daemon for the GnuPG “Smartcard” interface.
Setup
Configuring GnuPG
Configure the SignPath Cryptoki provider for
- GnuPG in
gpg-agent.conf
- gnupg-pkcs11-scd in
gnupg-pkcs11-scd.conf
For more details see
- Crypto Provider configuration documentation
samples/Scenarios/Gpg
in the Linux container samples (details about configuration and necessary dependencies)
Error logs
For gnupg-pkcs11-scd
, stdout
console output must be disabled. Use the log files for troubleshooting.
For the Linux container samples, the following log file locations are configured:
- SignPath Cryptoki logs:
samples/Scenarios/temp/SignPathLogs/*.log
gnupg-pkcs11
logs:samples/Scenarios/temp/gnupg-pkcs11-scd.log
- GPG logs:
samples/Scenarios/temp/gpg-agent.log
GPG Key Generation
GPG terminology: public keys
GPG uses the term public key for a specific file format that includes the actual public key key, the holder’s identity (name, email address), expiration, and other data. It is therefore more similar to a certificate than just a public key.
This sometimes creates confusion about whether the term public key refers to just the public part of the cryptographic key pair, or an entire GPG public key.
To use GPG with SignPath, you need to create an X.509 certificate for the cryptographic key pair, and a separate GPG public key on your computer. The GPG public key will contain the cryptographic public key from the certificate and reference the private key, which will remain with SignPath.
The reference is implemented as a “shadowed private key” and references a SignPath project slug and signing policy slug. (It is stored in $GNUPGHOME/private-keys-v1.d/$KeyGrip.key
and can be restored from the GPG public key.)
Tip: Create a self-signed certificate in SignPath
We recommend that you create a self-signed certificate in SignPath for each GPG public key. While the certificate’s metadata is not used, you might want to use similar values as for the GPG public key for clarity.
However, technically you can use any code signing certificate, including those issued by Certificate Authorities, with arbitrary metadata
Sample code to create a GPG public key
The Linux container samples contain scripts to generate a GPG key. Sample invocation:
run_scenario.sh ... -Scenario GenerateGpgKey \ -ProjectSlug "hash-signing" -SigningPolicySlug "test-signing" \ -GpgKeyName "Test GPG Key" -GpgKeyEmail "gpg-signing@example.com" -GpgKeyExpiry "1y"
Result:
- A GPG key exported to
samples/Scenarios/Gpg/Keys
including the public key- A corresponding revocation certificate in the
openpgp-revocs.d
subdirectoryGPG key generation causes two SignPath hash signing operations:
- self-sign the key
- sign the revocation certificate
In case errors appear, check out the error logs.
Prepare for signing
- Copy the generated public GPG key (
$Email.public.pgp
) to the target system. - Execute
SCD LEARN
to restore the shadowed keys. For details, see theUseSignPathCryptokiGpgConfiguration
function in the GPG scenario of the Linux container samples. - Import the GPG key . See the
ImportGpgKeys
function in the GPG scenario of the Linux container samples.
Signing code with GPG
GPG File Signing
The Linux container samples contain a full example to sign and verify a file with a detached signature (including the mentioned preparation steps) in run_scenario.sh ... -Scenario GpgSignFile -GpgKeyEmail "gpg-signing@example.com"
. The used GPG key is referenced via its email address.
During gpg --sign
, SignPath is called to perform a hash based signing operation with the Project / Signing Policy referenced in the shadowed private key. Note that the OrganizationId and the ApiToken still need to be passed to the SignPath Crypto Provider to authenticate the request.
RPM Signing (Linux)
The Linux container samples contain a full example to sign and verify a RPM file in run_scenario.sh ... -Scenario SignRpm -GpgKeyEmail "gpg-signing@example.com"
. The used GPG key is referenced via its email address. See SignRpm.ps1
for details.
During rpm --addsign
, SignPath is called to perform a hash based signing operation with the Project / Signing Policy referenced in the shadowed private key. Note that the OrganizationId and the ApiToken still need to be passed to the SignPath Crypto Provider to authenticate the request.
DEB Signing via dpkg-sig (Linux)
The Linux container samples contain a full example to sign and verify a DEB file using dpkg-sig in run_scenario.sh ... -Scenario SignDeb -GpgKeyEmail "gpg-signing@example.com"
. The used GPG key is referenced via its email address. Note the passed default “sign role” value of "builder"
.
During dpkg-sig --sign
, SignPath is called to perform a hash based signing operation with the project / signing policy referenced in the shadowed private key. Note that OrganizationId and the ApiToken still need to be passed to the SignPath Crypto Provider to authenticate the request.
Maven Artifact Signing (Linux)
The Linux container samples contain a full example to build, sign and verify Maven artifacts using the Apache maven-gpg-plugin in run_scenario.sh ... -Scenario SignMaven -GpgKeyEmail "gpg-signing@example.com"
. The used GPG key is referenced via its email address.
During mvn install
, SignPath is called to perform a hash based signing operations with the Project / Signing Policy referenced in the shadowed private key. Note that the OrganizationId and the ApiToken still need to be passed to the SignPath Crypto Provider to authenticate the request.