forked from adoptium/temurin-build
-
Notifications
You must be signed in to change notification settings - Fork 4
/
sign.sh
221 lines (194 loc) · 8.05 KB
/
sign.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
#!/bin/bash
# shellcheck disable=SC1091
# ********************************************************************************
# Copyright (c) 2018 Contributors to the Eclipse Foundation
#
# See the NOTICE file(s) with this work for additional
# information regarding copyright ownership.
#
# This program and the accompanying materials are made
# available under the terms of the Apache Software License 2.0
# which is available at https://www.apache.org/licenses/LICENSE-2.0.
#
# SPDX-License-Identifier: Apache-2.0
# ********************************************************************************
set -eu
SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
# shellcheck source=sbin/common/config_init.sh
source "$SCRIPT_DIR/sbin/common/config_init.sh"
# shellcheck source=sbin/common/constants.sh
source "$SCRIPT_DIR/sbin/common/constants.sh"
# shellcheck source=sbin/common/common.sh
source "$SCRIPT_DIR/sbin/common/common.sh"
ARCHIVE=""
SIGNING_CERTIFICATE=""
WORKSPACE=$(pwd)
TMP_DIR_NAME="tmp"
TMP_DIR="${WORKSPACE}/${TMP_DIR_NAME}/"
# List of valid timestamp servers:
# http://timestamp.comodoca.com/authenticode -> OK 02/08/2030 -> Sectigo RSA Time Stamping Signer #1
# http://timestamp.sectigo.com -> OK 02/08/2030 -> Sectigo RSA Time Stamping Signer #1 .. same as previous but with another url
# http://timestamp.comodoca.com/rfc3161 -> OK 02/08/2030 -> Sectigo RSA Time Stamping Signer #1 .. same as previous but with another url
# http://tsa.startssl.com/rfc3161 -> OK 15/08/2028 -> WoSign Time Stamping Signer ( buyed by WoTrus )
# http://tsa.starfieldtech.com -> OK 17/09/2027 -> Starfield Timestamp Authority - G2
# http://timestamp.globalsign.com/scripts/timstamp.dll -> OK 24/06/2027 -> GlobalSign TSA for MS Authenticode - G2
# http://timestamp.digicert.com -> OK 22/10/2024 -> DigiCert Timestamp Responder
TIMESTAMP_SERVER_CONFIG="./serverTimestamp.properties"
checkSignConfiguration() {
if [[ "${OPERATING_SYSTEM}" == "windows" ]] ; then
if [ ! -f "${SIGNING_CERTIFICATE}" ]
then
echo "Could not find certificate at: ${SIGNING_CERTIFICATE}"
exit 1
fi
if [ -z "${SIGN_PASSWORD+x}" ]
then
echo "If signing is enabled on window you must set SIGN_PASSWORD"
exit 1
fi
fi
}
# Sign the built binary
signRelease()
{
TIMESTAMPSERVERS=$(cut -d= -f2 < "$WORKSPACE/$TIMESTAMP_SERVER_CONFIG")
case "$OPERATING_SYSTEM" in
"windows")
echo "Signing Windows release"
signToolPath=${signToolPath:-"/cygdrive/c/Program Files (x86)/Windows Kits/10/bin/10.0.17763.0/x64/signtool.exe"}
# Sign .exe files
# The ./bin/C directory contains FIPS binaries that are signed by other means.
# Skip all files within this directory as signing them would cause failures when
# the libraries attempt to self verify themselves.
FILES=$(find . -type f -name '*.exe' -o -name '*.dll' -not -path './bin/C/*')
if [ "$FILES" == "" ]; then
echo "No files to sign"
else
for f in $FILES
do
echo "Signing ${f}"
if [ "$SIGN_TOOL" = "eclipse" ]; then
echo "Signing $f using Eclipse Foundation codesign service"
dir=$(dirname "$f")
file=$(basename "$f")
mv "$f" "${dir}/unsigned_${file}"
if ! curl --fail --silent --show-error -o "$f" -F file="@${dir}/unsigned_${file}" https://cbi.eclipse.org/authenticode/sign; then
echo "curl command failed, sign of $f failed"
# Retry up to 20 times
max_iterations=20
iteration=1
success=false
echo "Code Not Signed For File $f"
while [ $iteration -le $max_iterations ] && [ $success = false ]; do
echo $iteration Of $max_iterations
sleep 1
if ! curl --fail --silent --show-error -o "$f" -F file="@${dir}/unsigned_${file}" https://cbi.eclipse.org/authenticode/sign; then
echo "curl command failed, $f Failed Signing On Attempt $iteration"
success=false
iteration=$((iteration+1))
if [ $iteration -gt $max_iterations ]
then
echo "Errors Encountered During Signing"
exit 1
fi
else
echo "$f Signed OK On Attempt $iteration"
success=true
fi
done
fi
chmod --reference="${dir}/unsigned_${file}" "$f"
rm -rf "${dir}/unsigned_${file}"
else
STAMPED=false
for SERVER in $TIMESTAMPSERVERS; do
if [ "$STAMPED" = "false" ]; then
echo "Signing $f using $SERVER"
if [ "$SIGN_TOOL" = "ucl" ]; then
ucl sign-code --file "$f" -n ${SIGNING_CERTIFICATE} -t "${SERVER}" --hash SHA256
elif [ "$SIGN_TOOL" = "garasign" ]; then
garasign sign --type authenticode --key ${SIGNING_CERTIFICATE} --hashAlg SHA256 --inputFile "$f" --tsaUrl "${SERVER}" --append --overwrite
else
"$signToolPath" sign /f "${SIGNING_CERTIFICATE}" /p "$SIGN_PASSWORD" /fd SHA256 /t "${SERVER}" "$f"
fi
RC=$?
if [ $RC -eq 0 ]; then
STAMPED=true
else
echo "RETRYWARNING: Failed to sign ${f} at $(date +%T): Possible timestamp server error at ${SERVER} - Trying new server in 5 seconds"
sleep 2
fi
fi
done
if [ "$STAMPED" = "false" ]; then
echo "Failed to sign ${f} using any time server - aborting"
exit 1
fi
fi
done
fi
;;
*)
echo "Skipping code signing as it's not supported on $OPERATING_SYSTEM"
;;
esac
}
function parseArguments() {
parseConfigurationArguments "$@"
while [[ $# -gt 2 ]] ; do
shift;
done
SIGNING_CERTIFICATE="$1";
ARCHIVE="$2";
}
function extractArchive {
rm -rf "${TMP_DIR}" || true
mkdir "${TMP_DIR}"
case "$OPERATING_SYSTEM" in
"aix" | "linux" | "mac")
gunzip -dc "${ARCHIVE}" | tar xf - -C "${TMP_DIR}"
;;
"windows")
unzip -q "${ARCHIVE}" -d "${TMP_DIR}"
;;
*)
echo "could not detect archive type"
exit 1
;;
esac
}
if [ "${OPERATING_SYSTEM}" != "windows" ] && [ "${OPERATING_SYSTEM}" != "mac" ] && [ "${OPERATING_SYSTEM}" != "linux" ] && [ "${OPERATING_SYSTEM}" != "aix" ]; then
echo "Skipping code signing as it's not supported on ${OPERATING_SYSTEM}"
exit 0;
fi
configDefaults
parseArguments "$@"
if [ "${OPERATING_SYSTEM}" = "windows" ]; then
extractArchive
# this is because the windows signing is performed by a Linux machine now. It needs this variable set to know to create a zipfile instead of a tarball
BUILD_CONFIG[OS_KERNEL_NAME]="cygwin"
# Set jdkDir to the top level directory from the tarball/zipball
# shellcheck disable=SC2012
jdkDir=$(ls -1 "${TMP_DIR}" | head -1 | xargs basename)
cd "${TMP_DIR}/${jdkDir}" || exit 1
signRelease
cd "${TMP_DIR}"
createOpenJDKArchive "${jdkDir}" "OpenJDK"
archiveExtension=$(getArchiveExtension)
signedArchive="${TMP_DIR}/OpenJDK${archiveExtension}"
cd "${WORKSPACE}"
mv "${signedArchive}" "${ARCHIVE}"
fi
if ([ "$OPERATING_SYSTEM" = "aix" ] || [ "$OPERATING_SYSTEM" = "linux" ] || [ "$OPERATING_SYSTEM" = "windows" ] || [ "$OPERATING_SYSTEM" = "mac" ] && [ "$SIGN_TOOL" = "ucl" ] || [ "$SIGN_TOOL" = "garasign" ]); then
echo "Sign archive ${ARCHIVE}"
# sign the tarball/zip
if [ "$SIGN_TOOL" = "ucl" ]; then
ucl sign --hash SHA256 -n ${SIGNING_CERTIFICATE} -i "${ARCHIVE}" -o "${ARCHIVE}.sig"
elif [ "$SIGN_TOOL" = "garasign" ]; then
garasign sign --type cosign --key ${SIGNING_CERTIFICATE} --inputFile "${ARCHIVE}" --outputDirectory "workspace/target/" --overwrite --additionalFlags --b64=false
mv "${ARCHIVE}".cosign.sig "${ARCHIVE}".sig
fi
else
echo "Skipping code signing of archive ${ARCHIVE} as ${SIGN_TOOL} is unsupported on ${OPERATING_SYSTEM}"
fi
rm -rf "${TMP_DIR}"