aboutsummaryrefslogtreecommitdiff
path: root/crypto/x509/csr.go
blob: 76ea80919cebbb9adfad265c9584a67d865e5eb7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
package x509

import (
	"crypto/rand"
	"crypto/rsa"
	"crypto/x509"
	"crypto/x509/pkix"
)

const defaultRSAKeyStrength = 4096

func GenerateRSAKeyCSR(domains ...string) ([]byte, *rsa.PrivateKey, error) {
	ckey, err := rsa.GenerateKey(rand.Reader, defaultRSAKeyStrength)
	if err != nil {
		return nil, nil, err
	}

	csr, err := x509.CreateCertificateRequest(rand.Reader, &x509.CertificateRequest{
		Subject:         pkix.Name{CommonName: domains[0]},
		DNSNames:        domains,
		ExtraExtensions: []pkix.Extension{},
	}, ckey)
	if err != nil {
		return nil, nil, err
	}

	return csr, ckey, nil
}