2025-07-07 11:25:58 -04:00
|
|
|
package varsig
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"encoding/binary"
|
|
|
|
|
)
|
|
|
|
|
|
2025-08-05 15:35:12 +02:00
|
|
|
// AlgorithmRSA is the value specifying an RSA signature.
|
|
|
|
|
const AlgorithmRSA = Algorithm(0x1205)
|
2025-07-07 11:25:58 -04:00
|
|
|
|
2025-07-08 18:38:23 +02:00
|
|
|
var _ Varsig = RSAVarsig{}
|
2025-07-07 11:25:58 -04:00
|
|
|
|
|
|
|
|
// RSAVarsig is a varsig that encodes the parameters required to describe
|
2025-07-08 07:34:57 -04:00
|
|
|
// an RSA signature.
|
2025-07-07 11:25:58 -04:00
|
|
|
type RSAVarsig struct {
|
2025-07-08 18:38:23 +02:00
|
|
|
varsig
|
2025-07-22 11:27:24 +02:00
|
|
|
hashAlg Hash
|
2025-07-28 18:40:45 +02:00
|
|
|
keyLen uint64
|
2025-07-07 11:25:58 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// NewRSAVarsig creates and validates an RSA varsig with the provided
|
2025-07-08 07:34:57 -04:00
|
|
|
// hash algorithm, key length and payload encoding.
|
2025-07-28 18:40:45 +02:00
|
|
|
func NewRSAVarsig(hashAlgorithm Hash, keyLen uint64, payloadEncoding PayloadEncoding) RSAVarsig {
|
|
|
|
|
return RSAVarsig{
|
2025-07-08 18:38:23 +02:00
|
|
|
varsig: varsig{
|
2025-08-05 15:35:12 +02:00
|
|
|
algo: AlgorithmRSA,
|
2025-07-08 07:34:57 -04:00
|
|
|
payEnc: payloadEncoding,
|
2025-07-07 11:25:58 -04:00
|
|
|
},
|
|
|
|
|
hashAlg: hashAlgorithm,
|
2025-07-28 18:40:45 +02:00
|
|
|
keyLen: keyLen,
|
2025-07-07 11:25:58 -04:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2025-07-08 07:34:57 -04:00
|
|
|
// Encode returns the encoded byte format of the RSAVarsig.
|
2025-07-07 11:25:58 -04:00
|
|
|
func (v RSAVarsig) Encode() []byte {
|
|
|
|
|
buf := v.encode()
|
2025-07-28 18:40:45 +02:00
|
|
|
|
2025-07-07 11:25:58 -04:00
|
|
|
buf = binary.AppendUvarint(buf, uint64(v.hashAlg))
|
2025-07-28 18:40:45 +02:00
|
|
|
buf = binary.AppendUvarint(buf, v.keyLen)
|
2025-07-24 13:53:03 +02:00
|
|
|
buf = append(buf, EncodePayloadEncoding(v.payEnc)...)
|
2025-07-07 11:25:58 -04:00
|
|
|
|
|
|
|
|
return buf
|
|
|
|
|
}
|
|
|
|
|
|
2025-07-22 11:27:24 +02:00
|
|
|
// Hash returns the value describing the hash algorithm used to hash
|
|
|
|
|
// the payload content before the signature is generated.
|
|
|
|
|
func (v RSAVarsig) Hash() Hash {
|
2025-07-07 11:25:58 -04:00
|
|
|
return v.hashAlg
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// KeyLength returns the length of the RSA key used to sign the payload
|
|
|
|
|
// content.
|
2025-07-08 18:38:23 +02:00
|
|
|
func (v RSAVarsig) KeyLength() uint64 {
|
2025-07-28 18:40:45 +02:00
|
|
|
return v.keyLen
|
2025-07-07 11:25:58 -04:00
|
|
|
}
|
|
|
|
|
|
2025-07-28 18:40:45 +02:00
|
|
|
func decodeRSA(r BytesReader) (Varsig, error) {
|
2025-07-07 11:25:58 -04:00
|
|
|
hashAlg, err := DecodeHashAlgorithm(r)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, err
|
|
|
|
|
}
|
|
|
|
|
|
2025-07-28 18:40:45 +02:00
|
|
|
keyLen, err := binary.ReadUvarint(r)
|
2025-07-07 11:25:58 -04:00
|
|
|
if err != nil {
|
|
|
|
|
return nil, err
|
|
|
|
|
}
|
|
|
|
|
|
2025-07-28 18:40:45 +02:00
|
|
|
payEnc, err := DecodePayloadEncoding(r)
|
2025-07-08 18:38:23 +02:00
|
|
|
if err != nil {
|
|
|
|
|
return nil, err
|
|
|
|
|
}
|
|
|
|
|
|
2025-07-28 18:40:45 +02:00
|
|
|
return NewRSAVarsig(hashAlg, keyLen, payEnc), nil
|
2025-07-07 11:25:58 -04:00
|
|
|
}
|