184 lines
		
	
	
		
			6.4 KiB
		
	
	
	
		
			TeX
		
	
	
	
	
	
			
		
		
	
	
			184 lines
		
	
	
		
			6.4 KiB
		
	
	
	
		
			TeX
		
	
	
	
	
	
| ; Copyright (c) uib gmbh (www.uib.de)
 | |
| ; This sourcecode is owned by uib
 | |
| ; and published under the Terms of the General Public License.
 | |
| ; credits: http://www.opsi.org/en/credits/
 | |
| 
 | |
| [Actions]
 | |
| requiredWinstVersion >= "4.11.2.6"
 | |
| 
 | |
| DefVar $UninstallProgram$
 | |
| DefVar $UninstallProgramOld$
 | |
| DefVar $IniFile$
 | |
| DefVar $IniCfgFile$
 | |
| DefVar $LogDir$
 | |
| DefVar $ProductId$  
 | |
| DefVar $MinimumSpace$
 | |
| DefVar $InstallDir$
 | |
| DefVar $ExitCode$
 | |
| DefVar $OLD_VERSION$
 | |
| DefVar $OLD_CREATOR_TAG$
 | |
| DefVar $OLD_RELEASE$
 | |
| 
 | |
| Set $LogDir$ = "%SystemDrive%\tmp"
 | |
| 
 | |
| ; The token BUILDER_VARIABLES will be replaced by opsi-builder.sh
 | |
| ; and adds the following variables:
 | |
| ;   from builder-product.cfg :  all variables definded by attribute WINST[index]
 | |
| ;   from builder-product.cfg :  VENDOR PN VERSION RELEASE PRIORITY ADVICE TYPE   
 | |
| ;   from opsi-builder.cfg    :  CREATOR_TAG CREATOR_NAME CREATOR_EMAIL           
 | |
| ;   auto generated winst-variables
 | |
| ;         $IconFile$: path to product picture
 | |
| ;
 | |
| @@BUILDER_VARIABLES@@
 | |
| 
 | |
| ; ----------------------------------------------------------------
 | |
| ; - Please edit the following values                             -
 | |
| ; ----------------------------------------------------------------
 | |
| ;$ProductId$ should be the name of the product in opsi
 | |
| ; therefore please: only lower letters, no umlauts, 
 | |
| ; no white space use '-' as a seperator
 | |
| Set $MinimumSpace$    = "1 MB"
 | |
| ; the path were we find the product after the installation
 | |
| Set $InstallDir$      = "%ProgramFiles32Dir%\<path to the product>"
 | |
| ; ----------------------------------------------------------------
 | |
| 
 | |
| Set $IniCfgFile$ = "%ScriptPath%\opsi-" + $ProductId$ + ".ini"
 | |
| 
 | |
| if not(HasMinimumSpace ("%SystemDrive%", $MinimumSpace$))
 | |
| 	LogError "Not enough space on %SystemDrive%, " + $MinimumSpace$ + " on drive %SystemDrive% needed for " + $ProductId$
 | |
| 	isFatalError "No Space"
 | |
| 	; Stop process and set installation status to failed
 | |
| else
 | |
| 	comment "Show product picture"
 | |
| 	ShowBitmap "%ScriptPath%\" + $ProductId$ + ".png" $NAME$
 | |
| 	
 | |
| 	if FileExists("%ScriptPath%\delsub32.ins")
 | |
| 		comment "Start uninstall sub section"
 | |
| 		Sub "%ScriptPath%\delsub32.ins"
 | |
| 	endif
 | |
| 	
 | |
| 	Message "Installing " + $ProductId$ + " "+ $VERSION$ + "-" + $CREATOR_TAG$ + $RELEASE$ + " ..."
 | |
| 	
 | |
| 	comment "Start setup program"
 | |
| 	ChangeDirectory "%SCRIPTPATH%"
 | |
| 	Winbatch_install
 | |
| 	Sub_check_exitcode
 | |
| 	
 | |
| 	comment "Copy files"
 | |
| 	Files_install /32Bit
 | |
| 	
 | |
| 	comment "Patch Registry"
 | |
| 	Registry_install /32Bit
 | |
| 	
 | |
| 	comment "Create shortcuts"
 | |
| 	LinkFolder_install
 | |
| 	
 | |
| endif
 | |
| 
 | |
| [Winbatch_install]
 | |
| ; Choose one of the following examples as basis for your installation
 | |
| ; You can use $LicenseKey$ var to pass a license key to the installer
 | |
| ;
 | |
| ; === Nullsoft Scriptable Install System ================================================================
 | |
| ; "%ScriptPath%\Setup.exe" /S
 | |
| ;
 | |
| ; === MSI package =======================================================================================
 | |
| ; You may use the parameter PIDKEY=$Licensekey$
 | |
| ; msiexec /i "%ScriptPath%\some.msi" /l* "$LogDir$\$ProductId$.install_log.txt" /qb! ALLUSERS=1 REBOOT=ReallySuppress
 | |
| ;
 | |
| ; === InstallShield + MSI=====================================================================================
 | |
| ; Attention: The path to the log file should not contain any whitespaces
 | |
