signer

package
v4.0.0-...-cb4bf2f Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: May 29, 2023 License: Apache-2.0 Imports: 7 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type KMSSigner

type KMSSigner struct {
	// contains filtered or unexported fields
}

KMSSigner implements the crypto/Signer interface that can be used for signing operations using an AWS KMS key. see https://golang.org/pkg/crypto/#Signer

func New

func New(ctx context.Context, client interfaces.KMSClient, keyID string) (*KMSSigner, error)

New returns a KMSSigner instance given and AWS client and a KMS key used for signing. TODO: explain what are the pre-requisits for the KMS key. TODO: implement PublicKey caching with periodical refresh

func (*KMSSigner) Public

func (s *KMSSigner) Public() crypto.PublicKey

Public returns the public key corresponding to the opaque, private key.

func (*KMSSigner) Sign

func (s *KMSSigner) Sign(_ io.Reader, digest []byte, _ crypto.SignerOpts) ([]byte, error)

Sign signs digest with the KMS key. TODO: currently use SigningAlgorithmSpecRsassaPkcs1V15Sha256. Is that ok? TODO: should use the opts provided.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL