mirror of
https://github.com/game-ci/unity-builder.git
synced 2025-07-04 12:25:19 -04:00

- Added `runAsHostUser` to allow running the container as the same user as the host system. This fixes most permissions issues on self-hosted runners. - Perform android sdk setup during entrypoint.sh to ensure it has root permissions if the user switches to a non-root user - Automatically detect android sdk target version if parameters are not already provided to configure the sdk - Generate a new uuid for machineID to ensure separate containers are unique to reduce license activation errors - Add exponential retry strategy for Ubuntu license activations
103 lines
3.0 KiB
Bash
Executable File
103 lines
3.0 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
|
|
if [[ -n "$UNITY_SERIAL" && -n "$UNITY_EMAIL" && -n "$UNITY_PASSWORD" ]]; then
|
|
#
|
|
# SERIAL LICENSE MODE
|
|
#
|
|
# This will activate unity, using the serial activation process.
|
|
#
|
|
echo "Requesting activation"
|
|
|
|
# Loop the unity-editor call until the license is activated with exponential backoff and a maximum of 5 retries
|
|
retry_count=0
|
|
|
|
# Initialize delay to 15 seconds
|
|
delay=15
|
|
|
|
# Loop until UNITY_EXIT_CODE is 0 or retry count reaches 5
|
|
while [[ $retry_count -lt 5 ]]
|
|
do
|
|
# Activate license
|
|
unity-editor \
|
|
-logFile /dev/stdout \
|
|
-quit \
|
|
-serial "$UNITY_SERIAL" \
|
|
-username "$UNITY_EMAIL" \
|
|
-password "$UNITY_PASSWORD" \
|
|
-projectPath "/BlankProject"
|
|
|
|
# Store the exit code from the verify command
|
|
UNITY_EXIT_CODE=$?
|
|
|
|
# Check if UNITY_EXIT_CODE is 0
|
|
if [[ $UNITY_EXIT_CODE -eq 0 ]]
|
|
then
|
|
echo "Activation successful"
|
|
break
|
|
else
|
|
echo "Activation failed, retrying in $delay seconds..."
|
|
sleep $delay
|
|
|
|
# Increment retry count
|
|
((retry_count++))
|
|
|
|
# Double the delay for the next iteration
|
|
delay=$((delay * 2))
|
|
fi
|
|
done
|
|
|
|
if [[ $retry_count -eq 5 ]]
|
|
then
|
|
echo "Activation failed after 5 retries"
|
|
fi
|
|
|
|
elif [[ -n "$UNITY_LICENSING_SERVER" ]]; then
|
|
#
|
|
# Custom Unity License Server
|
|
#
|
|
echo "Adding licensing server config"
|
|
|
|
/opt/unity/Editor/Data/Resources/Licensing/Client/Unity.Licensing.Client --acquire-floating > license.txt #is this accessible in a env variable?
|
|
PARSEDFILE=$(grep -oP '\".*?\"' < license.txt | tr -d '"')
|
|
export FLOATING_LICENSE
|
|
FLOATING_LICENSE=$(sed -n 2p <<< "$PARSEDFILE")
|
|
FLOATING_LICENSE_TIMEOUT=$(sed -n 4p <<< "$PARSEDFILE")
|
|
|
|
echo "Acquired floating license: \"$FLOATING_LICENSE\" with timeout $FLOATING_LICENSE_TIMEOUT"
|
|
# Store the exit code from the verify command
|
|
UNITY_EXIT_CODE=$?
|
|
else
|
|
#
|
|
# NO LICENSE ACTIVATION STRATEGY MATCHED
|
|
#
|
|
# This will exit since no activation strategies could be matched.
|
|
#
|
|
echo "License activation strategy could not be determined."
|
|
echo ""
|
|
echo "Visit https://game.ci/docs/github/getting-started for more"
|
|
echo "details on how to set up one of the possible activation strategies."
|
|
|
|
echo "::error ::No valid license activation strategy could be determined. Make sure to provide UNITY_EMAIL, UNITY_PASSWORD, and either a UNITY_SERIAL \
|
|
or UNITY_LICENSE. Otherwise please use UNITY_LICENSING_SERVER."
|
|
# Immediately exit as no UNITY_EXIT_CODE can be derived.
|
|
exit 1;
|
|
|
|
fi
|
|
|
|
#
|
|
# Display information about the result
|
|
#
|
|
if [ $UNITY_EXIT_CODE -eq 0 ]; then
|
|
# Activation was a success
|
|
echo "Activation complete."
|
|
else
|
|
# Activation failed so exit with the code from the license verification step
|
|
echo "Unclassified error occured while trying to activate license."
|
|
echo "Exit code was: $UNITY_EXIT_CODE"
|
|
echo "::error ::There was an error while trying to activate the Unity license."
|
|
exit $UNITY_EXIT_CODE
|
|
fi
|
|
|
|
# Return to previous working directory
|
|
popd
|