summaryrefslogtreecommitdiff
path: root/Source/CMakeInstallSignTool.cmake.in
blob: fca629c31fc539c0477ba0b871ada16d9384d556 (plain)
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
# The signtool.  Default to PATH.
set(CMake_INSTALL_SIGNTOOL "@CMake_INSTALL_SIGNTOOL@")
if(NOT CMake_INSTALL_SIGNTOOL)
  set(CMake_INSTALL_SIGNTOOL signtool)
endif()

# Select a certificate by Subject Name.  Default to automatic selection.
set(CMake_INSTALL_SIGNTOOL_SUBJECT_NAME "@CMake_INSTALL_SIGNTOOL_SUBJECT_NAME@")
if(CMake_INSTALL_SIGNTOOL_SUBJECT_NAME)
  set(select_cert -n "${CMake_INSTALL_SIGNTOOL_SUBJECT_NAME}")
else()
  set(select_cert -a)
endif()

# Timestamp URL.  Default to a common provider.
set(CMake_INSTALL_SIGNTOOL_TIMESTAMP_URL "@CMake_INSTALL_SIGNTOOL_TIMESTAMP_URL@")
if(NOT CMake_INSTALL_SIGNTOOL_TIMESTAMP_URL)
  set(CMake_INSTALL_SIGNTOOL_TIMESTAMP_URL "http://timestamp.digicert.com")
endif()

# Glob files that need a signature.
file(GLOB files "$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/bin/*.exe")

# Sign all files at once.
if(files)
  # Run the signtool through 'cmd /c' to enable password prompt popup.
  # Some providers have trouble when signtool is invoked with SW_HIDE.
  set(cmd cmd /c "${CMake_INSTALL_SIGNTOOL}" sign -v ${select_cert})

  # Sign with SHA-1 for Windows 7 and below.
  execute_process(
    COMMAND ${cmd} -t  "${CMake_INSTALL_SIGNTOOL_TIMESTAMP_URL}" ${files}
    RESULT_VARIABLE result
    ERROR_VARIABLE stderr
    )
  if(NOT result EQUAL 0)
    string(REPLACE "\n" "\n  " stderr "  ${stderr}")
    message(WARNING "signtool failed:\n${stderr}")
  endif()

  # Sign with SHA-256 for Windows 8 and above.
  execute_process(
    COMMAND ${cmd} -tr "${CMake_INSTALL_SIGNTOOL_TIMESTAMP_URL}" -fd sha256 -td sha256 -as ${files}
    RESULT_VARIABLE result
    ERROR_VARIABLE stderr
    )
  if(NOT result EQUAL 0)
    string(REPLACE "\n" "\n  " stderr "  ${stderr}")
    message(WARNING "signtool failed:\n${stderr}")
  endif()
endif()