accounts-profiles-endpoint/internal/services/signer/local.go
2024-10-01 01:41:29 +02:00

62 lines
1.1 KiB
Go

package signer
import (
"bytes"
"context"
"crypto"
"crypto/rand"
"crypto/rsa"
"crypto/sha1"
"crypto/x509"
"encoding/pem"
"errors"
"io"
)
var randomReader = rand.Reader
var invalidKeyFormat = errors.New(`invalid key format: it should be "der" or "pem"`)
type Local struct {
Key *rsa.PrivateKey
}
func NewLocal(key *rsa.PrivateKey) *Local {
return &Local{key}
}
func (s *Local) Sign(ctx context.Context, data []byte) ([]byte, error) {
messageHash := sha1.New()
_, err := io.Copy(messageHash, bytes.NewReader(data))
if err != nil {
return nil, err
}
messageHashSum := messageHash.Sum(nil)
signature, err := rsa.SignPKCS1v15(randomReader, s.Key, crypto.SHA1, messageHashSum)
if err != nil {
return nil, err
}
return signature, nil
}
func (s *Local) GetPublicKey(ctx context.Context, format string) ([]byte, error) {
if format != "der" && format != "pem" {
return nil, invalidKeyFormat
}
asn1Bytes, err := x509.MarshalPKIXPublicKey(s.Key.Public())
if err != nil {
return nil, err
}
if format == "pem" {
return pem.EncodeToMemory(&pem.Block{
Type: "PUBLIC KEY",
Bytes: asn1Bytes,
}), nil
}
return asn1Bytes, nil
}