apache-tuscany/sca-cpp/trunk/modules/edit/ssl-start

170 lines
5 KiB
Bash
Executable file

#!/bin/sh
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.
# For this module to work, add the sca-store.com domain to your /etc/hosts as follows:
# 127.0.0.1 sca-store.com
here=`echo "import os; print os.path.realpath('$0')" | python`; here=`dirname $here`
jsprefix=`echo "import os; print os.path.realpath('$here/../js')" | python`
# Create SSL certificates
../../modules/http/ssl-ca-conf tmp sca-store.com
../../modules/http/ssl-cert-conf tmp sca-store.com server
# Configure and start logging
if [ -x ../../components/log/scribe-cat ]; then
../../components/log/scribed-central-conf tmp
../../components/log/scribed-client-conf tmp localhost
../../components/log/scribed-central-start tmp
../../components/log/scribed-client-start tmp
fi
# Start memcached
../../components/cache/memcached-start tmp 11211
../../components/cache/memcached-start tmp 11212
# Configure server
../../modules/http/httpd-conf tmp sca-store.com 8090 htdocs
../../modules/http/httpd-event-conf tmp
../../modules/http/httpd-ssl-conf tmp 8453
# Configure password authentication
#../../modules/http/open-auth-conf tmp
#../../modules/http/passwd-auth-conf tmp john john
#../../modules/http/passwd-auth-conf tmp jane jane
#../../modules/http/passwd-auth-conf tmp admin admin
# Configure OAuth authentication
# Configure your OAuth app keys here
../../modules/oauth/oauth-conf tmp
../../modules/oauth/oauth-memcached-conf tmp localhost 11212
../../modules/oauth/oauth2-appkey-conf tmp facebook.com 12345 67890
# Configure OpenID step2 authentication
../../modules/openid/openid-conf tmp
../../modules/openid/openid-step2-conf tmp
../../modules/openid/openid-memcached-conf tmp localhost 11212
# Configure authorized users
#../../modules/http/group-auth-conf tmp john
#../../modules/http/group-auth-conf tmp jane
#../../modules/http/group-auth-conf tmp admin
# Configure the email addresses associated with your OpenID and OAuth ids here
../../modules/http/group-auth-conf tmp john@sca-store.com
../../modules/http/group-auth-conf tmp jane@sca-store.com
# Configure mod-security
../../modules/http/mod-security-conf tmp
# Configure Python component support
../../modules/server/server-conf tmp
../../modules/python/python-conf tmp
# Configure server log streaming
if [ -x ../../components/log/scribe-cat ]; then
cat >tmp/conf/log.conf <<EOF
# Generated by: ssl-start $*
ErrorLog "|$here/../../components/log/scribe-cat server"
CustomLog "|$here/../../components/log/scribe-cat server" combined
EOF
cat >tmp/conf/log-ssl.conf <<EOF
# Generated by: ssl-start $*
CustomLog "|$here/../../components/log/scribe-cat server" sslcombined
EOF
cat >tmp/conf/mod-security-log.conf <<EOF
# Generated by: ssl-start $*
SecAuditLog "|$here/../../components/log/scribe-cat secaudit"
EOF
fi
# Configure certificate mime type
cat >>tmp/conf/svhost-ssl.conf <<EOF
# Generated by: ssl-start $*
# Certificate mime type
<Location /ca.crt>
ForceType application/x-x509-ca-cert
</Location>
EOF
# Configure error pages
cat >>tmp/conf/svhost-ssl.conf <<EOF
# Generated by: ssl-start $*
# Error pages
ErrorDocument 404 /public/notfound/
ErrorDocument 401 /public/notauth/
ErrorDocument 500 /public/oops/
ErrorDocument 405 /public/oops/
EOF
# Configure SCA contributions
cat >>tmp/conf/httpd.conf <<EOF
# Generated by: ssl-start $*
# Configure SCA Composite
SCAContribution `pwd`/
SCAComposite edit.composite
# Configure SCA Composite for mass dynamic virtual Hosting
SCAVirtualContribution `pwd`/apps/
SCAVirtualComposite app.composite
EOF
# Configure resource aliases
cat >>tmp/conf/httpd.conf <<EOF
# Generated by: ssl-start $*
Alias /home/home.png $here/htdocs/home/home.png
Alias /home/home.b64 $here/htdocs/home/home.b64
EOF
# Create app resource links
./mkapplinks . ../../../.. ../../../../../nuvem
# Configure app resource aliases
cat >>tmp/conf/svhost-ssl.conf <<EOF
# Generated by: ssl-start $*
<Location /v>
RewriteEngine on
# Map /v/<app-name>/<path> to htdocs/app/<path>
RewriteCond %{REQUEST_URI} ^/v/.+/.*$
RewriteRule /v/(.+)/(.*)$ $here/htdocs/app/\$2 [L]
# Redirect /v/<app-name> to /<app-name>/
RewriteCond %{REQUEST_URI} ^/v/[^/]+$
RewriteRule /v/([^/]+)$ /\$1/ [L,R]
</Location>
EOF
# Create application database directories
mkdir -p tmp/appdata/filedb
# Start server
../../modules/http/httpd-start tmp