| ; "%ScriptPath%\setup.exe" /s /v" /l* $LogDir$\$ProductId$.install_log.txt /qb! ALLUSERS=1 REBOOT=ReallySuppress"
 | |
| ; "%ScriptPath%\setup.exe" /s /v" /qb! ALLUSERS=2 REBOOT=ReallySuppress"
 | |
| ;
 | |
| ; === InstallShield =====================================================================================
 | |
| ; Create setup.iss answer file by running: setup.exe /r /f1"c:\setup.iss"
 | |
| ; You may use an answer file by the parameter /f1"c:\setup.iss"
 | |
| ; "%ScriptPath%\setup.exe" /s /sms /f2"$LogDir$\$ProductId$.install_log.txt"
 | |
| ;
 | |
| ; === Inno Setup ========================================================================================
 | |
| ; http://unattended.sourceforge.net/InnoSetup_Switches_ExitCodes.html
 | |
| ; You may create setup answer file by: setup.exe /SAVEINF="filename"
 | |
| ; You may use an answer file by the parameter /LOADINF="filename"
 | |
| ; "%ScriptPath%\setup.exe" /sp- /silent /norestart /nocancel /SUPPRESSMSGBOXES
 | |
| 
 | |
| [Files_install]
 | |
| ; copy the ini file to the InstallDir
 | |
| copy "$IniCfgFile$" "$InstallDir$"
 | |
| 
 | |
| ; Example of recursively copying some files into the installation directory:
 | |
| ;
 | |
| ; copy -s "%ScriptPath%\files\*.*" "$InstallDir$"
 | |
| 
 | |
| [Registry_install]
 | |
| ; Example of setting some values of an registry key:
 | |
| ;
 | |
| ; openkey [HKEY_LOCAL_MACHINE\Software\$ProductId$]
 | |
| ; set "name1" = "some string value"
 | |
| ; set "name2" = REG_DWORD:0001
 | |
| ; set "name3" = REG_BINARY:00 af 99 cd
 | |
| 
 | |
| [LinkFolder_install]
 | |
| ; Example of deleting a folder from AllUsers startmenu:
 | |
| ;
 | |
| ; set_basefolder common_programs
 | |
| ; delete_subfolder $ProductId$
 | |
| ;
 | |
| ; Example of creating an shortcut to the installed exe in AllUsers startmenu:
 | |
| ;
 | |
| ; set_basefolder common_programs
 | |
| ; set_subfolder $ProductId$
 | |
| ;
 | |
| ; set_link
 | |
| ; 	name: $ProductId$
 | |
| ; 	target: <path to the program>
 | |
| ; 	parameters:
 | |
| ; 	working_dir: $InstallDir$
 | |
| ; 	icon_file:
 | |
| ; 	icon_index:
 | |
| ; end_link
 | |
| ;
 | |
| ; Example of creating an shortcut to the installed exe on AllUsers desktop:
 | |
| ;
 | |
| ; set_basefolder common_desktopdirectory
 | |
| ; set_subfolder ""
 | |
| ;
 | |
| ; set_link
 | |
| ; 	name: $ProductId$
 | |
| ; 	target: <path to the program>
 | |
| ; 	parameters: <some_param>
 | |
| ; 	working_dir: $InstallDir$
 | |
| ; 	icon_file: <path to icon file>
 | |
| ; 	icon_index: 2
 | |
| ; end_link
 | |
| 
 | |
| [Sub_check_exitcode]
 | |
| comment "Test for installation success via exit code"
 | |
| set $ExitCode$ = getLastExitCode
 | |
| ; informations to exit codes see
 | |
| ; http://msdn.microsoft.com/en-us/library/aa372835(VS.85).aspx
 | |
| ; http://msdn.microsoft.com/en-us/library/aa368542.aspx
 | |
| if ($ExitCode$ = "0")
 | |
| 	comment "Looks good: setup program gives exitcode zero"
 | |
| else
 | |
| 	comment "Setup program gives a exitcode unequal zero: " + $ExitCode$
 | |
| 	if ($ExitCode$ = "1605")
 | |
| 		comment "ERROR_UNKNOWN_PRODUCT	1605	This action is only valid for products that are currently installed."
 | |
| 		comment "Uninstall of a not installed product failed - no problem"
 | |
| 	else
 | |
| 		if ($ExitCode$ = "1641")
 | |
| 			comment "looks good: setup program gives exitcode 1641"
 | |
| 			comment "ERROR_SUCCESS_REBOOT_INITIATED	1641	The installer has initiated a restart. This message is indicative of a success."
 | |
| 		else
 | |
| 			if ($ExitCode$ = "3010")
 | |
| 				comment "looks good: setup program gives exitcode 3010"
 | |
| 				comment "ERROR_SUCCESS_REBOOT_REQUIRED	3010	A restart is required to complete the install. This message is indicative of a success."
 | |
| 			else
 | |
| 				logError "Fatal: Setup program gives an unknown exitcode unequal zero: " + $ExitCode$
 | |
| 				isFatalError
 | |
| 			endif
 | |
| 		endif
 | |
| 	endif
 | |
| endif
 | |
| 
 |