mirror of
https://github.com/bjc/prosody.git
synced 2025-04-03 21:27:38 +03:00
certs: Add a default OpenSSL configuration file, and a Makefile.
This commit is contained in:
parent
f79be6e720
commit
f8adb8757e
2 changed files with 80 additions and 0 deletions
28
certs/Makefile
Normal file
28
certs/Makefile
Normal file
|
@ -0,0 +1,28 @@
|
|||
.DEFAULT: localhost.cert
|
||||
keysize=2048
|
||||
|
||||
# How to:
|
||||
# First, `make yourhost.cnf` which creates a openssl config file.
|
||||
# Then edit this file and fill in the details you want it to have,
|
||||
# and add or change hosts and components it should cover.
|
||||
# Then `make yourhost.key` to create your private key, you can
|
||||
# include keysize=number to change the size of the key.
|
||||
# Then you can either `make yourhost.csr` to generate a certificate
|
||||
# signing request that you can submit to a CA, or `make yourhost.cert`
|
||||
# to generate a self signed certificate.
|
||||
|
||||
# To request a cert
|
||||
%.csr: %.cnf %.key
|
||||
openssl req -new -key $(lastword $^) -out $@ -utf8 -config $(firstword $^)
|
||||
|
||||
# Self signed
|
||||
%.cert: %.cnf %.key
|
||||
openssl req -new -x509 -nodes -key $(lastword $^) -days 365 \
|
||||
-sha1 -out $@ -utf8 -config $(firstword $^)
|
||||
|
||||
%.cnf:
|
||||
sed 's,example\.com,$*,g' openssl.cnf > $@
|
||||
|
||||
%.key:
|
||||
openssl genrsa $(keysize) > $@
|
||||
@chmod 400 -c $@
|
52
certs/openssl.cnf
Normal file
52
certs/openssl.cnf
Normal file
|
@ -0,0 +1,52 @@
|
|||
oid_section = new_oids
|
||||
|
||||
[ new_oids ]
|
||||
|
||||
# RFC 3920 section 5.1.1 defines this OID
|
||||
xmppAddr = 1.3.6.1.5.5.7.8.5
|
||||
|
||||
# RFC 4985 defines this OID
|
||||
SRVName = 1.3.6.1.5.5.7.8.7
|
||||
|
||||
[ req ]
|
||||
|
||||
default_bits = 4096
|
||||
default_keyfile = example.com.key
|
||||
distinguished_name = distinguished_name
|
||||
req_extensions = v3_extensions
|
||||
x509_extensions = v3_extensions
|
||||
|
||||
# ask about the DN?
|
||||
prompt = no
|
||||
|
||||
[ distinguished_name ]
|
||||
|
||||
commonName = example.com
|
||||
countryName = UK
|
||||
localityName = The Internet
|
||||
organizationName = Your Organisation
|
||||
organizationalUnitName = XMPP Department
|
||||
emailAddress = xmpp@example.com
|
||||
|
||||
[ v3_extensions ]
|
||||
|
||||
# for certificate requests (req_extensions)
|
||||
# and self-signed certificates (x509_extensions)
|
||||
|
||||
basicConstraints = CA:FALSE
|
||||
keyUsage = digitalSignature,keyEncipherment
|
||||
extendedKeyUsage = serverAuth,clientAuth
|
||||
subjectAltName = @subject_alternative_name
|
||||
|
||||
[ subject_alternative_name ]
|
||||
|
||||
# See http://tools.ietf.org/html/draft-ietf-xmpp-3920bis#section-13.7.1.2 for more info.
|
||||
|
||||
DNS.0 = example.com
|
||||
otherName.0 = xmppAddr;UTF8:example.com
|
||||
otherName.1 = SRVName;IA5STRING:_xmpp-client.example.com
|
||||
otherName.2 = SRVName;IA5STRING:_xmpp-server.example.com
|
||||
|
||||
DNS.1 = conference.example.com
|
||||
otherName.3 = xmppAddr;UTF8:conference.example.com
|
||||
otherName.4 = SRVName;IA5STRING:_xmpp-server.conference.example.com
|
Loading…
Add table
Add a link
Reference in a new issue