-
Notifications
You must be signed in to change notification settings - Fork 40
/
Copy pathsign.bat
117 lines (90 loc) · 3.97 KB
/
sign.bat
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
@echo off
setlocal EnableDelayedExpansion
cls
Rem ******************************************************************************************
rem "sign a binaray file (exe, dll)"
Rem ******************************************************************************************
call "%~dp0/defaults.inc.bat"
Rem ******************************************************************************************
echo "*** Sign file: %~1"
if "%~1" == "" (
echo "Missing parameter: Please specify file to sign"
exit 1
)
Rem ******************************************************************************************
echo "* PROJECT_PATH=%PROJECT_PATH%"
echo "* SIGNTOOL=%SIGNTOOL%"
echo "* VCINSTALLDIR=%VCINSTALLDIR%"
echo "* Build date %BUILD_DATE%"
echo "* APPLICATION_VENDOR %APPLICATION_VENDOR%"
echo "* TAG_DESKTOP %TAG_DESKTOP%"
echo "* APPLICATION_NAME %APPLICATION_NAME%"
echo "* SIGN_FILE_DIGEST_ALG=%SIGN_FILE_DIGEST_ALG%"
echo "* SIGN_TIMESTAMP_URL=%SIGN_TIMESTAMP_URL%"
echo "* SIGN_TIMESTAMP_DIGEST_ALG=%SIGN_TIMESTAMP_DIGEST_ALG%"
echo "* USE_CODE_SIGNING=%USE_CODE_SIGNING%"
echo "* PATH=%PATH%"
Rem ******************************************************************************************
rem "check for required environment variables"
Rem ******************************************************************************************
if "%USE_CODE_SIGNING%" == "0" (
echo "** Abort sign: Code signing is disabled by USE_CODE_SIGNING"
exit
)
call :testEnv PROJECT_PATH
call :testEnv APPLICATION_VENDOR
call :testEnv TAG_DESKTOP
call :testEnv APPLICATION_NAME
call :testEnv CERTIFICATE_FILENAME
call :testEnv CERTIFICATE_CSP
call :testEnv CERTIFICATE_KEY_CONTAINER_NAME
call :testEnv CERTIFICATE_PASSWORD
call :testEnv SIGN_FILE_DIGEST_ALG
call :testEnv SIGN_TIMESTAMP_URL
call :testEnv SIGN_TIMESTAMP_DIGEST_ALG
if %ERRORLEVEL% neq 0 goto onError
Rem ******************************************************************************************
rem "try to find signtool, if not specified via environment"
Rem ******************************************************************************************
REM Note: vcvars is the official way to set the path for all the VC and Win SDK tools.
REM signtool.exe resides in a SDK version specific directory, like:
REM C:\Program Files (x86)\Windows Kits\10\bin\10.0.17763.0\x86\signtool.exe
if "%SIGNTOOL%" == "" (
echo "** SIGNTOOL not set: trying to find via VCINSTALLDIR:"
call :testEnv VCINSTALLDIR
if %ERRORLEVEL% neq 0 goto onError
echo "** Calling vcvars64.bat to add signtool to the PATH:"
call "%VCINSTALLDIR%\Auxiliary\Build\vcvars64.bat"
if %ERRORLEVEL% neq 0 goto onError
for %%i in (signtool.exe) do @set SIGNTOOL=%%~$PATH:i
if "!SIGNTOOL!" == "" (
echo "** Unable to find signtool.exe in the PATH."
goto onError
) else (
echo "** Found signtool.exe: !SIGNTOOL!"
)
)
call :testEnv SIGNTOOL
if %ERRORLEVEL% neq 0 goto onError
Rem ******************************************************************************************
rem "sign"
Rem ******************************************************************************************
rem Reference: https://ss64.com/nt/setlocal.html
rem Reference: https://ss64.com/nt/start.html
echo "* Run signtool on file: %~1"
start "signtool" /D "%PROJECT_PATH%" /B /wait "%SIGNTOOL%" sign /debug /v /d "%APPLICATION_NAME% %TAG_DESKTOP%" /tr "%SIGN_TIMESTAMP_URL%" /td %SIGN_TIMESTAMP_DIGEST_ALG% /fd %SIGN_FILE_DIGEST_ALG% /f "%CERTIFICATE_FILENAME%" /csp "%CERTIFICATE_CSP%" /kc "[{{%CERTIFICATE_PASSWORD%}}]=%CERTIFICATE_KEY_CONTAINER_NAME%" "%~1"
if %ERRORLEVEL% neq 0 goto onError
Rem ******************************************************************************************
echo "*** Finished sign file: %~1"
exit 0
:onError
echo "*** Sign FAILED for file: %~1"
if %ERRORLEVEL% neq 0 exit %ERRORLEVEL%
if !ERRORLEVEL! neq 0 exit !ERRORLEVEL!
exit 1
:testEnv
if "!%*!" == "" (
echo "Missing environment variable: %*"
exit /B 1
)
exit /B