aboutsummaryrefslogtreecommitdiffstats
path: root/release
diff options
context:
space:
mode:
authorPierre Ossman <ossman@cendio.se>2020-07-16 13:45:51 +0200
committerPierre Ossman <ossman@cendio.se>2020-07-16 15:40:32 +0200
commit502132ba54a21fedd3572bdf9512e410d14f47ea (patch)
treec5ec4889cfd4123e38ece0c9631a0eae87d72c97 /release
parent4d635a9f03f15a934c9ffd2cd6de730ba72c07aa (diff)
downloadtigervnc-502132ba54a21fedd3572bdf9512e410d14f47ea.tar.gz
tigervnc-502132ba54a21fedd3572bdf9512e410d14f47ea.zip
Split WinVNC to a separate installer
It doesn't work very well so it shouldn't be included by default.
Diffstat (limited to 'release')
-rw-r--r--release/CMakeLists.txt27
-rw-r--r--release/tigervnc.iss.in140
-rw-r--r--release/winvnc.iss.in160
3 files changed, 172 insertions, 155 deletions
diff --git a/release/CMakeLists.txt b/release/CMakeLists.txt
index 419546b1..9bf0816e 100644
--- a/release/CMakeLists.txt
+++ b/release/CMakeLists.txt
@@ -9,29 +9,26 @@
if(WIN32)
if(CMAKE_SIZEOF_VOID_P MATCHES 8)
- set(INST_NAME ${CMAKE_PROJECT_NAME}64-${VERSION})
+ set(INST_SUFFIX 64)
set(INST_DEFS -DWIN64)
-else()
- set(INST_NAME ${CMAKE_PROJECT_NAME}-${VERSION})
-endif()
-
-set(INST_DEPS vncviewer)
-
-if(BUILD_WINVNC)
- set(INST_DEFS ${INST_DEFS} -DBUILD_WINVNC)
- if(BUILD_JAVA)
- set(INST_DEPS ${INST_DEPS} java)
- endif()
- set(INST_DEPS ${INST_DEPS} winvnc4 wm_hooks vncconfig)
endif()
configure_file(tigervnc.iss.in tigervnc.iss)
add_custom_target(installer
- iscc -o. ${INST_DEFS} -F${INST_NAME} tigervnc.iss
- DEPENDS ${INST_DEPS}
+ iscc -o. ${INST_DEFS} -F${CMAKE_PROJECT_NAME}${INST_SUFFIX}-${VERSION} tigervnc.iss
+ DEPENDS vncviewer
SOURCES tigervnc.iss)
+if(BUILD_WINVNC)
+ configure_file(winvnc.iss.in winvnc.iss)
+
+ add_custom_target(winvnc_installer
+ iscc -o. ${INST_DEFS} -F${CMAKE_PROJECT_NAME}${INST_SUFFIX}-winvnc-${VERSION} winvnc.iss
+ DEPENDS winvnc4 wm_hooks vncconfig
+ SOURCES winvnc.iss)
+endif()
+
endif() # WIN32
diff --git a/release/tigervnc.iss.in b/release/tigervnc.iss.in
index 7292a80f..0168b790 100644
--- a/release/tigervnc.iss.in
+++ b/release/tigervnc.iss.in
@@ -18,155 +18,15 @@ DefaultGroupName=TigerVNC
#endif
LicenseFile=@CMAKE_SOURCE_DIR@\LICENCE.txt
-[Dirs]
-; This directory is necessary to prevent the X509 file chooser from causing
-; an error dialog to appear when GetOpenFileName is called by SYSTEM account.
-Name: "{sys}\config\systemprofile\Desktop"
-
[Files]
-#ifdef BUILD_WINVNC
-Source: "@CMAKE_BINARY_DIR@\win\winvnc\winvnc4.exe"; DestDir: "{app}"; Flags: ignoreversion restartreplace;
-Source: "@CMAKE_BINARY_DIR@\win\wm_hooks\wm_hooks.dll"; DestDir: "{app}"; Flags: ignoreversion restartreplace;
-Source: "@CMAKE_BINARY_DIR@\win\vncconfig\vncconfig.exe"; DestDir: "{app}"; Flags: ignoreversion restartreplace;
-#endif
Source: "@CMAKE_BINARY_DIR@\vncviewer\vncviewer.exe"; DestDir: "{app}"; Flags: ignoreversion restartreplace;
Source: "@CMAKE_SOURCE_DIR@\README.rst"; DestDir: "{app}"; Flags: ignoreversion
Source: "@CMAKE_SOURCE_DIR@\LICENCE.TXT"; DestDir: "{app}"; Flags: ignoreversion
-
[Icons]
Name: "{group}\TigerVNC Viewer"; FileName: "{app}\vncviewer.exe";
Name: "{group}\Listening TigerVNC Viewer"; FileName: "{app}\vncviewer.exe"; Parameters: "-listen";
-#ifdef BUILD_WINVNC
-Name: "{group}\VNC Server (User-Mode)\Run VNC Server"; FileName: "{app}\winvnc4.exe"; Parameters: "-noconsole";
-Name: "{group}\VNC Server (User-Mode)\Configure VNC Server"; FileName: "{app}\vncconfig.exe"; Parameters: "-user";
-
-Name: "{group}\VNC Server (Service-Mode)\Configure VNC Service"; FileName: "{app}\vncconfig.exe"; Parameters: "-noconsole -service";
-Name: "{group}\VNC Server (Service-Mode)\Register VNC Service"; FileName: "{app}\winvnc4.exe"; Parameters: "-register";
-Name: "{group}\VNC Server (Service-Mode)\Unregister VNC Service"; FileName: "{app}\winvnc4.exe"; Parameters: "-unregister";
-Name: "{group}\VNC Server (Service-Mode)\Start VNC Service"; FileName: "{app}\winvnc4.exe"; Parameters: "-noconsole -start";
-Name: "{group}\VNC Server (Service-Mode)\Stop VNC Service"; FileName: "{app}\winvnc4.exe"; Parameters: "-noconsole -stop";
-#endif
Name: "{group}\License"; FileName: "write.exe"; Parameters: "LICENCE.TXT"; WorkingDir: "{app}"; Flags: "useapppaths"
Name: "{group}\Read Me"; FileName: "write.exe"; Parameters: "README.rst"; WorkingDir: "{app}"; Flags: "useapppaths"
Name: "{group}\Uninstall TigerVNC"; FileName: "{uninstallexe}"; WorkingDir: "{app}";
-
-#ifdef BUILD_WINVNC
-[Tasks]
-Name: installservice; Description: "&Register new TigerVNC Server as a system service"; GroupDescription: "Server configuration:";
-Name: startservice; Description: "&Start or restart TigerVNC service"; GroupDescription: "Server configuration:";
-
-[Run]
-Filename: "{app}\winvnc4.exe"; Parameters: "-register"; Tasks: installservice
-Filename: "net"; Parameters: "start winvnc4"; Tasks: startservice
-#endif
-
-#ifdef BUILD_WINVNC
-[Code]
-
-{--- IShellLink ---}
-
-const
- CLSID_ShellLink = '{00021401-0000-0000-C000-000000000046}';
- SLDF_RUNAS_USER = $2000;
-
-type
- IShellLinkW = interface(IUnknown)
- '{000214F9-0000-0000-C000-000000000046}'
- procedure Dummy;
- procedure Dummy2;
- procedure Dummy3;
- function GetDescription(pszName: String; cchMaxName: Integer): HResult;
- function SetDescription(pszName: String): HResult;
- function GetWorkingDirectory(pszDir: String; cchMaxPath: Integer): HResult;
- function SetWorkingDirectory(pszDir: String): HResult;
- function GetArguments(pszArgs: String; cchMaxPath: Integer): HResult;
- function SetArguments(pszArgs: String): HResult;
- function GetHotkey(var pwHotkey: Word): HResult;
- function SetHotkey(wHotkey: Word): HResult;
- function GetShowCmd(out piShowCmd: Integer): HResult;
- function SetShowCmd(iShowCmd: Integer): HResult;
- function GetIconLocation(pszIconPath: String; cchIconPath: Integer;
- out piIcon: Integer): HResult;
- function SetIconLocation(pszIconPath: String; iIcon: Integer): HResult;
- function SetRelativePath(pszPathRel: String; dwReserved: DWORD): HResult;
- function Resolve(Wnd: HWND; fFlags: DWORD): HResult;
- function SetPath(pszFile: String): HResult;
- end;
-
- IShellLinkDataList = interface(IUnknown)
- '{45E2B4AE-B1C3-11D0-B92F-00A0C90312E1}'
- function AddDataBlock(pDataBlock : DWORD) : HResult;
- function CopyDataBlock(dwSig : DWORD; var ppDataBlock : DWORD) : HResult;
- function RemoveDataBlock(dwSig : DWORD) : HResult;
- function GetFlags(var pdwFlags : DWORD) : HResult;
- function SetFlags(dwFlags : DWORD) : HResult;
- end;
-
- IPersist = interface(IUnknown)
- '{0000010C-0000-0000-C000-000000000046}'
- function GetClassID(var classID: TGUID): HResult;
- end;
-
- IPersistFile = interface(IPersist)
- '{0000010B-0000-0000-C000-000000000046}'
- function IsDirty: HResult;
- function Load(pszFileName: String; dwMode: Longint): HResult;
- function Save(pszFileName: String; fRemember: BOOL): HResult;
- function SaveCompleted(pszFileName: String): HResult;
- function GetCurFile(out pszFileName: String): HResult;
- end;
-
-var
- OSVersion: TWindowsVersion;
-
-function InitializeSetup: Boolean;
-begin
- GetWindowsVersionEx(OSVersion);
- Result := True;
-end;
-
-procedure SetRunAsUserFlag(Path: String);
-var
- Obj: IUnknown;
- SL: IShellLinkW;
- SDL: IShellLinkDataList;
- PF: IPersistFile;
- Flags: DWord;
-begin
- Obj := CreateComObject(StringToGuid(CLSID_ShellLink));
- SL := IShellLinkW(Obj);
- PF := IPersistFile(Obj);
- SDL := IShellLinkDataList(Obj);
- Path := ExpandConstant(Path);
- OleCheck(PF.Load(Path, 0));
- OleCheck(SDL.GetFlags(Flags));
- OleCheck(SDL.SetFlags(Flags or SLDF_RUNAS_USER));
- OleCheck(PF.Save(Path, True));
-end;
-
-procedure CurStepChanged(CurStep: TSetupStep);
-var
- Flags: DWord;
-begin
- { Post-install actions on Windows Vista and higher:
- o Modify Service-Mode start menu commands so they run as administrator.
- o Set up the SoftwareSASGeneration system policy so as to allow services to simulate Ctrl+Alt+Del. }
- if (CurStep = ssPostInstall) and (OSVersion.Major >= 6) then begin
- SetRunAsUserFlag('{group}\VNC Server (Service-Mode)\Configure VNC Service.lnk');
- SetRunAsUserFlag('{group}\VNC Server (Service-Mode)\Register VNC Service.lnk');
- SetRunAsUserFlag('{group}\VNC Server (Service-Mode)\Unregister VNC Service.lnk');
- SetRunAsUserFlag('{group}\VNC Server (Service-Mode)\Start VNC Service.lnk');
- SetRunAsUserFlag('{group}\VNC Server (Service-Mode)\Stop VNC Service.lnk');
- if not RegQueryDWordValue(
- HKEY_LOCAL_MACHINE, 'SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\System',
- 'SoftwareSASGeneration', Flags
- ) then Flags := 0;
- RegWriteDWordValue(
- HKEY_LOCAL_MACHINE, 'SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\System',
- 'SoftwareSASGeneration', Flags or 1
- );
- end;
-end;
-#endif
diff --git a/release/winvnc.iss.in b/release/winvnc.iss.in
new file mode 100644
index 00000000..2173038a
--- /dev/null
+++ b/release/winvnc.iss.in
@@ -0,0 +1,160 @@
+[Setup]
+#ifdef WIN64
+ArchitecturesInstallIn64BitMode=x64
+AppName=TigerVNC Server 64-bit
+AppVerName=TigerVNC Server 64-bit @VERSION@ (@BUILD@)
+#else
+AppName=TigerVNC Server
+AppVerName=TigerVNC Server v@VERSION@ (@BUILD@)
+#endif
+AppVersion=@VERSION@
+AppPublisher=TigerVNC project
+AppPublisherURL=https://tigervnc.org
+DefaultDirName={pf}\TigerVNC Server
+#ifdef WIN64
+DefaultGroupName=TigerVNC Server 64-bit
+#else
+DefaultGroupName=TigerVNC Server
+#endif
+LicenseFile=@CMAKE_SOURCE_DIR@\LICENCE.txt
+
+[Dirs]
+; This directory is necessary to prevent the X509 file chooser from causing
+; an error dialog to appear when GetOpenFileName is called by SYSTEM account.
+Name: "{sys}\config\systemprofile\Desktop"
+
+[Files]
+Source: "@CMAKE_BINARY_DIR@\win\winvnc\winvnc4.exe"; DestDir: "{app}"; Flags: ignoreversion restartreplace;
+Source: "@CMAKE_BINARY_DIR@\win\wm_hooks\wm_hooks.dll"; DestDir: "{app}"; Flags: ignoreversion restartreplace;
+Source: "@CMAKE_BINARY_DIR@\win\vncconfig\vncconfig.exe"; DestDir: "{app}"; Flags: ignoreversion restartreplace;
+Source: "@CMAKE_SOURCE_DIR@\README.rst"; DestDir: "{app}"; Flags: ignoreversion
+Source: "@CMAKE_SOURCE_DIR@\LICENCE.TXT"; DestDir: "{app}"; Flags: ignoreversion
+
+
+[Icons]
+Name: "{group}\VNC Server (User-Mode)\Run VNC Server"; FileName: "{app}\winvnc4.exe"; Parameters: "-noconsole";
+Name: "{group}\VNC Server (User-Mode)\Configure VNC Server"; FileName: "{app}\vncconfig.exe"; Parameters: "-user";
+
+Name: "{group}\VNC Server (Service-Mode)\Configure VNC Service"; FileName: "{app}\vncconfig.exe"; Parameters: "-noconsole -service";
+Name: "{group}\VNC Server (Service-Mode)\Register VNC Service"; FileName: "{app}\winvnc4.exe"; Parameters: "-register";
+Name: "{group}\VNC Server (Service-Mode)\Unregister VNC Service"; FileName: "{app}\winvnc4.exe"; Parameters: "-unregister";
+Name: "{group}\VNC Server (Service-Mode)\Start VNC Service"; FileName: "{app}\winvnc4.exe"; Parameters: "-noconsole -start";
+Name: "{group}\VNC Server (Service-Mode)\Stop VNC Service"; FileName: "{app}\winvnc4.exe"; Parameters: "-noconsole -stop";
+Name: "{group}\License"; FileName: "write.exe"; Parameters: "LICENCE.TXT"; WorkingDir: "{app}"; Flags: "useapppaths"
+Name: "{group}\Read Me"; FileName: "write.exe"; Parameters: "README.rst"; WorkingDir: "{app}"; Flags: "useapppaths"
+Name: "{group}\Uninstall TigerVNC Server"; FileName: "{uninstallexe}"; WorkingDir: "{app}";
+
+[Tasks]
+Name: installservice; Description: "&Register new TigerVNC Server as a system service"; GroupDescription: "Server configuration:";
+Name: startservice; Description: "&Start or restart TigerVNC service"; GroupDescription: "Server configuration:";
+
+[Run]
+Filename: "{app}\winvnc4.exe"; Parameters: "-register"; Tasks: installservice
+Filename: "net"; Parameters: "start winvnc4"; Tasks: startservice
+
+[Code]
+
+{--- IShellLink ---}
+
+const
+ CLSID_ShellLink = '{00021401-0000-0000-C000-000000000046}';
+ SLDF_RUNAS_USER = $2000;
+
+type
+ IShellLinkW = interface(IUnknown)
+ '{000214F9-0000-0000-C000-000000000046}'
+ procedure Dummy;
+ procedure Dummy2;
+ procedure Dummy3;
+ function GetDescription(pszName: String; cchMaxName: Integer): HResult;
+ function SetDescription(pszName: String): HResult;
+ function GetWorkingDirectory(pszDir: String; cchMaxPath: Integer): HResult;
+ function SetWorkingDirectory(pszDir: String): HResult;
+ function GetArguments(pszArgs: String; cchMaxPath: Integer): HResult;
+ function SetArguments(pszArgs: String): HResult;
+ function GetHotkey(var pwHotkey: Word): HResult;
+ function SetHotkey(wHotkey: Word): HResult;
+ function GetShowCmd(out piShowCmd: Integer): HResult;
+ function SetShowCmd(iShowCmd: Integer): HResult;
+ function GetIconLocation(pszIconPath: String; cchIconPath: Integer;
+ out piIcon: Integer): HResult;
+ function SetIconLocation(pszIconPath: String; iIcon: Integer): HResult;
+ function SetRelativePath(pszPathRel: String; dwReserved: DWORD): HResult;
+ function Resolve(Wnd: HWND; fFlags: DWORD): HResult;
+ function SetPath(pszFile: String): HResult;
+ end;
+
+ IShellLinkDataList = interface(IUnknown)
+ '{45E2B4AE-B1C3-11D0-B92F-00A0C90312E1}'
+ function AddDataBlock(pDataBlock : DWORD) : HResult;
+ function CopyDataBlock(dwSig : DWORD; var ppDataBlock : DWORD) : HResult;
+ function RemoveDataBlock(dwSig : DWORD) : HResult;
+ function GetFlags(var pdwFlags : DWORD) : HResult;
+ function SetFlags(dwFlags : DWORD) : HResult;
+ end;
+
+ IPersist = interface(IUnknown)
+ '{0000010C-0000-0000-C000-000000000046}'
+ function GetClassID(var classID: TGUID): HResult;
+ end;
+
+ IPersistFile = interface(IPersist)
+ '{0000010B-0000-0000-C000-000000000046}'
+ function IsDirty: HResult;
+ function Load(pszFileName: String; dwMode: Longint): HResult;
+ function Save(pszFileName: String; fRemember: BOOL): HResult;
+ function SaveCompleted(pszFileName: String): HResult;
+ function GetCurFile(out pszFileName: String): HResult;
+ end;
+
+var
+ OSVersion: TWindowsVersion;
+
+function InitializeSetup: Boolean;
+begin
+ GetWindowsVersionEx(OSVersion);
+ Result := True;
+end;
+
+procedure SetRunAsUserFlag(Path: String);
+var
+ Obj: IUnknown;
+ SL: IShellLinkW;
+ SDL: IShellLinkDataList;
+ PF: IPersistFile;
+ Flags: DWord;
+begin
+ Obj := CreateComObject(StringToGuid(CLSID_ShellLink));
+ SL := IShellLinkW(Obj);
+ PF := IPersistFile(Obj);
+ SDL := IShellLinkDataList(Obj);
+ Path := ExpandConstant(Path);
+ OleCheck(PF.Load(Path, 0));
+ OleCheck(SDL.GetFlags(Flags));
+ OleCheck(SDL.SetFlags(Flags or SLDF_RUNAS_USER));
+ OleCheck(PF.Save(Path, True));
+end;
+
+procedure CurStepChanged(CurStep: TSetupStep);
+var
+ Flags: DWord;
+begin
+ { Post-install actions on Windows Vista and higher:
+ o Modify Service-Mode start menu commands so they run as administrator.
+ o Set up the SoftwareSASGeneration system policy so as to allow services to simulate Ctrl+Alt+Del. }
+ if (CurStep = ssPostInstall) and (OSVersion.Major >= 6) then begin
+ SetRunAsUserFlag('{group}\VNC Server (Service-Mode)\Configure VNC Service.lnk');
+ SetRunAsUserFlag('{group}\VNC Server (Service-Mode)\Register VNC Service.lnk');
+ SetRunAsUserFlag('{group}\VNC Server (Service-Mode)\Unregister VNC Service.lnk');
+ SetRunAsUserFlag('{group}\VNC Server (Service-Mode)\Start VNC Service.lnk');
+ SetRunAsUserFlag('{group}\VNC Server (Service-Mode)\Stop VNC Service.lnk');
+ if not RegQueryDWordValue(
+ HKEY_LOCAL_MACHINE, 'SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\System',
+ 'SoftwareSASGeneration', Flags
+ ) then Flags := 0;
+ RegWriteDWordValue(
+ HKEY_LOCAL_MACHINE, 'SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\System',
+ 'SoftwareSASGeneration', Flags or 1
+ );
+ end;
+end;