Documentation ¶
Index ¶
- func GenerateJWTKeysetsFromCloudKMS(keyUri string, credentialsJSON []byte) (privateEc256 []byte, publicEc256 []byte, err error)
- func GenerateLocalKeys() (masterKey []byte, privateEc256 []byte, publicEc256 []byte, err error)
- func GenerateRandomBytes(n int) (string, error)
- func NewCloudKMSEncryption(keyUri string, credentialsJSON, privateEc256, publicEc256 []byte) (*cloudkmsEncryptionService, error)
- func NewLocalEncryption(masterKey []byte, privateEc256 []byte, publicEc256 []byte) (*localEncryptionService, error)
- type EncryptionService
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func GenerateLocalKeys ¶
func GenerateRandomBytes ¶
GenerateRandomBytes generates a random string of n bytes.
func NewCloudKMSEncryption ¶
func NewCloudKMSEncryption(keyUri string, credentialsJSON, privateEc256, publicEc256 []byte) (*cloudkmsEncryptionService, error)
NewCloudKMSEncryption creates a GCP CloudKMS-backed encryption service.
func NewLocalEncryption ¶
func NewLocalEncryption(masterKey []byte, privateEc256 []byte, publicEc256 []byte) (*localEncryptionService, error)
NewLocalEncryption creates a new local encryption service. keysetBytes is the raw keyset in base64-encoded JSON format. This can be generated by calling hatchet-admin keyset create-local.
Types ¶
type EncryptionService ¶
type EncryptionService interface { // Encrypt encrypts the given plaintext with the given data id. The data id is used to // associate the ciphertext with the data in the database. // For more information, see: https://developers.google.com/tink/client-side-encryption#kms_envelope_aead Encrypt(plaintext []byte, dataId string) ([]byte, error) // Decrypt decrypts the given ciphertext with the given data id. The data id is used to // associate the ciphertext with the data in the database. // For more information, see: https://developers.google.com/tink/client-side-encryption#kms_envelope_aead Decrypt(ciphertext []byte, dataId string) ([]byte, error) // GetPrivateJWTHandle returns a private JWT handle. This is used to sign JWTs. GetPrivateJWTHandle() *keyset.Handle // GetPublicJWTHandle returns a public JWT handle. This is used to verify JWTs. GetPublicJWTHandle() *keyset.Handle }
Click to show internal directories.
Click to hide internal directories.