blob: 6705df62b25b0802caf65194f5e595b8a77f2cff [file] [log] [blame]
#!/bin/bash
#
# Copyright (C) 2015 The Android Open Source Project
#
# Licensed 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.
#
# Version: 1.3-eng
#
set -o nounset
umask 077
#
# Settings
#
JACK_VERSION=${JACK_VERSION:=4.32.CANDIDATE}
JACK_HOME="${JACK_HOME:=$HOME/.jack-server}"
JACK_CLIENT_SETTING="${JACK_CLIENT_SETTING:=$HOME/.jack-settings}"
TMPDIR=${TMPDIR:=/tmp}
# This is half the timeout since the script will make a second attempt collecting debugs when
# the first attempt fails on connection timeout
JACK_CONNECTION_TIMEOUT=150
JACK_EXTRA_CURL_OPTIONS=${JACK_EXTRA_CURL_OPTIONS:=}
JACK_ASSERTION_ENABLED="${JACK_ASSERTION_ENABLED:=false}"
abort () { exit 255; }
#
# Load client settings
#
if [ -f "$JACK_CLIENT_SETTING" ]; then
source "$JACK_CLIENT_SETTING"
else
echo "Cannot find settings at '$JACK_CLIENT_SETTING'" >&2
abort
fi
JACK_SERVER=${JACK_SERVER:=true}
JACK_MAIN_COMMAND=${JACK_MAIN_COMMAND:="java -Djava.io.tmpdir=$TMPDIR -Dfile.encoding=UTF-8 -XX:+TieredCompilation"}
JACK_REPOSITORY=${JACK_REPOSITORY:=}
#
# If not in server mode, exec jack
#
if [ "$JACK_SERVER" != "true" ]; then
if [ -z "$JACK_REPOSITORY" ]; then
echo "Running Jack without Jack server requires definition of JACK_REPOSITORY" >&2
abort
fi
JACK_JAR=$JACK_REPOSITORY/jack-$JACK_VERSION.jar
if [ ! -r "$JACK_JAR" ]; then
echo "Jack jar \"$JACK_JAR\" is not readable" >&2
abort
fi
exec $JACK_MAIN_COMMAND -jar $JACK_JAR "$@"
echo "Cannot succeed to launch Jack without Jack server" >&2
abort
fi
#
# Prepare compilation
#
JACK_PWD="$PWD"
JACK_EXIT="$TMPDIR/jack-task-$USER-$$-exit"
# Cleanup
trap 'rm -f "$JACK_EXIT" 2>/dev/null;' EXIT
set -o errexit
# Check that we can create temp file for exit status
rm -rf "$JACK_EXIT"
echo "" > "$JACK_EXIT"
#
# Launch the compilation
#
set +o errexit
trap ERR
# put arguments in a non array variable
ARGS=""
for i in "$@"; do
ARGS="$ARGS $i"
done
CURRENT_CHARSET=$(locale charmap)
if [ -z "$CURRENT_CHARSET" ]; then
CHARSET_ARGUMENT=
else
CHARSET_ARGUMENT=";charset=$CURRENT_CHARSET"
fi
# Check base64 availability
BASE64_CHECK=$((echo amFjaw==;echo LXNlcnZlcg==) | base64 --decode 2>&1)
sendRequest() {
RETRY_OPTION=$1
shift
# Launch compilation
exec 3>&1
exec 4>&2
if [ "$BASE64_CHECK" = jack-server ]; then
HTTP_CODE=$(curl -f $JACK_EXTRA_CURL_OPTIONS $RETRY_OPTION \
--cert "${JACK_HOME}/client.pem" \
--cacert "${JACK_HOME}/server.pem" \
--output >(tee >(sed -n -e 's/^E|\(.*\)$/\1/p' | base64 --decode >&4 ) | tee >(sed -n -e 's/^X|\(.*\)$/\1/p' >>$JACK_EXIT) | sed -n -e 's/^O|\(.*\)$/\1/p' | base64 --decode >&3) \
--no-buffer --write-out '%{http_code}' --silent --connect-timeout $JACK_CONNECTION_TIMEOUT \
-X POST \
-H "Accept: application/vnd.jack.command-out-base64;version=1$CHARSET_ARGUMENT" \
-F "cli=$ARGS;type=text/plain$CHARSET_ARGUMENT" \
-F "version=$JACK_VERSION;type=application/vnd.jack.select-exact;version=1" \
-F "pwd=$JACK_PWD;type=text/plain$CHARSET_ARGUMENT" \
-F "assert=$JACK_ASSERTION_ENABLED;type=text/plain$CHARSET_ARGUMENT" \
--noproxy ${SERVER_HOST} \
https://${SERVER_HOST}:$SERVER_PORT_SERVICE/jack \
)
else
HTTP_CODE=$(curl -f $JACK_EXTRA_CURL_OPTIONS $RETRY_OPTION \
--cert "${JACK_HOME}/client.pem" \
--cacert "${JACK_HOME}/server.pem" \
--output >(tee >(sed -n -e 's/^E|\(.*\)$/\1/p' >&4 ) | tee >(sed -n -e 's/^X|\(.*\)$/\1/p' >>$JACK_EXIT) | sed -n -e 's/^O|\(.*\)$/\1/p' >&3) \
--no-buffer --write-out '%{http_code}' --silent --connect-timeout $JACK_CONNECTION_TIMEOUT \
-X POST \
-H "Accept: application/vnd.jack.command-out;version=1$CHARSET_ARGUMENT" \
-F "cli=$ARGS;type=text/plain$CHARSET_ARGUMENT" \
-F "version=$JACK_VERSION;type=application/vnd.jack.select-exact;version=1" \
-F "pwd=$JACK_PWD;type=text/plain$CHARSET_ARGUMENT" \
-F "assert=$JACK_ASSERTION_ENABLED;type=text/plain$CHARSET_ARGUMENT" \
--noproxy ${SERVER_HOST} \
https://${SERVER_HOST}:$SERVER_PORT_SERVICE/jack \
)
fi
CURL_CODE=$?
exec 3>&-
exec 4>&-
set -o errexit
if [ $CURL_CODE -eq 0 ]; then
# No problem, let's go
JACK_CODE=$(cat "$JACK_EXIT")
exit $JACK_CODE
elif [ $CURL_CODE -eq 7 ]; then
# Failed to connect
echo "No Jack server running. Try 'jack-admin start-server'" >&2
abort
elif [ $CURL_CODE -eq 28 ]; then
if [ "$RETRY_OPTION" == "" ]; then
echo "Connection to the Jack server timeout, retrying with debug"
sendRequest -v $@
else
echo "Connection to the Jack server timeout" >&2
abort
fi
elif [ $CURL_CODE -eq 35 ]; then
if [ "$RETRY_OPTION" == "" ]; then
echo "SSL error when connecting to the Jack server, retrying with debug"
sendRequest -v $@
else
echo "SSL error when connecting to the Jack server. Try 'jack-diagnose'" >&2
abort
fi
elif [ $CURL_CODE -eq 58 ]; then
echo "Failed to contact Jack server: Problem reading ${JACK_HOME}/client.pem. Try 'jack-diagnose'" >&2
abort
elif [ $CURL_CODE -eq 60 ]; then
echo "Failed to authenticate Jack server certificate. Try 'jack-diagnose'" >&2
abort
elif [ $CURL_CODE -eq 77 ]; then
echo "Failed to contact Jack server: Problem reading ${JACK_HOME}/server.pem. Try 'jack-diagnose'" >&2
abort
elif [ $CURL_CODE -eq 22 ]; then
# Http code not OK, let's decode and abort
if [ $HTTP_CODE -eq 400 ]; then
# 400: Bad request
echo "Bad request, see server log" >&2
abort
else
# Other
echo "Internal unknown error ($HTTP_CODE), try 'jack-diagnose' or see Jack server log" >&2
abort
fi
else
echo "Communication error with Jack server ($CURL_CODE). Try 'jack-diagnose'" >&2
abort
fi
}
sendRequest "" $@