blob: 22c35d4dd72e490fbca8053d53dbf12ef11b838e (
plain) (
tree)
|
|
package pki
import (
"crypto"
)
// this file holds all the interfaces used in the program until it can be split
// properly
const PemLabelPublic = "PUBLIC KEY"
type (
// interface for any private key
PrivateKey interface {
// derive a public key from the private key
Public() PublicKey
// Sign a message using the public key and the given hash method.
// To use a hash method, include the package
// import _ "crypto/sha512"
Sign(message []byte, hash crypto.Hash) ([]byte, error)
// return the private key structure
privateKey() crypto.PrivateKey
}
// interface for any public key
PublicKey interface {
Pemmer
// use the public key to verify a message against a signature
Verify(message []byte, signature []byte, hash crypto.Hash) (bool, error)
}
Pemmer interface {
MarshalPem() (marshalledPemBlock, error)
}
)
|