mirror of
https://github.com/elyby/accounts-profiles-endpoint.git
synced 2024-11-30 02:32:09 +05:30
62 lines
1.1 KiB
Go
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
|
|
}
|