Documentation ¶
Overview ¶
Package profile provides different profiles to run GopenPGP.
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func PresetProfiles ¶
func PresetProfiles() []string
PresetProfiles returns the names of the available profiles.
Types ¶
type Custom ¶
type Custom struct { // Name defines the name of the custom profile. Name string // SetKeyAlgorithm is a function that sets public key encryption // algorithm in the config bases on the int8 security level. SetKeyAlgorithm func(*packet.Config, int8) // AeadKeyEncryption defines the aead encryption algorithm for key encryption. AeadKeyEncryption *packet.AEADConfig // S2kKeyEncryption defines the s2k algorithm for key encryption. S2kKeyEncryption *s2k.Config // AeadEncryption defines the aead encryption algorithm for pgp encryption. // If nil, aead is disabled even if the key supports it. AeadEncryption *packet.AEADConfig // KeyGenAeadEncryption defines if the output key in key generation // advertises SEIPDv2 and aead algorithms in its key preferences. // If nil, uses AeadEncryption as key preferences. KeyGenAeadEncryption *packet.AEADConfig // S2kEncryption defines the s2k algorithm for pgp encryption. S2kEncryption *s2k.Config // CompressionConfiguration defines the compression configuration to be used if any. CompressionConfiguration *packet.CompressionConfig // Hash defines hash algorithm to be used. Hash crypto.Hash // SignHash defines if a different hash algorithm should be used for signing. // If nil, the a above field Hash is used. SignHash *crypto.Hash // CipherKeyEncryption defines the cipher to be used for key encryption. CipherKeyEncryption packet.CipherFunction // CipherEncryption defines the cipher to be used for pgp message encryption. CipherEncryption packet.CipherFunction // CompressionAlgorithm defines the compression algorithm to be used if any. CompressionAlgorithm packet.CompressionAlgo // V6 is a flag to indicate if v6 from the crypto-refresh should be used. V6 bool // AllowAllPublicKeyAlgorithms is a flag to disable all checks for deprecated public key algorithms. AllowAllPublicKeyAlgorithms bool // DisableIntendedRecipients is a flag to disable the intended recipients pgp feature from the crypto-refresh. DisableIntendedRecipients bool // AllowWeakRSA is a flag to disable checks for weak rsa keys. AllowWeakRSA bool }
Custom type represents a profile for setting algorithm parameters for generating keys, encrypting data, and signing data. Use one of the pre-defined profiles if possible. i.e., profile.Default(), profile.RFC4880().
func CryptoRefresh ¶
func CryptoRefresh() *Custom
CryptoRefresh returns a custom profile for this library that conforms with the algorithms in draft-ietf-openpgp-crypto-refresh.
func Default ¶
func Default() *Custom
Default returns a custom profile that support features that are widely implemented.
func GnuPG ¶
func GnuPG() *Custom
GnuPG returns a custom profile for this library that conforms with the algorithms in GnuPG. Use this profile for modern algorithms and GnuPG interoperability.
func RFC4880 ¶
func RFC4880() *Custom
RFC4880 returns a custom profile for this library that conforms with the algorithms in rfc 4880.