Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

golang - marshal PKCS8 private key?

Tags:

go

pkcs#8

Is there a way to marshal a PKCS8 private key in go 1.5?
e.g. something similar to or starting from x509.MarshalPKCS1PrivateKey?

like image 465
Dan Tanner Avatar asked Nov 26 '15 06:11

Dan Tanner


2 Answers

Funny enough, there are no standard function to do that, but here is a custom solution:

type pkcs8Key struct {
    Version             int
    PrivateKeyAlgorithm []asn1.ObjectIdentifier
    PrivateKey          []byte
}


func rsa2pkcs8(key *rsa.PrivateKey) ([]byte, error) {
    var pkey pkcs8Key
    pkey.Version = 0 
    pkey.PrivateKeyAlgorithm = make([]asn1.ObjectIdentifier, 1)
    pkey.PrivateKeyAlgorithm[0] = asn1.ObjectIdentifier{1, 2, 840, 113549, 1, 1, 1}
    pkey.PrivateKey = x509.MarshalPKCS1PrivateKey(key)

    return asn1.Marshal(pkey)
}
like image 139
kofemann Avatar answered Oct 13 '22 13:10

kofemann


Since the above answer was written, go 1.10 has been released with a x509.MarshalPKCS8PrivateKey method.

like image 34
James Roper Avatar answered Oct 13 '22 13:10

James Roper