| Index: tools/telemetry/third_party/gsutilz/third_party/boto/boto/pyami/installers/ubuntu/trac.py
|
| diff --git a/tools/telemetry/third_party/gsutilz/third_party/boto/boto/pyami/installers/ubuntu/trac.py b/tools/telemetry/third_party/gsutilz/third_party/boto/boto/pyami/installers/ubuntu/trac.py
|
| deleted file mode 100644
|
| index 8c51c8f7201d3134d411dac1dc54021a560f61ba..0000000000000000000000000000000000000000
|
| --- a/tools/telemetry/third_party/gsutilz/third_party/boto/boto/pyami/installers/ubuntu/trac.py
|
| +++ /dev/null
|
| @@ -1,139 +0,0 @@
|
| -# Copyright (c) 2008 Chris Moyer http://coredumped.org
|
| -#
|
| -# Permission is hereby granted, free of charge, to any person obtaining a
|
| -# copy of this software and associated documentation files (the
|
| -# "Software"), to deal in the Software without restriction, including
|
| -# without limitation the rights to use, copy, modify, merge, publish, dis-
|
| -# tribute, sublicense, and/or sell copies of the Software, and to permit
|
| -# persons to whom the Software is furnished to do so, subject to the fol-
|
| -# lowing conditions:
|
| -#
|
| -# The above copyright notice and this permission notice shall be included
|
| -# in all copies or substantial portions of the Software.
|
| -#
|
| -# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
| -# OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABIL-
|
| -# ITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT
|
| -# SHALL THE AUTHOR BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
|
| -# WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
| -# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
|
| -# IN THE SOFTWARE.
|
| -#
|
| -from boto.pyami.installers.ubuntu.installer import Installer
|
| -import boto
|
| -import os
|
| -
|
| -class Trac(Installer):
|
| - """
|
| - Install Trac and DAV-SVN
|
| - Sets up a Vhost pointing to [Trac]->home
|
| - Using the config parameter [Trac]->hostname
|
| - Sets up a trac environment for every directory found under [Trac]->data_dir
|
| -
|
| - [Trac]
|
| - name = My Foo Server
|
| - hostname = trac.foo.com
|
| - home = /mnt/sites/trac
|
| - data_dir = /mnt/trac
|
| - svn_dir = /mnt/subversion
|
| - server_admin = root@foo.com
|
| - sdb_auth_domain = users
|
| - # Optional
|
| - SSLCertificateFile = /mnt/ssl/foo.crt
|
| - SSLCertificateKeyFile = /mnt/ssl/foo.key
|
| - SSLCertificateChainFile = /mnt/ssl/FooCA.crt
|
| -
|
| - """
|
| -
|
| - def install(self):
|
| - self.run('apt-get -y install trac', notify=True, exit_on_error=True)
|
| - self.run('apt-get -y install libapache2-svn', notify=True, exit_on_error=True)
|
| - self.run("a2enmod ssl")
|
| - self.run("a2enmod mod_python")
|
| - self.run("a2enmod dav_svn")
|
| - self.run("a2enmod rewrite")
|
| - # Make sure that boto.log is writable by everyone so that subversion post-commit hooks can
|
| - # write to it.
|
| - self.run("touch /var/log/boto.log")
|
| - self.run("chmod a+w /var/log/boto.log")
|
| -
|
| - def setup_vhost(self):
|
| - domain = boto.config.get("Trac", "hostname").strip()
|
| - if domain:
|
| - domain_info = domain.split('.')
|
| - cnf = open("/etc/apache2/sites-available/%s" % domain_info[0], "w")
|
| - cnf.write("NameVirtualHost *:80\n")
|
| - if boto.config.get("Trac", "SSLCertificateFile"):
|
| - cnf.write("NameVirtualHost *:443\n\n")
|
| - cnf.write("<VirtualHost *:80>\n")
|
| - cnf.write("\tServerAdmin %s\n" % boto.config.get("Trac", "server_admin").strip())
|
| - cnf.write("\tServerName %s\n" % domain)
|
| - cnf.write("\tRewriteEngine On\n")
|
| - cnf.write("\tRewriteRule ^(.*)$ https://%s$1\n" % domain)
|
| - cnf.write("</VirtualHost>\n\n")
|
| -
|
| - cnf.write("<VirtualHost *:443>\n")
|
| - else:
|
| - cnf.write("<VirtualHost *:80>\n")
|
| -
|
| - cnf.write("\tServerAdmin %s\n" % boto.config.get("Trac", "server_admin").strip())
|
| - cnf.write("\tServerName %s\n" % domain)
|
| - cnf.write("\tDocumentRoot %s\n" % boto.config.get("Trac", "home").strip())
|
| -
|
| - cnf.write("\t<Directory %s>\n" % boto.config.get("Trac", "home").strip())
|
| - cnf.write("\t\tOptions FollowSymLinks Indexes MultiViews\n")
|
| - cnf.write("\t\tAllowOverride All\n")
|
| - cnf.write("\t\tOrder allow,deny\n")
|
| - cnf.write("\t\tallow from all\n")
|
| - cnf.write("\t</Directory>\n")
|
| -
|
| - cnf.write("\t<Location />\n")
|
| - cnf.write("\t\tAuthType Basic\n")
|
| - cnf.write("\t\tAuthName \"%s\"\n" % boto.config.get("Trac", "name"))
|
| - cnf.write("\t\tRequire valid-user\n")
|
| - cnf.write("\t\tAuthUserFile /mnt/apache/passwd/passwords\n")
|
| - cnf.write("\t</Location>\n")
|
| -
|
| - data_dir = boto.config.get("Trac", "data_dir")
|
| - for env in os.listdir(data_dir):
|
| - if(env[0] != "."):
|
| - cnf.write("\t<Location /trac/%s>\n" % env)
|
| - cnf.write("\t\tSetHandler mod_python\n")
|
| - cnf.write("\t\tPythonInterpreter main_interpreter\n")
|
| - cnf.write("\t\tPythonHandler trac.web.modpython_frontend\n")
|
| - cnf.write("\t\tPythonOption TracEnv %s/%s\n" % (data_dir, env))
|
| - cnf.write("\t\tPythonOption TracUriRoot /trac/%s\n" % env)
|
| - cnf.write("\t</Location>\n")
|
| -
|
| - svn_dir = boto.config.get("Trac", "svn_dir")
|
| - for env in os.listdir(svn_dir):
|
| - if(env[0] != "."):
|
| - cnf.write("\t<Location /svn/%s>\n" % env)
|
| - cnf.write("\t\tDAV svn\n")
|
| - cnf.write("\t\tSVNPath %s/%s\n" % (svn_dir, env))
|
| - cnf.write("\t</Location>\n")
|
| -
|
| - cnf.write("\tErrorLog /var/log/apache2/error.log\n")
|
| - cnf.write("\tLogLevel warn\n")
|
| - cnf.write("\tCustomLog /var/log/apache2/access.log combined\n")
|
| - cnf.write("\tServerSignature On\n")
|
| - SSLCertificateFile = boto.config.get("Trac", "SSLCertificateFile")
|
| - if SSLCertificateFile:
|
| - cnf.write("\tSSLEngine On\n")
|
| - cnf.write("\tSSLCertificateFile %s\n" % SSLCertificateFile)
|
| -
|
| - SSLCertificateKeyFile = boto.config.get("Trac", "SSLCertificateKeyFile")
|
| - if SSLCertificateKeyFile:
|
| - cnf.write("\tSSLCertificateKeyFile %s\n" % SSLCertificateKeyFile)
|
| -
|
| - SSLCertificateChainFile = boto.config.get("Trac", "SSLCertificateChainFile")
|
| - if SSLCertificateChainFile:
|
| - cnf.write("\tSSLCertificateChainFile %s\n" % SSLCertificateChainFile)
|
| - cnf.write("</VirtualHost>\n")
|
| - cnf.close()
|
| - self.run("a2ensite %s" % domain_info[0])
|
| - self.run("/etc/init.d/apache2 force-reload")
|
| -
|
| - def main(self):
|
| - self.install()
|
| - self.setup_vhost()
|
|
|