| #!/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. |
| |
| # Generate an SSL tunnel configuration |
| here=`echo "import os; print os.path.realpath('$0')" | python`; here=`dirname $here` |
| mkdir -p $1 |
| root=`echo "import os; print os.path.realpath('$1')" | python` |
| |
| conf=`cat $root/conf/httpd.conf | grep "# Generated by: httpd-conf"` |
| host=`echo $conf | awk '{ print $6 }'` |
| |
| port=`$here/httpd-addr port $2` |
| sslhost=$3 |
| sslport=$4 |
| tport=$5 |
| |
| # Generate HTTPD configuration |
| cat >>$root/conf/httpd.conf <<EOF |
| # Generated by: tunnel-ssl-conf $* |
| # Tunnel TCP/IP traffic over HTTPS |
| |
| # Listen on local port |
| Listen 127.0.0.1:$port |
| |
| # Tunnel virtual host |
| <VirtualHost 127.0.0.1:$port> |
| ServerName http://localhost:$port |
| |
| TunnelPass https://$sslhost:$sslport/tunnel/localhost/$tport |
| |
| # Declare SSL certificates used in this virtual host |
| #TunnelSSLCACertificateFile "$root/cert/ca.crt" |
| TunnelSSLCertificateFile "$root/cert/tunnel.crt" |
| TunnelSSLCertificateKeyFile "$root/cert/tunnel.key" |
| |
| </VirtualHost> |
| |
| EOF |
| |