source: trunk/server/fedora/config/etc/httpd/vhosts.d/reify-vhost.py @ 2257

Last change on this file since 2257 was 2227, checked in by geofft, 13 years ago
reify-vhost: Add SSLCertificateChainFile by default It makes the case of sites with intermediate certs not differ from the output of this script, and it's harmless for sites without intermediate certs.
  • Property svn:executable set to *
File size: 2.8 KB
Line 
1#!/usr/bin/python
2#
3# Converts an apacheConfig record from LDAP, as used by mod_vhost_ldap,
4# into a <VirtualHost> record as used in an Apache conf.d directory.
5# Useful for adding things like SSL server certs that mod_vhost_ldap
6# doesn't support.
7#
8# Usage:
9# scripts# cd /etc/httpd/vhosts.d
10# scripts# ./reify-vhost.py geofft > geofft.conf
11# scripts# service httpd graceful
12#
13# Geoffrey Thomas <geofft@mit.edu>, 2008, public domain.
14
15# Note: As of 1/2011 we are inserting SSLCertificateKeyFile into reified
16# hosts, because previously-acqured certificates were signed with an
17# older (1024-bit) key. Sometime around 2014 when our last cert with
18# this key expires, we can update /etc/httpd/conf/httpd.conf to point to
19# the current key instead of the old one, and stop inserting this into
20# individual vhost records. -geofft
21
22import ldap
23import ldap.filter
24import pwd
25import sys
26
27ll = ldap.initialize("ldapi://%2fvar%2frun%2fslapd-scripts.socket/")
28ll.simple_bind_s("", "")
29
30host = sys.argv[1]
31
32r = ll.search_s(
33    "ou=VirtualHosts,dc=scripts,dc=mit,dc=edu",
34    ldap.SCOPE_SUBTREE,
35    ldap.filter.filter_format(
36            "(&(objectClass=apacheConfig)" +
37            "(|(apacheServerName=%s)" +
38            "(apacheServerAlias=%s)))",
39           [host, host]))
40if len(r) != 0:
41    user = pwd.getpwuid(int(r[0][1]['apacheSuexecUid'][0]))
42    serveralias = ""
43    if 'apacheServerAlias' in r[0][1]:
44        serveralias = "ServerAlias "+" ".join(r[0][1]['apacheServerAlias'])
45    print """# do not trailing-slash DocumentRoot
46
47<VirtualHost *:80>
48        ServerName %(servername)s
49        %(serveralias)s
50        DocumentRoot %(docroot)s
51        Alias /~%(uname)s %(homedir)s/web_scripts
52        SuExecUserGroup %(uname)s %(uname)s
53        Include conf.d/vhosts-common.conf
54</VirtualHost>
55
56<IfModule ssl_module>
57        <VirtualHost *:443>
58                ServerName %(servername)s
59                %(serveralias)s
60                DocumentRoot %(docroot)s
61                Alias /~%(uname)s %(homedir)s/web_scripts
62                SuExecUserGroup %(uname)s %(uname)s
63                Include conf.d/vhosts-common-ssl.conf
64                SSLCertificateFile /etc/pki/tls/certs/%(hname)s.pem
65                SSLCertificateChainFile /etc/pki/tls/certs/%(hname)s.pem
66                SSLCertificateKeyFile /etc/pki/tls/private/scripts.key
67        </VirtualHost>
68        <VirtualHost *:444>
69                ServerName %(servername)s
70                %(serveralias)s
71                DocumentRoot %(docroot)s
72                Alias /~%(uname)s %(homedir)s/web_scripts
73                SuExecUserGroup %(uname)s %(uname)s
74                Include conf.d/vhosts-common-ssl.conf
75                Include conf.d/vhosts-common-ssl-cert.conf
76                SSLCertificateFile /etc/pki/tls/certs/%(hname)s.pem
77                SSLCertificateChainFile /etc/pki/tls/certs/%(hname)s.pem
78                SSLCertificateKeyFile /etc/pki/tls/private/scripts.key
79        </VirtualHost>
80</IfModule>""" % {
81    'servername': r[0][1]['apacheServerName'][0],
82    'serveralias': serveralias,
83    'docroot': r[0][1]['apacheDocumentRoot'][0],
84    'uname': user[0],
85    'homedir': user[5],
86    'hname': host
87}
88
89# vim: set ts=4 sw=4 et:
Note: See TracBrowser for help on using the repository browser.