]> git.sur5r.net Git - bacula/bacula/commitdiff
Add src/win32/newinstaller -- single file installer
authorKern Sibbald <kern@sibbald.com>
Sun, 11 Jan 2009 19:22:27 +0000 (19:22 +0000)
committerKern Sibbald <kern@sibbald.com>
Sun, 11 Jan 2009 19:22:27 +0000 (19:22 +0000)
git-svn-id: https://bacula.svn.sourceforge.net/svnroot/bacula/trunk@8355 91ce42f0-d328-0410-95d8-f526ca767f89

23 files changed:
bacula/src/win32/Makefile
bacula/src/win32/newinstaller/ConfigPage1.nsh [new file with mode: 0644]
bacula/src/win32/newinstaller/ConfigPage2.nsh [new file with mode: 0644]
bacula/src/win32/newinstaller/DumpLog.nsh [new file with mode: 0644]
bacula/src/win32/newinstaller/InstallType.ini [new file with mode: 0644]
bacula/src/win32/newinstaller/InstallType.nsh [new file with mode: 0644]
bacula/src/win32/newinstaller/Makefile [new file with mode: 0644]
bacula/src/win32/newinstaller/Readme.txt [new file with mode: 0755]
bacula/src/win32/newinstaller/Start.bat [new file with mode: 0644]
bacula/src/win32/newinstaller/Stop.bat [new file with mode: 0644]
bacula/src/win32/newinstaller/WriteTemplates.ini [new file with mode: 0644]
bacula/src/win32/newinstaller/bacula-dir.conf.in [new file with mode: 0644]
bacula/src/win32/newinstaller/bacula-fd.conf.in [new file with mode: 0644]
bacula/src/win32/newinstaller/bacula-logo.bmp [new file with mode: 0644]
bacula/src/win32/newinstaller/bacula-sd.conf.in [new file with mode: 0644]
bacula/src/win32/newinstaller/bconsole.conf.in [new file with mode: 0644]
bacula/src/win32/newinstaller/build-installer.cmd [new file with mode: 0644]
bacula/src/win32/newinstaller/bwx-console.conf.in [new file with mode: 0644]
bacula/src/win32/newinstaller/client.conf.in [new file with mode: 0644]
bacula/src/win32/newinstaller/installer.vcproj [new file with mode: 0644]
bacula/src/win32/newinstaller/storage.conf.in [new file with mode: 0644]
bacula/src/win32/newinstaller/winbacula.nsi [new file with mode: 0644]
bacula/technotes-2.5

index cf91859bb203ce2f52da47a34ccaf2ddcaf2f38a..fe953245786f1c83edb3c6c8c931d5b509380807 100644 (file)
@@ -9,16 +9,33 @@ DIRS= dll \
        console \
        wx-console \
        tools \
-       scripts \
-       installer
+       scripts
 
-.PHONY: $(DIRS) clean all Makefile.inc
+.PHONY: $(DIRS) clean all Makefile.inc installer newinstaller
 
-all: Makefile.inc $(DIRS)
+all: Makefile.inc $(DIRS) installer newinstaller
 
 clean: $(DIRS)
        $(ECHO_CMD)-rm -rf release
 
+newinstaller:
+       @if test -f Makefile.inc; then \
+          if $(MAKE) -C $@ $(MAKECMDGOALS); then \
+               echo "\n===== Make of $@ succeeded =====\n\n" ; \
+          else  \
+               echo "\n!!!!! Make of $@ failed !!!!!\n\n" ; \
+          fi ; \
+       fi
+
+installer:
+       @if test -f Makefile.inc; then \
+          if $(MAKE) -C $@ $(MAKECMDGOALS); then \
+               echo "\n===== Make of $@ succeeded =====\n\n" ; \
+          else  \
+               echo "\n!!!!! Make of $@ failed !!!!!\n\n" ; \
+          fi ; \
+       fi
+
 $(DIRS):
        @if test -f Makefile.inc; then \
           if $(MAKE) -C $@ $(MAKECMDGOALS); then \
diff --git a/bacula/src/win32/newinstaller/ConfigPage1.nsh b/bacula/src/win32/newinstaller/ConfigPage1.nsh
new file mode 100644 (file)
index 0000000..71965a2
--- /dev/null
@@ -0,0 +1,294 @@
+Function EnterConfigPage1\r
+  ${If} $AutomaticInstall = 1\r
+    Abort\r
+  ${EndIf}\r
+\r
+  IntOp $R0 $NewComponents & ${ComponentsFileAndStorage}\r
+\r
+  ${If} $R0 = 0\r
+    Abort\r
+  ${EndIf}\r
+\r
+  FileOpen $R5 "$PLUGINSDIR\ConfigPage1.ini" w\r
+\r
+  StrCpy $R6 1  ; Field Number\r
+  StrCpy $R7 0  ; Top\r
+\r
+  IntOp $R0 $NewComponents & ${ComponentFile}\r
+  ${If} $R0 <> 0\r
+    IntOp $R8 $R7 + 52\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="GroupBox"$\r$\nText="Client"$\r$\nLeft=0$\r$\nTop=$R7$\r$\nRight=300$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+    IntOp $R6 $R6 + 1\r
+    IntOp $R7 $R7 + 12\r
+\r
+    IntOp $R8 $R7 + 8\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="Label"$\r$\nText="Name"$\r$\nLeft=6$\r$\nTop=$R7$\r$\nRight=26$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+    IntOp $R6 $R6 + 1\r
+    IntOp $R7 $R7 - 2\r
+\r
+    IntOp $R8 $R8 + 2\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="Text"$\r$\nState=$ConfigClientName$\r$\nLeft=50$\r$\nTop=$R7$\r$\nRight=158$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+    IntOp $R6 $R6 + 1\r
+    IntOp $R7 $R7 + 2\r
+\r
+    IntOp $R8 $R8 - 2\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="Label"$\r$\nText="Port"$\r$\nLeft=172$\r$\nTop=$R7$\r$\nRight=188$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+    IntOp $R6 $R6 + 1\r
+    IntOp $R7 $R7 - 2\r
+\r
+    IntOp $R8 $R8 + 2\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="Text"$\r$\nFlags="ONLY_NUMBERS"$\r$\nState=$ConfigClientPort$\r$\nLeft=190$\r$\nTop=$R7$\r$\nRight=218$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+    IntOp $R6 $R6 + 1\r
+    IntOp $R7 $R7 + 2\r
+\r
+    IntOp $R8 $R8 - 2\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="Label"$\r$\nText="Max Jobs"$\r$\nLeft=238$\r$\nTop=$R7$\r$\nRight=270$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+    IntOp $R6 $R6 + 1\r
+    IntOp $R7 $R7 - 2\r
+\r
+    IntOp $R8 $R8 + 2\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="Text"$\r$\nFlags="ONLY_NUMBERS"$\r$\nState=$ConfigClientMaxJobs$\r$\nLeft=274$\r$\nTop=$R7$\r$\nRight=294$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+    IntOp $R6 $R6 + 1\r
+    IntOp $R7 $R7 + 16\r
+\r
+    IntOp $R8 $R7 + 8\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="Label"$\r$\nText="Password"$\r$\nLeft=6$\r$\nTop=$R7$\r$\nRight=38$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+    IntOp $R6 $R6 + 1\r
+    IntOp $R7 $R7 - 2\r
+\r
+    IntOp $R8 $R8 + 2\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="Text"$\r$\nState=$ConfigClientPassword$\r$\nLeft=50$\r$\nTop=$R7$\r$\nRight=294$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+    IntOp $R6 $R6 + 1\r
+    IntOp $R7 $R7 + 14\r
+\r
+    IntOp $R8 $R7 + 10\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="Checkbox"$\r$\nState=$ConfigClientInstallService$\r$\nText="Install as service"$\r$\nLeft=50$\r$\nTop=$R7$\r$\nRight=118$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+    IntOp $R6 $R6 + 1\r
+\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="Checkbox"$\r$\nState=$ConfigClientStartService$\r$\nText="Start after install"$\r$\nLeft=190$\r$\nTop=$R7$\r$\nRight=260$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+    IntOp $R6 $R6 + 1\r
+    IntOp $R7 $R7 + 16\r
+  ${Endif}\r
+\r
+  IntOp $R0 $NewComponents & ${ComponentStorage}\r
+  ${If} $R0 <> 0\r
+    IntOp $R8 $R7 + 52\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="GroupBox"$\r$\nText="Storage"$\r$\nLeft=0$\r$\nTop=$R7$\r$\nRight=300$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+    IntOp $R6 $R6 + 1\r
+    IntOp $R7 $R7 + 12\r
+    \r
+    IntOp $R8 $R7 + 8\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="Label"$\r$\nText="Name"$\r$\nLeft=6$\r$\nTop=$R7$\r$\nRight=26$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+    IntOp $R6 $R6 + 1\r
+    IntOp $R7 $R7 - 2\r
+\r
+    IntOp $R8 $R8 + 2\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="Text"$\r$\nState=$ConfigStorageName$\r$\nLeft=50$\r$\nTop=$R7$\r$\nRight=158$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+    IntOp $R6 $R6 + 1\r
+    IntOp $R7 $R7 + 2\r
+\r
+    IntOp $R8 $R8 - 2\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="Label"$\r$\nText="Port"$\r$\nLeft=172$\r$\nTop=$R7$\r$\nRight=188$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+    IntOp $R6 $R6 + 1\r
+    IntOp $R7 $R7 - 2\r
+\r
+    IntOp $R8 $R8 + 2\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="Text"$\r$\nFlags="ONLY_NUMBERS"$\r$\nState=$ConfigStoragePort$\r$\nLeft=190$\r$\nTop=$R7$\r$\nRight=218$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+    IntOp $R6 $R6 + 1\r
+    IntOp $R7 $R7 + 2\r
+\r
+    IntOp $R8 $R8 - 2\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="Label"$\r$\nText="Max Jobs"$\r$\nLeft=238$\r$\nTop=$R7$\r$\nRight=270$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+    IntOp $R6 $R6 + 1\r
+    IntOp $R7 $R7 - 2\r
+\r
+    IntOp $R8 $R8 + 2\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="Text"$\r$\nFlags="ONLY_NUMBERS"$\r$\nState=$ConfigStorageMaxJobs$\r$\nLeft=274$\r$\nTop=$R7$\r$\nRight=294$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+    IntOp $R6 $R6 + 1\r
+    IntOp $R7 $R7 + 16\r
+\r
+    IntOp $R8 $R7 + 8\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="Label"$\r$\nText="Password"$\r$\nLeft=6$\r$\nTop=$R7$\r$\nRight=38$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+    IntOp $R6 $R6 + 1\r
+    IntOp $R7 $R7 - 2\r
+\r
+    IntOp $R8 $R8 + 2\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="Text"$\r$\nState=$ConfigStoragePassword$\r$\nLeft=50$\r$\nTop=$R7$\r$\nRight=294$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+    IntOp $R6 $R6 + 1\r
+    IntOp $R7 $R7 + 14\r
+\r
+    IntOp $R8 $R7 + 10\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="Checkbox"$\r$\nState=$ConfigStorageInstallService$\r$\nText="Install as service"$\r$\nLeft=50$\r$\nTop=$R7$\r$\nRight=118$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+    IntOp $R6 $R6 + 1\r
+\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="Checkbox"$\r$\nState=$ConfigStorageStartService$\r$\nText="Start after install"$\r$\nLeft=190$\r$\nTop=$R7$\r$\nRight=260$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+    IntOp $R6 $R6 + 1\r
+    IntOp $R7 $R7 + 16\r
+  ${Endif}\r
+\r
+  IntOp $R6 $R6 - 1\r
+\r
+  FileWrite $R5 "[Settings]$\r$\nNumFields=$R6$\r$\n"\r
+\r
+  FileClose $R5\r
+\r
+  !insertmacro MUI_HEADER_TEXT "$(TITLE_ConfigPage1)" "$(SUBTITLE_ConfigPage1)"\r
+  !insertmacro MUI_INSTALLOPTIONS_INITDIALOG "ConfigPage1.ini"\r
+  Pop $HDLG ;HWND of dialog\r
+\r
+  ; Initialize Controls\r
+\r
+  StrCpy $R6 1  ; Field Number\r
+\r
+  IntOp $R0 $NewComponents & ${ComponentFile}\r
+  ${If} $R0 <> 0\r
+    IntOp $R6 $R6 + 2\r
+\r
+    ; Client Name\r
+    !insertmacro MUI_INSTALLOPTIONS_READ $HCTL "ConfigPage1.ini" "Field $R6" "HWND"\r
+    SendMessage $HCTL ${EM_LIMITTEXT} 30 0\r
+\r
+    IntOp $R6 $R6 + 2\r
+\r
+    ; Client Port Number\r
+    !insertmacro MUI_INSTALLOPTIONS_READ $HCTL "ConfigPage1.ini" "Field $R6" "HWND"\r
+    SendMessage $HCTL ${EM_LIMITTEXT} 5 0\r
+\r
+    IntOp $R6 $R6 + 2\r
+\r
+    ; Max Jobs\r
+    !insertmacro MUI_INSTALLOPTIONS_READ $HCTL "ConfigPage1.ini" "Field $R6" "HWND"\r
+    SendMessage $HCTL ${EM_LIMITTEXT} 3 0\r
+\r
+    IntOp $R6 $R6 + 5\r
+  ${Endif}\r
+\r
+  IntOp $R0 $NewComponents & ${ComponentStorage}\r
+  ${If} $R0 <> 0\r
+    IntOp $R6 $R6 + 2\r
+\r
+    ; Storage Name\r
+    !insertmacro MUI_INSTALLOPTIONS_READ $HCTL "ConfigPage1.ini" "Field $R6" "HWND"\r
+    SendMessage $HCTL ${EM_LIMITTEXT} 30 0\r
+\r
+    IntOp $R6 $R6 + 2\r
+\r
+    ; Storage Port Number\r
+    !insertmacro MUI_INSTALLOPTIONS_READ $HCTL "ConfigPage1.ini" "Field $R6" "HWND"\r
+    SendMessage $HCTL ${EM_LIMITTEXT} 5 0\r
+\r
+    IntOp $R6 $R6 + 2\r
+\r
+    ; Max Jobs\r
+    !insertmacro MUI_INSTALLOPTIONS_READ $HCTL "ConfigPage1.ini" "Field $R6" "HWND"\r
+    SendMessage $HCTL ${EM_LIMITTEXT} 3 0\r
+\r
+    IntOp $R6 $R6 + 5\r
+  ${Endif}\r
+\r
+  !insertmacro MUI_INSTALLOPTIONS_SHOW\r
+\r
+  ; Process results\r
+\r
+  StrCpy $R6 3\r
+\r
+  IntOp $R0 $NewComponents & ${ComponentFile}\r
+  ${If} $R0 <> 0\r
+    !insertmacro MUI_INSTALLOPTIONS_READ $ConfigClientName "ConfigPage1.ini" "Field $R6" "State"\r
+\r
+    IntOp $R6 $R6 + 2\r
+\r
+    !insertmacro MUI_INSTALLOPTIONS_READ $ConfigClientPort "ConfigPage1.ini" "Field $R6" "State"\r
+\r
+    IntOp $R6 $R6 + 2\r
+\r
+    !insertmacro MUI_INSTALLOPTIONS_READ $ConfigClientMaxJobs "ConfigPage1.ini" "Field $R6" "State"\r
+\r
+    IntOp $R6 $R6 + 2\r
+\r
+    !insertmacro MUI_INSTALLOPTIONS_READ $ConfigClientPassword "ConfigPage1.ini" "Field $R6" "State"\r
+\r
+    IntOp $R6 $R6 + 1\r
+\r
+    !insertmacro MUI_INSTALLOPTIONS_READ $ConfigClientInstallService "ConfigPage1.ini" "Field $R6" "State"\r
+\r
+    IntOp $R6 $R6 + 1\r
+\r
+    !insertmacro MUI_INSTALLOPTIONS_READ $ConfigClientStartService "ConfigPage1.ini" "Field $R6" "State"\r
+\r
+    IntOp $R6 $R6 + 3\r
+  ${Endif}\r
+\r
+  IntOp $R0 $NewComponents & ${ComponentStorage}\r
+  ${If} $R0 <> 0\r
+    !insertmacro MUI_INSTALLOPTIONS_READ $ConfigStorageName "ConfigPage1.ini" "Field $R6" "State"\r
+\r
+    IntOp $R6 $R6 + 2\r
+\r
+    !insertmacro MUI_INSTALLOPTIONS_READ $ConfigStoragePort "ConfigPage1.ini" "Field $R6" "State"\r
+\r
+    IntOp $R6 $R6 + 2\r
+\r
+    !insertmacro MUI_INSTALLOPTIONS_READ $ConfigStorageMaxJobs "ConfigPage1.ini" "Field $R6" "State"\r
+\r
+    IntOp $R6 $R6 + 2\r
+\r
+    !insertmacro MUI_INSTALLOPTIONS_READ $ConfigStoragePassword "ConfigPage1.ini" "Field $R6" "State"\r
+\r
+    IntOp $R6 $R6 + 1\r
+\r
+    !insertmacro MUI_INSTALLOPTIONS_READ $ConfigStorageInstallService "ConfigPage1.ini" "Field $R6" "State"\r
+\r
+    IntOp $R6 $R6 + 1\r
+\r
+    !insertmacro MUI_INSTALLOPTIONS_READ $ConfigStorageStartService "ConfigPage1.ini" "Field $R6" "State"\r
+\r
+    IntOp $R6 $R6 + 3\r
+  ${Endif}\r
+FunctionEnd\r
+\r
+Function LeaveConfigPage1\r
+  StrCpy $R6 5\r
+\r
+  IntOp $R0 $NewComponents & ${ComponentFile}\r
+  ${If} $R0 <> 0\r
+    !insertmacro MUI_INSTALLOPTIONS_READ $R0 "ConfigPage1.ini" "Field $R6" "State"\r
+    ${If} $R0 < 1024\r
+    ${OrIf} $R0 > 65535\r
+      MessageBox MB_OK "Port must be between 1024 and 65535 inclusive."\r
+      Abort\r
+    ${EndIf}\r
+\r
+    IntOp $R6 $R6 + 2\r
+\r
+    !insertmacro MUI_INSTALLOPTIONS_READ $R0 "ConfigPage1.ini" "Field $R6" "State"\r
+    ${If} $R0 < 1\r
+    ${OrIf} $R0 > 99\r
+      MessageBox MB_OK "Max Jobs must be between 1 and 99 inclusive."\r
+      Abort\r
+    ${EndIf}\r
+\r
+    IntOp $R6 $R6 + 9\r
+  ${Endif}\r
+  \r
+  IntOp $R0 $NewComponents & ${ComponentStorage}\r
+  ${If} $R0 <> 0\r
+    !insertmacro MUI_INSTALLOPTIONS_READ $R0 "ConfigPage1.ini" "Field $R6" "State"\r
+    ${If} $R0 < 1024\r
+    ${OrIf} $R0 > 65535\r
+      MessageBox MB_OK "Port must be between 1024 and 65535 inclusive."\r
+      Abort\r
+    ${EndIf}\r
+\r
+    IntOp $R6 $R6 + 2\r
+\r
+    !insertmacro MUI_INSTALLOPTIONS_READ $R0 "ConfigPage1.ini" "Field $R6" "State"\r
+    ${If} $R0 < 1\r
+    ${OrIf} $R0 > 99\r
+      MessageBox MB_OK "Max Jobs must be between 1 and 99 inclusive."\r
+      Abort\r
+    ${EndIf}\r
+\r
+    IntOp $R6 $R6 + 9\r
+  ${Endif}\r
+FunctionEnd\r
diff --git a/bacula/src/win32/newinstaller/ConfigPage2.nsh b/bacula/src/win32/newinstaller/ConfigPage2.nsh
new file mode 100644 (file)
index 0000000..321d7b9
--- /dev/null
@@ -0,0 +1,454 @@
+Function EnterConfigPage2\r
+  IntOp $R0 $NewComponents & ${ComponentsRequiringUserConfig}\r
+\r
+  ${If} $R0 = 0\r
+    Abort\r
+  ${EndIf}\r
+\r
+  FileOpen $R5 "$PLUGINSDIR\ConfigPage2.ini" w\r
+\r
+  StrCpy $R6 1  ; Field Number\r
+  StrCpy $R7 0  ; Top\r
+\r
+  IntOp $R0 $NewComponents & ${ComponentDirector}\r
+  ${If} $R0 <> 0\r
+    ${If} $AutomaticInstall = 1\r
+      IntOp $R8 $R7 + 54\r
+    ${Else}\r
+      IntOp $R8 $R7 + 92\r
+    ${EndIf}\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="GroupBox"$\r$\nText="Director"$\r$\nLeft=0$\r$\nTop=$R7$\r$\nRight=300$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+  ${Else}\r
+    IntOp $R0 $NewComponents & ${ComponentsTextAndGuiConsoles}\r
+    ${If} $R0 <> 0\r
+      IntOp $R8 $R7 + 54\r
+    ${Else}\r
+      IntOp $R8 $R7 + 26\r
+    ${EndIf}\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="GroupBox"$\r$\nText="Remote Director"$\r$\nLeft=0$\r$\nTop=$R7$\r$\nRight=300$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+  ${EndIf}\r
+\r
+  IntOp $R6 $R6 + 1\r
+  IntOp $R7 $R7 + 12\r
+\r
+  IntOp $R0 $NewComponents & ${ComponentDirector}\r
+  ${If} $R0 <> 0\r
+    ${If} "$ConfigDirectorName" == ""\r
+      StrCpy $ConfigDirectorName "$HostName-dir"\r
+    ${EndIf}\r
+    ${If} "$ConfigDirectorPassword" == ""\r
+      StrCpy $ConfigDirectorPassword "$LocalDirectorPassword"\r
+    ${EndIf}\r
+  ${Else}\r
+    ${If} "$ConfigDirectorName" == "$HostName-dir"\r
+      StrCpy $ConfigDirectorName ""\r
+    ${EndIf}\r
+    ${If} "$ConfigDirectorPassword" == "$LocalDirectorPassword"\r
+      StrCpy $ConfigDirectorPassword ""\r
+    ${EndIf}\r
+  ${EndIf}\r
+\r
+  IntOp $R0 $NewComponents & ${ComponentDirector}\r
+  ${If} $R0 = 0\r
+  ${OrIf} $AutomaticInstall = 0\r
+    IntOp $R8 $R7 + 8\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="Label"$\r$\nText="Name"$\r$\nLeft=6$\r$\nTop=$R7$\r$\nRight=26$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+    IntOp $R6 $R6 + 1\r
+    IntOp $R7 $R7 - 2\r
+\r
+    IntOp $R8 $R8 + 2\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="Text"$\r$\nState=$ConfigDirectorName$\r$\nLeft=50$\r$\nTop=$R7$\r$\nRight=158$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+    IntOp $R6 $R6 + 1\r
+\r
+    ${If} $AutomaticInstall = 0\r
+      IntOp $R0 $NewComponents & ${ComponentsDirectorAndTextGuiConsoles}\r
+      ${If} $R0 <> 0\r
+        IntOp $R7 $R7 + 2\r
+        IntOp $R8 $R8 - 2\r
+        FileWrite $R5 '[Field $R6]$\r$\nType="Label"$\r$\nText="Port"$\r$\nLeft=172$\r$\nTop=$R7$\r$\nRight=188$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+        IntOp $R6 $R6 + 1\r
+        IntOp $R7 $R7 - 2\r
+\r
+        IntOp $R8 $R8 + 2\r
+        FileWrite $R5 '[Field $R6]$\r$\nType="Text"$\r$\nFlags="ONLY_NUMBERS"$\r$\nState=$ConfigDirectorPort$\r$\nLeft=190$\r$\nTop=$R7$\r$\nRight=218$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+        IntOp $R6 $R6 + 1\r
+      ${EndIf}\r
+\r
+      IntOp $R0 $NewComponents & ${ComponentDirector}\r
+      ${If} $R0 <> 0\r
+        IntOp $R7 $R7 + 2\r
+        IntOp $R8 $R8 - 2\r
+        FileWrite $R5 '[Field $R6]$\r$\nType="Label"$\r$\nText="Max Jobs"$\r$\nLeft=238$\r$\nTop=$R7$\r$\nRight=270$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+        IntOp $R6 $R6 + 1\r
+        IntOp $R7 $R7 - 2\r
+\r
+        IntOp $R8 $R8 + 2\r
+        FileWrite $R5 '[Field $R6]$\r$\nType="Text"$\r$\nFlags="ONLY_NUMBERS"$\r$\nState=$ConfigDirectorMaxJobs$\r$\nLeft=274$\r$\nTop=$R7$\r$\nRight=294$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+        IntOp $R6 $R6 + 1\r
+      ${EndIf}\r
+    ${EndIf}\r
+\r
+    IntOp $R7 $R7 + 14\r
+  ${EndIf}\r
+\r
+  IntOp $R0 $NewComponents & ${ComponentsTextAndGuiConsoles}\r
+  ${If} $R0 <> 0\r
+  ${OrIf} $AutomaticInstall = 0\r
+    IntOp $R0 $NewComponents & ${ComponentsDirectorAndTextGuiConsoles}\r
+    ${If} $R0 <> 0\r
+      IntOp $R7 $R7 + 2\r
+      IntOp $R8 $R7 + 8\r
+\r
+      FileWrite $R5 '[Field $R6]$\r$\nType="Label"$\r$\nText="Password"$\r$\nLeft=6$\r$\nTop=$R7$\r$\nRight=38$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+\r
+      IntOp $R6 $R6 + 1\r
+      IntOp $R7 $R7 - 2\r
+      IntOp $R8 $R8 + 2\r
+\r
+      FileWrite $R5 '[Field $R6]$\r$\nType="Text"$\r$\nState=$ConfigDirectorPassword$\r$\nLeft=50$\r$\nTop=$R7$\r$\nRight=294$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+\r
+      IntOp $R6 $R6 + 1\r
+      IntOp $R7 $R7 + 14\r
+    ${EndIf}\r
+  ${EndIf}\r
+\r
+  IntOp $R0 $NewComponents & ${ComponentDirector}\r
+  ${If} $R0 <> 0\r
+    IntOp $R7 $R7 + 2\r
+    IntOp $R8 $R7 + 8\r
+\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="Label"$\r$\nText="Mail Server"$\r$\nLeft=6$\r$\nTop=$R7$\r$\nRight=48$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+\r
+    IntOp $R6 $R6 + 1\r
+    IntOp $R7 $R7 - 2\r
+    IntOp $R8 $R8 + 2\r
+\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="Text"$\r$\nState=$ConfigDirectorMailServer$\r$\nLeft=50$\r$\nTop=$R7$\r$\nRight=294$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+    IntOp $R6 $R6 + 1\r
+    IntOp $R7 $R7 + 16\r
+    IntOp $R8 $R7 + 8\r
+\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="Label"$\r$\nText="Mail Address"$\r$\nLeft=6$\r$\nTop=$R7$\r$\nRight=48$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+\r
+    IntOp $R6 $R6 + 1\r
+    IntOp $R7 $R7 - 2\r
+    IntOp $R8 $R8 + 2\r
+\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="Text"$\r$\nState=$ConfigDirectorMailAddress$\r$\nLeft=50$\r$\nTop=$R7$\r$\nRight=294$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+    IntOp $R6 $R6 + 1\r
+    IntOp $R7 $R7 + 16\r
+    IntOp $R8 $R7 + 8\r
+\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="Label"$\r$\nText="Database"$\r$\nLeft=6$\r$\nTop=$R7$\r$\nRight=38$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+\r
+    IntOp $R6 $R6 + 1\r
+    IntOp $R7 $R7 - 2\r
+    IntOp $R8 $R8 + 2\r
+\r
+    ${If} $ConfigDirectorDB = 0\r
+      ${If} $MySQLPath != ""\r
+        StrCpy $ConfigDirectorDB 1\r
+      ${ElseIf} $PostgreSQLPath != ""\r
+        StrCpy $ConfigDirectorDB 2\r
+      ${Else}\r
+        StrCpy $ConfigDirectorDB 3\r
+      ${EndIf}\r
+    ${EndIf}\r
+\r
+    ${If} $ConfigDirectorDB = 1\r
+      StrCpy $R9 1\r
+    ${Else}\r
+      StrCpy $R9 0\r
+    ${EndIf}\r
+\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="RadioButton"$\r$\nState=$R9$\r$\nText="MySQL"$\r$\nFlags="GROUP"$\r$\nLeft=50$\r$\nTop=$R7$\r$\nRight=90$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+\r
+    IntOp $R6 $R6 + 1\r
+\r
+    ${If} $ConfigDirectorDB = 2\r
+      StrCpy $R9 1\r
+    ${Else}\r
+      StrCpy $R9 0\r
+    ${EndIf}\r
+\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="RadioButton"$\r$\nState=$R9$\r$\nText="PostgreSQL"$\r$\nFlags="NOTABSTOP"$\r$\nLeft=94$\r$\nTop=$R7$\r$\nRight=146$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+\r
+    IntOp $R6 $R6 + 1\r
+\r
+    ${If} $ConfigDirectorDB = 3\r
+      StrCpy $R9 1\r
+    ${Else}\r
+      StrCpy $R9 0\r
+    ${EndIf}\r
+\r
+    FileWrite $R5 '[Field $R6]$\r$\nType="RadioButton"$\r$\nState=$R9$\r$\nText="Sqlite"$\r$\nFlags="NOTABSTOP"$\r$\nLeft=150$\r$\nTop=$R7$\r$\nRight=182$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+\r
+    IntOp $R6 $R6 + 1\r
+    IntOp $R7 $R7 + 12\r
+\r
+    ${If} $AutomaticInstall = 0\r
+      IntOp $R8 $R7 + 10\r
+      FileWrite $R5 '[Field $R6]$\r$\nType="Checkbox"$\r$\nState=$ConfigDirectorInstallService$\r$\nText="Install as service"$\r$\nLeft=50$\r$\nTop=$R7$\r$\nRight=118$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+      IntOp $R6 $R6 + 1\r
+\r
+      FileWrite $R5 '[Field $R6]$\r$\nType="Checkbox"$\r$\nState=$ConfigDirectorStartService$\r$\nText="Start after install"$\r$\nLeft=190$\r$\nTop=$R7$\r$\nRight=260$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+\r
+      IntOp $R6 $R6 + 1\r
+      IntOp $R7 $R7 + 12\r
+    ${EndIf}\r
+  ${Else}\r
+    IntOp $R0 $NewComponents & ${ComponentsTextAndGuiConsoles}\r
+    ${If} $R0 <> 0\r
+      IntOp $R7 $R7 + 2\r
+      IntOp $R8 $R7 + 8\r
+\r
+      FileWrite $R5 '[Field $R6]$\r$\nType="Label"$\r$\nText="Address"$\r$\nLeft=6$\r$\nTop=$R7$\r$\nRight=48$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+\r
+      IntOp $R6 $R6 + 1\r
+      IntOp $R7 $R7 - 2\r
+      IntOp $R8 $R8 + 2\r
+\r
+      FileWrite $R5 '[Field $R6]$\r$\nType="Text"$\r$\nState=$ConfigDirectorAddress$\r$\nLeft=50$\r$\nTop=$R7$\r$\nRight=294$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+      IntOp $R6 $R6 + 1\r
+      IntOp $R7 $R7 + 14\r
+      IntOp $R8 $R7 + 8\r
+    ${EndIf}\r
+  ${EndIf}\r
+\r
+  IntOp $R7 $R7 + 4\r
+\r
+  ${If} $AutomaticInstall = 0\r
+    IntOp $R0 $NewComponents & ${ComponentsFileAndStorageAndDirector}\r
+    ${If} $R0 <> 0\r
+      IntOp $R8 $R7 + 42\r
+\r
+      FileWrite $R5 '[Field $R6]$\r$\nType="GroupBox"$\r$\nText="Monitor"$\r$\nLeft=0$\r$\nTop=$R7$\r$\nRight=300$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+      IntOp $R6 $R6 + 1\r
+      IntOp $R7 $R7 + 12\r
+\r
+      IntOp $R8 $R7 + 8\r
+      FileWrite $R5 '[Field $R6]$\r$\nType="Label"$\r$\nText="Name"$\r$\nLeft=6$\r$\nTop=$R7$\r$\nRight=26$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+      IntOp $R6 $R6 + 1\r
+      IntOp $R7 $R7 - 2\r
+\r
+      IntOp $R8 $R8 + 2\r
+      FileWrite $R5 '[Field $R6]$\r$\nType="Text"$\r$\nState=$ConfigMonitorName$\r$\nLeft=50$\r$\nTop=$R7$\r$\nRight=150$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+      IntOp $R6 $R6 + 1\r
+      IntOp $R7 $R7 + 16\r
+      IntOp $R8 $R7 + 8\r
+\r
+      FileWrite $R5 '[Field $R6]$\r$\nType="Label"$\r$\nText="Password"$\r$\nLeft=6$\r$\nTop=$R7$\r$\nRight=38$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+\r
+      IntOp $R6 $R6 + 1\r
+      IntOp $R7 $R7 - 2\r
+      IntOp $R8 $R8 + 2\r
+\r
+      FileWrite $R5 '[Field $R6]$\r$\nType="Text"$\r$\nState=$ConfigMonitorPassword$\r$\nLeft=50$\r$\nTop=$R7$\r$\nRight=294$\r$\nBottom=$R8$\r$\n$\r$\n'\r
+\r
+      IntOp $R6 $R6 + 1\r
+      IntOp $R7 $R7 + 20\r
+    ${EndIf}\r
+  ${EndIf}\r
+\r
+  IntOp $R6 $R6 - 1\r
+  FileWrite $R5 "[Settings]$\r$\nNumFields=$R6$\r$\n"\r
+\r
+  FileClose $R5\r
+\r
+  IntOp $R0 $NewComponents & ${ComponentsFileAndStorage}\r
+  ${If} $R0 = 0\r
+  ${OrIf} $AutomaticInstall = 1\r
+    !insertmacro MUI_HEADER_TEXT "$(TITLE_ConfigPage1)" "$(SUBTITLE_ConfigPage1)"\r
+  ${Else}\r
+    !insertmacro MUI_HEADER_TEXT "$(TITLE_ConfigPage2)" "$(SUBTITLE_ConfigPage2)"\r
+  ${EndIf}\r
+\r
+  !insertmacro MUI_INSTALLOPTIONS_INITDIALOG "ConfigPage2.ini"\r
+  Pop $HDLG ;HWND of dialog\r
+\r
+  ; Initialize Controls\r
+  StrCpy $R6 2  ; Field Number\r
+\r
+  IntOp $R0 $NewComponents & ${ComponentDirector}\r
+  ${If} $R0 = 0\r
+  ${OrIf} $AutomaticInstall = 0\r
+    ; Name\r
+    IntOp $R6 $R6 + 1\r
+    !insertmacro MUI_INSTALLOPTIONS_READ $HCTL "ConfigPage2.ini" "Field $R6" "HWND"\r
+    SendMessage $HCTL ${EM_LIMITTEXT} 30 0\r
+    IntOp $R6 $R6 + 1\r
+\r
+    ${If} $AutomaticInstall = 0\r
+      IntOp $R0 $NewComponents & ${ComponentsDirectorAndTextGuiConsoles}\r
+      ${If} $R0 <> 0\r
+        IntOp $R6 $R6 + 1\r
+        ; Port Number\r
+        !insertmacro MUI_INSTALLOPTIONS_READ $HCTL "ConfigPage2.ini" "Field $R6" "HWND"\r
+        SendMessage $HCTL ${EM_LIMITTEXT} 5 0\r
+        IntOp $R6 $R6 + 1\r
+      ${EndIf}\r
+\r
+      IntOp $R0 $NewComponents & ${ComponentDirector}\r
+      ${If} $R0 <> 0\r
+        IntOp $R6 $R6 + 1\r
+        ; Max Jobs\r
+        !insertmacro MUI_INSTALLOPTIONS_READ $HCTL "ConfigPage2.ini" "Field $R6" "HWND"\r
+        SendMessage $HCTL ${EM_LIMITTEXT} 3 0\r
+\r
+        IntOp $R6 $R6 + 1\r
+      ${EndIf}\r
+    ${EndIf}\r
+  ${EndIf}\r
+\r
+  IntOp $R0 $NewComponents & ${ComponentsTextAndGuiConsoles}\r
+  ${If} $R0 <> 0\r
+  ${OrIf} $AutomaticInstall = 0\r
+    IntOp $R0 $NewComponents & ${ComponentsDirectorAndTextGuiConsoles}\r
+    ${If} $R0 <> 0\r
+      IntOp $R6 $R6 + 2\r
+    ${EndIf}\r
+  ${EndIf}\r
+\r
+  IntOp $R0 $NewComponents & ${ComponentDirector}\r
+  ${If} $R0 <> 0\r
+    IntOp $R6 $R6 + 9\r
+\r
+    ${If} $AutomaticInstall = 0\r
+      IntOp $R6 $R6 + 2\r
+    ${EndIf}\r
+  ${Else}\r
+    IntOp $R0 $NewComponents & ${ComponentsTextAndGuiConsoles}\r
+    ${If} $R0 <> 0\r
+      IntOp $R6 $R6 + 2\r
+    ${EndIf}\r
+  ${EndIf}\r
+\r
+  ${If} $AutomaticInstall = 0\r
+    IntOp $R0 $NewComponents & ${ComponentsFileAndStorageAndDirector}\r
+    ${If} $R0 <> 0\r
+      IntOp $R6 $R6 + 2\r
+      !insertmacro MUI_INSTALLOPTIONS_READ $HCTL "ConfigPage2.ini" "Field $R6" "HWND"\r
+      SendMessage $HCTL ${EM_LIMITTEXT} 30 0\r
+      IntOp $R6 $R6 + 2\r
+    ${EndIf}\r
+  ${EndIf}\r
+\r
+  !insertmacro MUI_INSTALLOPTIONS_SHOW\r
+\r
+  ; Process results\r
+\r
+  StrCpy $R6 2\r
+\r
+  IntOp $R0 $NewComponents & ${ComponentDirector}\r
+  ${If} $R0 = 0\r
+  ${OrIf} $AutomaticInstall = 0\r
+    IntOp $R6 $R6 + 1\r
+    !insertmacro MUI_INSTALLOPTIONS_READ $ConfigDirectorName "ConfigPage2.ini" "Field $R6" "State"\r
+    IntOp $R6 $R6 + 1\r
+\r
+    ${If} $AutomaticInstall = 0\r
+      IntOp $R0 $NewComponents & ${ComponentsDirectorAndTextGuiConsoles}\r
+      ${If} $R0 <> 0\r
+        IntOp $R6 $R6 + 1\r
+        !insertmacro MUI_INSTALLOPTIONS_READ $ConfigDirectorPort "ConfigPage2.ini" "Field $R6" "State"\r
+        IntOp $R6 $R6 + 1\r
+      ${EndIf}\r
+\r
+      IntOp $R0 $NewComponents & ${ComponentDirector}\r
+      ${If} $R0 <> 0\r
+        IntOp $R6 $R6 + 1\r
+        !insertmacro MUI_INSTALLOPTIONS_READ $ConfigDirectorMaxJobs "ConfigPage2.ini" "Field $R6" "State"\r
+        IntOp $R6 $R6 + 1\r
+      ${EndIf}\r
+    ${EndIf}\r
+  ${EndIf}\r
+\r
+  IntOp $R0 $NewComponents & ${ComponentsTextAndGuiConsoles}\r
+  ${If} $R0 <> 0\r
+  ${OrIf} $AutomaticInstall = 0\r
+    IntOp $R0 $NewComponents & ${ComponentsDirectorAndTextGuiConsoles}\r
+    ${If} $R0 <> 0\r
+      IntOp $R6 $R6 + 1\r
+      !insertmacro MUI_INSTALLOPTIONS_READ $ConfigDirectorPassword "ConfigPage2.ini" "Field $R6" "State"\r
+      IntOp $R6 $R6 + 1\r
+    ${EndIf}\r
+  ${EndIf}\r
+\r
+  IntOp $R0 $NewComponents & ${ComponentDirector}\r
+  ${If} $R0 <> 0\r
+    IntOp $R6 $R6 + 1\r
+    !insertmacro MUI_INSTALLOPTIONS_READ $ConfigDirectorMailServer "ConfigPage2.ini" "Field $R6" "State"\r
+    IntOp $R6 $R6 + 2\r
+    !insertmacro MUI_INSTALLOPTIONS_READ $ConfigDirectorMailAddress "ConfigPage2.ini" "Field $R6" "State"\r
+    IntOp $R6 $R6 + 2\r
+    !insertmacro MUI_INSTALLOPTIONS_READ $R5 "ConfigPage2.ini" "Field $R6" "State"\r
+    ${If} $R5 = 1\r
+      StrCpy $ConfigDirectorDB 1\r
+    ${Endif}\r
+    IntOp $R6 $R6 + 1\r
+    !insertmacro MUI_INSTALLOPTIONS_READ $R5 "ConfigPage2.ini" "Field $R6" "State"\r
+    ${If} $R5 = 1\r
+      StrCpy $ConfigDirectorDB 2\r
+    ${Endif}\r
+    IntOp $R6 $R6 + 1\r
+    !insertmacro MUI_INSTALLOPTIONS_READ $R5 "ConfigPage2.ini" "Field $R6" "State"\r
+    ${If} $R5 = 1\r
+      StrCpy $ConfigDirectorDB 3\r
+    ${Endif}\r
+    IntOp $R6 $R6 + 1\r
+\r
+    ${If} $AutomaticInstall = 0\r
+      !insertmacro MUI_INSTALLOPTIONS_READ $ConfigDirectorInstallService "ConfigPage2.ini" "Field $R6" "State"\r
+      IntOp $R6 $R6 + 1\r
+      !insertmacro MUI_INSTALLOPTIONS_READ $ConfigDirectorStartService "ConfigPage2.ini" "Field $R6" "State"\r
+      IntOp $R6 $R6 + 1\r
+    ${EndIf}\r
+  ${Else}\r
+    IntOp $R0 $NewComponents & ${ComponentsTextAndGuiConsoles}\r
+    ${If} $R0 <> 0\r
+      IntOp $R6 $R6 + 1\r
+      !insertmacro MUI_INSTALLOPTIONS_READ $ConfigDirectorAddress "ConfigPage2.ini" "Field $R6" "State"\r
+      IntOp $R6 $R6 + 1\r
+    ${EndIf}\r
+  ${EndIf}\r
+\r
+  ${If} $AutomaticInstall = 0\r
+    IntOp $R0 $NewComponents & ${ComponentsFileAndStorageAndDirector}\r
+    ${If} $R0 <> 0\r
+      IntOp $R6 $R6 + 2\r
+      !insertmacro MUI_INSTALLOPTIONS_READ $ConfigMonitorName "ConfigPage2.ini" "Field $R6" "State"\r
+      IntOp $R6 $R6 + 2\r
+      !insertmacro MUI_INSTALLOPTIONS_READ $ConfigMonitorPassword "ConfigPage2.ini" "Field $R6" "State"\r
+    ${EndIf}\r
+  ${EndIf}\r
+FunctionEnd\r
+\r
+Function LeaveConfigPage2\r
+  ${If} $AutomaticInstall = 0\r
+    StrCpy $R6 4\r
+\r
+    IntOp $R0 $NewComponents & ${ComponentsDirectorAndTextGuiConsoles}\r
+    ${If} $R0 <> 0\r
+      IntOp $R6 $R6 + 1\r
+      !insertmacro MUI_INSTALLOPTIONS_READ $R0 "ConfigPage2.ini" "Field $R6" "State"\r
+      ${If} $R0 < 1024\r
+      ${OrIf} $R0 > 65535\r
+        MessageBox MB_OK "Port must be between 1024 and 65535 inclusive."\r
+        Abort\r
+      ${EndIf}\r
+      IntOp $R6 $R6 + 1\r
+    ${EndIf}\r
+\r
+    IntOp $R0 $NewComponents & ${ComponentDirector}\r
+    ${If} $R0 <> 0\r
+      IntOp $R6 $R6 + 1\r
+      !insertmacro MUI_INSTALLOPTIONS_READ $R0 "ConfigPage2.ini" "Field $R6" "State"\r
+      ${If} $R0 < 1\r
+      ${OrIf} $R0 > 99\r
+        MessageBox MB_OK "Max Jobs must be between 1 and 99 inclusive."\r
+        Abort\r
+      ${EndIf}\r
+      IntOp $R6 $R6 + 1\r
+    ${EndIf}\r
+  ${EndIf}\r
+FunctionEnd\r
diff --git a/bacula/src/win32/newinstaller/DumpLog.nsh b/bacula/src/win32/newinstaller/DumpLog.nsh
new file mode 100644 (file)
index 0000000..c450044
--- /dev/null
@@ -0,0 +1,46 @@
+!define LVM_GETITEMCOUNT 0x1004\r
+!define LVM_GETITEMTEXT 0x102D\r
+\r
+Function DumpLog\r
+  Exch $5\r
+  Push $0\r
+  Push $1\r
+  Push $2\r
+  Push $3\r
+  Push $4\r
+  Push $6\r
+\r
+  FindWindow $0 "#32770" "" $HWNDPARENT\r
+  GetDlgItem $0 $0 1016\r
+  StrCmp $0 0 error\r
+  FileOpen $5 $5 "w"\r
+  StrCmp $5 0 error\r
+    SendMessage $0 ${LVM_GETITEMCOUNT} 0 0 $6\r
+    System::Alloc ${NSIS_MAX_STRLEN}\r
+    Pop $3\r
+    StrCpy $2 0\r
+    System::Call "*(i, i, i, i, i, i, i, i, i) i \\r
+      (0, 0, 0, 0, 0, r3, ${NSIS_MAX_STRLEN}) .r1"\r
+    loop: StrCmp $2 $6 done\r
+      System::Call "User32::SendMessageA(i, i, i, i) i \\r
+        ($0, ${LVM_GETITEMTEXT}, $2, r1)"\r
+      System::Call "*$3(&t${NSIS_MAX_STRLEN} .r4)"\r
+      FileWrite $5 "$4$\r$\n"\r
+      IntOp $2 $2 + 1\r
+      Goto loop\r
+    done:\r
+      FileClose $5\r
+      System::Free $1\r
+      System::Free $3\r
+      Goto exit\r
+  error:\r
+    MessageBox MB_OK error\r
+  exit:\r
+    Pop $6\r
+    Pop $4\r
+    Pop $3\r
+    Pop $2\r
+    Pop $1\r
+    Pop $0\r
+    Exch $5\r
+FunctionEnd\r
diff --git a/bacula/src/win32/newinstaller/InstallType.ini b/bacula/src/win32/newinstaller/InstallType.ini
new file mode 100644 (file)
index 0000000..62c88cf
--- /dev/null
@@ -0,0 +1,51 @@
+[Settings]\r
+NumFields=6\r
+\r
+[Field 1]\r
+Type=Label\r
+Text=This is a new installation.  Please choose the installation type.\r
+Left=0\r
+Right=300\r
+Top=0\r
+Bottom=28\r
+\r
+[Field 2]\r
+Type=GroupBox\r
+Text=Installation Type\r
+Left=0\r
+Right=300\r
+Top=32\r
+Bottom=136\r
+\r
+[Field 3]\r
+Type=RadioButton\r
+Text=Automatic\r
+State=1\r
+Left=6\r
+Right=52\r
+Top=44\r
+Bottom=54\r
+\r
+[Field 4]\r
+Type=RadioButton\r
+Text=Custom\r
+Left=6\r
+Right=44\r
+Top=90\r
+Bottom=100\r
+\r
+[Field 5]\r
+Type=Label\r
+Text=The software will be installed in the default directory "Program Files\\Bacula".  The configuration files will be generated using defaults applicable to most installations.\r
+Left=17\r
+Right=295\r
+Top=58\r
+Bottom=86\r
+\r
+[Field 6]\r
+Type=Label\r
+Text=You may choose the installation directory.  The configuration defaults will be displayed and you will be given the chance to make changes before the configuration files are written.\r
+Left=17\r
+Right=295\r
+Top=104\r
+Bottom=132\r
diff --git a/bacula/src/win32/newinstaller/InstallType.nsh b/bacula/src/win32/newinstaller/InstallType.nsh
new file mode 100644 (file)
index 0000000..0a0f902
--- /dev/null
@@ -0,0 +1,98 @@
+Function EnterInstallType\r
+  Push $R0\r
+  Push $R1\r
+  Push $R2\r
+\r
+  ; Check if this is an upgrade by looking for an uninstaller configured \r
+  ; in the registry.\r
+  ReadRegStr $R0 HKLM "Software\Microsoft\Windows\CurrentVersion\Uninstall\Bacula" "UninstallString"\r
+\r
+  ${If} "$R0" != ""\r
+    ; Check registry for new installer\r
+    ReadRegStr $R1 HKLM "Software\Bacula" "InstallLocation"\r
+    ${If} "$R1" != ""\r
+      ; New Installer \r
+      StrCpy $OldInstallDir $R1\r
+      StrCpy $InstallType ${UpgradeInstall}\r
+\r
+      SetShellVarContext all\r
+\r
+      StrCpy $R1 "$APPDATA\Bacula"\r
+      StrCpy $R2 "$INSTDIR\Doc"\r
+\r
+      ReadRegDWORD $PreviousComponents HKLM "Software\Bacula" "Components"\r
+\r
+      WriteINIStr "$PLUGINSDIR\InstallType.ini" "Field 1" "Text" "A previous installation has been found in $OldInstallDir.  Please choose the installation type for any additional components you select."\r
+      WriteINIStr "$PLUGINSDIR\InstallType.ini" "Field 5" "Text" "The configuration files for additional components will be generated using defaults applicable to most installations."\r
+      WriteINIStr "$PLUGINSDIR\InstallType.ini" "Field 6" "Text" "The configuration defaults for additional components will be displayed and you will be given the chance to make changes before the configuration files are written."\r
+\r
+      ReadRegDWORD $ConfigDirectorDB HKLM Software\Bacula Database\r
+\r
+      ${If} $ConfigDirectorDB = 0\r
+        IntOp $R0 $PreviousComponents & ${ComponentDirector}\r
+        ${If} $R0 <> 0\r
+          StrCpy $ConfigDirectorDB 1\r
+        ${EndIf}\r
+      ${EndIf}\r
+    ${Else}\r
+      ; Processing Upgrade - Get Install Directory\r
+      ${StrRep} $R0 $R0 '"' ''\r
+      ${GetParent} $R0 $OldInstallDir\r
+\r
+      ; Old Installer \r
+      StrCpy $InstallType ${MigrateInstall}\r
+      StrCpy $R1 "$OldInstallDir\bin"\r
+      StrCpy $R2 "$OldInstallDir\Doc"\r
+\r
+      WriteINIStr "$PLUGINSDIR\InstallType.ini" "Field 1" "Text" "An old installation has been found in $OldInstallDir.  The Configuration will be migrated.  Please choose the installation type for any additional components you select."\r
+      WriteINIStr "$PLUGINSDIR\InstallType.ini" "Field 5" "Text" "The software will be installed in the default directory $\"$PROGRAMFILES\Bacula$\".  The configuration files for additional components will be generated using defaults applicable to most installations."\r
+      WriteINIStr "$PLUGINSDIR\InstallType.ini" "Field 6" "Text" "You may choose the installation directory.  The configuration defaults will be displayed and you will be given the chance to make changes before the configuration files are written."\r
+    ${EndIf}\r
+  ${Else}\r
+    ; New Install\r
+    StrCpy $InstallType ${NewInstall}\r
+    WriteINIStr "$PLUGINSDIR\InstallType.ini" "Field 5" "Text" "The software will be installed in the default directory $\"$PROGRAMFILES\Bacula$\".  The configuration files will be generated using defaults applicable to most installations."\r
+  ${EndIf}\r
+\r
+  ${If} $InstallType <> ${NewInstall}\r
+  ${AndIf} $PreviousComponents = 0\r
+    ${If} ${FileExists} "$R1\bacula-fd.conf"\r
+      IntOp $PreviousComponents $PreviousComponents | ${ComponentFile}\r
+    ${EndIf}\r
+    ${If} ${FileExists} "$R1\bconsole.conf"\r
+      IntOp $PreviousComponents $PreviousComponents | ${ComponentTextConsole}\r
+    ${EndIf}\r
+    ${If} ${FileExists} "$R1\wx-console.conf"\r
+      IntOp $PreviousComponents $PreviousComponents | ${ComponentGUIConsole}\r
+    ${EndIf}\r
+    ${If} ${FileExists} "$R2\bacula.pdf"\r
+      IntOp $PreviousComponents $PreviousComponents | ${ComponentPDFDocs}\r
+    ${EndIf}\r
+    ${If} ${FileExists} "$R2\bacula\bacula.html"\r
+      IntOp $PreviousComponents $PreviousComponents | ${ComponentHTMLDocs}\r
+    ${EndIf}\r
+    ${If} ${FileExists} "$R2\bacula.html"\r
+      IntOp $PreviousComponents $PreviousComponents | ${ComponentHTMLDocs}\r
+    ${EndIf}\r
+  ${EndIf}\r
+\r
+  !InsertMacro MUI_HEADER_TEXT "$(TITLE_InstallType)" "$(SUBTITLE_InstallType)"\r
+  !InsertMacro MUI_INSTALLOPTIONS_INITDIALOG "InstallType.ini"\r
+  Pop $HDLG ;HWND of dialog\r
+\r
+  !insertmacro MUI_INSTALLOPTIONS_SHOW\r
+\r
+  ; Process Results\r
+\r
+  !insertmacro MUI_INSTALLOPTIONS_READ $R0 "InstallType.ini" "Field 3" "State"\r
+\r
+  ${If} $R0 = 1\r
+    StrCpy $AutomaticInstall 1\r
+  ${Else}\r
+    StrCpy $AutomaticInstall 0\r
+  ${EndIf}\r
+\r
+  Pop $R2\r
+  Pop $R1\r
+  Pop $R0\r
+FunctionEnd\r
diff --git a/bacula/src/win32/newinstaller/Makefile b/bacula/src/win32/newinstaller/Makefile
new file mode 100644 (file)
index 0000000..a52659d
--- /dev/null
@@ -0,0 +1,182 @@
+#
+# Makefile for win32 bacula executables
+# Using MinGW cross-compiler on GNU/Linux
+#
+#  Written by Robert Nelson, June 2006
+#
+
+include ../Makefile.inc
+
+VERSION := $(shell sed -ne 's/.*[ \t]VERSION[ \t][ \t]*"\(.*\)"/\1/p' < ../../version.h)
+
+DEFINES := \
+       -DVERSION=$(VERSION) \
+       -DOUT_DIR=..\\release \
+       -DSRC_DIR=release \
+       -DBUILD_TOOLS=MinGW \
+
+INSTALL_EXE := $(BUILDDIR)/release/winbacula-$(VERSION).exe
+
+BACULA_BINARIES := \
+       bacula.dll \
+       cats_mysql.dll \
+       cats_postgresql.dll \
+       cats_sqlite3.dll \
+       exchange-fd.dll \
+       bacula-dir.exe \
+       bacula-fd.exe \
+       bacula-sd.exe \
+       bconsole.exe \
+       bcopy.exe \
+       bextract.exe \
+       bls.exe \
+       bscan.exe \
+       bsleep.exe \
+       bsmtp.exe \
+       btape.exe \
+       dbcheck.exe \
+       scsilist.exe \
+       bwx-console.exe
+
+DEPKGS_BINARIES := \
+       libeay32.dll \
+       pthreadGCE.dll \
+       ssleay32.dll \
+       zlib1.dll \
+       sqlite3.exe \
+       openssl.exe \
+       loaderinfo.exe \
+       mt.exe \
+       mtx.exe \
+       scsitape.exe \
+       sed.exe \
+       tapeinfo.exe \
+       expr64.exe \
+       snooze.exe \
+       mkisofs.exe \
+       growisofs.exe \
+       dvd-ram-control.exe \
+       dvd+rw-booktype.exe \
+       dvd+rw-format.exe \
+       dvd+rw-mediainfo.exe \
+       wxbase28_gcc_bacula.dll \
+       wxmsw28_core_gcc_bacula.dll
+
+NONGCC_BINARIES := \
+       libmysql.dll
+
+NONGCC_LIBRARIES := \
+       libpq.dll
+
+MINGW_BINARIES := \
+       mingwm10.dll
+
+SCRIPT_FILES := \
+       mtx-changer.cmd \
+       disk-changer.cmd \
+       dvd-handler.cmd
+
+CAT_FILES := \
+       create_mysql_database.cmd \
+       drop_mysql_database.cmd \
+       make_mysql_tables.cmd \
+       make_mysql_tables.sql \
+       drop_mysql_tables.cmd \
+       drop_mysql_tables.sql \
+       grant_mysql_privileges.cmd \
+       grant_mysql_privileges.sql \
+       make_mysql_catalog_backup.cmd \
+       create_postgresql_database.cmd \
+       create_postgresql_database.sql \
+       drop_postgresql_database.cmd \
+       make_postgresql_tables.cmd \
+       make_postgresql_tables.sql \
+       drop_postgresql_tables.cmd \
+       drop_postgresql_tables.sql \
+       grant_postgresql_privileges.cmd \
+       grant_postgresql_privileges.sql \
+       make_postgresql_catalog_backup.cmd \
+       create_sqlite3_database.cmd \
+       drop_sqlite3_database.cmd \
+       make_sqlite3_tables.cmd \
+       make_sqlite3_tables.sql \
+       drop_sqlite3_tables.cmd \
+       grant_sqlite3_privileges.cmd \
+       make_sqlite3_catalog_backup.cmd \
+       delete_catalog_backup.cmd
+
+DIRD_FILES := \
+       query.sql
+
+SSL_FILES := \
+       openssl.cnf
+
+DOC_FILES := \
+       manual/bacula.pdf \
+       manual/bacula/*.html \
+       manual/bacula/*.png  \
+       manual/bacula/*.css
+
+##########################################################################
+
+# Targets
+
+.PHONY: all clean installer
+
+all:           $(INSTALL_EXE)
+
+installer:     $(INSTALL_EXE)
+
+clean:
+       @echo "Cleaning `pwd`"
+       $(CMD_ECHO)-rm -f $(INSTALL_EXE)
+       $(CMD_ECHO)-rm -rf release
+
+#
+# Rules
+#
+
+define Convert_Binary
+release/$$(notdir $(1)): $(1)
+       $$(call checkdir,$$@)
+       $(ECHO_CMD)cp -f $$^ $$@ ; \
+       $(STAB2CV) $$@
+endef
+
+define Copy_Binary
+release/$$(notdir $(1)): $(1)
+       $$(call checkdir,$$@)
+       $(ECHO_CMD)cp -f $$^ $$@
+endef
+
+define Copy_Docs
+release/$(1): $(DOCDIR)/$(1)
+       $$(call checkdir,$$@)
+       $(ECHO_CMD)cp -f $$^ $$(dir $$@)
+endef
+
+$(foreach file,$(addprefix $(DEPKGS)/bin/, $(DEPKGS_BINARIES)),$(eval $(call Convert_Binary,$(file))))
+
+$(foreach file,$(addprefix $(DEPKGS)/bin/, $(NONGCC_BINARIES)),$(eval $(call Copy_Binary,$(file))))
+
+$(foreach file,$(addprefix $(DEPKGS)/lib/, $(NONGCC_LIBRARIES)),$(eval $(call Copy_Binary,$(file))))
+
+$(foreach file,$(addprefix $(BINDIR)/, $(BACULA_BINARIES)),$(eval $(call Convert_Binary,$(file))))
+
+$(foreach file,$(addprefix $(MINGW_DLLDIR)/, $(MINGW_BINARIES)),$(eval $(call Copy_Binary,$(file))))
+
+$(foreach file,$(addprefix $(DEPKGS)/ssl/, $(SSL_FILES)),$(eval $(call Copy_Binary,$(file))))
+
+$(foreach file,$(addprefix ../scripts/, $(SCRIPT_FILES)),$(eval $(call Copy_Binary,$(file))))
+
+$(foreach file,$(addprefix ../cats/, $(CAT_FILES)),$(eval $(call Copy_Binary,$(file))))
+
+$(foreach file,$(addprefix ../../dird/, $(DIRD_FILES)),$(eval $(call Copy_Binary,$(file))))
+
+$(foreach file,$(DOC_FILES),$(eval $(call Copy_Docs,$(file))))
+
+$(INSTALL_EXE): winbacula.nsi $(addprefix release/,$(BACULA_BINARIES) $(SCRIPT_FILES) $(CAT_FILES) $(DEPKGS_BINARIES) $(NONGCC_BINARIES) $(NONGCC_LIBRARIES) $(MINGW_BINARIES) $(SSL_FILES) $(DIRD_FILES) $(DOC_FILES))
+       NSISDIR=$(NSIS_DIR) \
+       $(NSIS_DIR)/makensis -V3 $(DEFINES) winbacula.nsi
+
+include $(BUILDDIR)/Makefile.rules
diff --git a/bacula/src/win32/newinstaller/Readme.txt b/bacula/src/win32/newinstaller/Readme.txt
new file mode 100755 (executable)
index 0000000..5535f9b
--- /dev/null
@@ -0,0 +1,85 @@
+Bacula - Windows Version Disclaimer\r
+===================================\r
+\r
+Please note, only the Win32 Client (File daemon) is supported.  All the\r
+other components (Director, Storage daemon, their utilities) are provided\r
+on an "as is" basis.  Unfortunately, they are neither properly tested,   \r
+documented, or supported.  This means that we cannot ensure that bug reports\r
+against the non-supported components will be fixed.  For them to be supported, \r
+we need three things from the Open Source community:\r
+\r
+1. Full documentation of the Windows particularities of the Director,\r
+   the Storage daemon, and their utilities in the Bacula manual.\r
+\r
+2. Someone to periodically and on demand run the regressions tests.\r
+\r
+3. One or more developers who are willing to accept and correct Windows\r
+   related bugs as they occur.\r
+\r
+4. A certain Win32 community that will respond to user support questions\r
+   on the bacula-users list.  (This is probably already fullfilled). \r
+             \r
+\r
+Bacula - Windows Version Notes\r
+==============================\r
+\r
+These notes highlight how the Windows version of Bacula differs from the \r
+other versions.  It also provides any notes additional to the documentation.\r
+\r
+For detailed documentation on using, configuring and troubleshooting Bacula,\r
+please consult the installed documentation or the online documentation at\r
+http://www.bacula.org/?page=documentation.\r
+\r
+\r
+Start Menu Items\r
+----------------\r
+A number of menu items have been created in the Start menu under All Programs\r
+in the Bacula submenu.  They may be selected to edit the configuration files,\r
+view the documentation or run one of the console or utility programs.  The \r
+choices available will vary depending on the options you chose to install.\r
+\r
+\r
+File Locations\r
+--------------\r
+The programs and documentation are installed in the directory \r
+"C:\Program Files\Bacula" unless a different directory was selected during\r
+installation.  The configuration and other application data files are in the\r
+"C:\Documents and Settings\All Users\Application Data\Bacula" directory.\r
+\r
+Code Page Problems\r
+-------------------\r
+Please note that Bacula expects the contents of the configuration files to be \r
+written in UTF-8 format. Some translations of "Application Data" have accented\r
+characters, and apparently the installer writes this translated data in the\r
+standard Windows code page coding.  This occurs for the Working Directory, and \r
+when it happens the daemon will not start since Bacula cannot find the directory.\r
+The workaround is to manually edit the appropriate conf file and ensure that it\r
+is written out in UTF-8 format.\r
+\r
+The conf files can be edited with any UTF-8 compatible editor, or on most \r
+modern Win32 machines, you can edit them with notepad, then choose UTF-8\r
+output encoding before saving them.\r
+\r
+\r
+Storage and Director Services\r
+-----------------------------\r
+These services are still considered experimental in this release.  Use of \r
+them should be approached with caution since they haven't received the\r
+same level of extensive usage and testing that the File service has \r
+received.\r
+\r
+Storage Device Names\r
+--------------------\r
+There is a utility installed called scsilist.exe which displays the installed \r
+devices, their physical address and their device name.  A link to it is \r
+created in the Bacula menu when the Storage service is installed.\r
+\r
+Changer and Tape device names in Windows are Changer0, Changer1, etc and \r
+Tape0, Tape1, etc.  If there isn't a device driver loaded for the Changer \r
+then you need to use the address <Port>:<Bus>:<Target>:<Lun>.  Port is the \r
+SCSI Adapter Number, Bus is the Bus Number on the adapter (usually 0 since \r
+most adapters only have one bus), Target is the device's Target Device ID, \r
+Lun is the Logical Unit Number.\r
\r
+You must specify DeviceType = tape in the Device resource in bacula-sd.conf \r
+since auto detection of device type doesn't work at the present time.\r
diff --git a/bacula/src/win32/newinstaller/Start.bat b/bacula/src/win32/newinstaller/Start.bat
new file mode 100644 (file)
index 0000000..0b61f7e
--- /dev/null
@@ -0,0 +1,5 @@
+rem\r
+rem Bacula start file for Win95/98/Me\r
+rem\r
+cd c:\bacula\bin\r
+c:\bacula\bin\bacula-fd.exe /service -c c:\bacula\bin\bacula-fd.conf\r
diff --git a/bacula/src/win32/newinstaller/Stop.bat b/bacula/src/win32/newinstaller/Stop.bat
new file mode 100644 (file)
index 0000000..3b1d0e5
--- /dev/null
@@ -0,0 +1,5 @@
+rem\r
+rem Bacula stop file for Win95/98/Me\r
+rem\r
+cd c:\bacula\bin\r
+c:\bacula\bin\bacula-fd.exe /kill\r
diff --git a/bacula/src/win32/newinstaller/WriteTemplates.ini b/bacula/src/win32/newinstaller/WriteTemplates.ini
new file mode 100644 (file)
index 0000000..c3c0aad
--- /dev/null
@@ -0,0 +1,48 @@
+[Settings]\r
+NumFields=5\r
+CancelEnabled=0\r
+BackEnabled=0\r
+\r
+[Field 1]\r
+Type="Label"\r
+Text="Templates of the Client and Storage resources can be generated that are customized with the information about this system.  These templates can then be copied to the Director computer and included in the Director's configuration file."\r
+Left=7\r
+Right=293\r
+Top=6\r
+Bottom=32\r
+\r
+[Field 2]\r
+Type="CheckBox"\r
+Text="Client"\r
+Left=6\r
+Right=40\r
+Top=38\r
+Bottom=48\r
+\r
+[Field 3]\r
+Type="FileRequest"\r
+State="Client.conf"\r
+Flags=\r
+Filter=Configuration Files|*.conf|All Files|*.*\r
+Left=16\r
+Right=288\r
+Top=50\r
+Bottom=62\r
+\r
+[Field 4]\r
+Type="CheckBox"\r
+Text="Storage"\r
+Left=6\r
+Right=48\r
+Top=70\r
+Bottom=80\r
+\r
+[Field 5]\r
+Type="FileRequest"\r
+State="Storage.conf"\r
+Flags=REQ_SAVE|FILE_EXPLORER|WARN_IF_EXIST\r
+Filter=Configuration Files|*.conf|All Files|*.*\r
+Left=16\r
+Right=288\r
+Top=82\r
+Bottom=94\r
diff --git a/bacula/src/win32/newinstaller/bacula-dir.conf.in b/bacula/src/win32/newinstaller/bacula-dir.conf.in
new file mode 100644 (file)
index 0000000..8a53eee
--- /dev/null
@@ -0,0 +1,384 @@
+#\r
+# Default Bacula Director Configuration file\r
+#\r
+#  The only thing that MUST be changed is to add one or more\r
+#   file or directory names in the Include directive of the\r
+#   FileSet resource.\r
+#\r
+#  For Bacula release @VERSION@ (@DATE@) -- @DISTNAME@ @DISTVER@\r
+#\r
+#  You might also want to change the default email address\r
+#   from root to your address.  See the "mail" and "operator"\r
+#   directives in the Messages resource.\r
+#\r
+\r
+Director {                            # define myself\r
+  Name = @director_name@\r
+  DIRport = @director_port@                # where we listen for UA connections\r
+  QueryFile = "@bin_dir@\\query.sql"\r
+  WorkingDirectory = "@working_dir@"\r
+  PidDirectory = "@working_dir@"\r
+  Maximum Concurrent Jobs = @director_maxjobs@\r
+  Password = "@director_password@"         # Console password\r
+  Messages = Daemon\r
+}\r
+\r
+JobDefs {\r
+  Name = "DefaultJob"\r
+  Type = Backup\r
+  Level = Incremental\r
+  Client = @client_name@\r
+  FileSet = "Test Set"\r
+  Schedule = "WeeklyCycle"\r
+  Storage = File\r
+  Messages = Standard\r
+  Pool = Default\r
+  Priority = 10\r
+}\r
+\r
+\r
+#\r
+# Define the main nightly save backup job\r
+#   By default, this job will back up to disk in C:/tmp\r
+Job {\r
+  Name = "Client1"\r
+  JobDefs = "DefaultJob"\r
+  Write Bootstrap = "@working_dir@\\Client1.bsr"\r
+}\r
+\r
+#Job {\r
+#  Name = "Client2"\r
+#  Client = @client_name@2\r
+#  JobDefs = "DefaultJob"\r
+#  Write Bootstrap = "@working_dir@\\Client2.bsr"\r
+#}\r
+\r
+# Backup the catalog database (after the nightly save)\r
+Job {\r
+  Name = "BackupCatalog"\r
+  JobDefs = "DefaultJob"\r
+  Level = Full\r
+  FileSet="Catalog"\r
+  Schedule = "WeeklyCycleAfterBackup"\r
+  # This creates an ASCII copy of the catalog\r
+  RunBeforeJob = "\"@bin_dir@\\make_catalog_backup\" bacula bacula"\r
+  # This deletes the copy of the catalog\r
+  RunAfterJob  = "\"@bin_dir@\\delete_catalog_backup\""\r
+  Write Bootstrap = "@working_dir@\\BackupCatalog.bsr"\r
+  Priority = 11                   # run after main backup\r
+}\r
+\r
+#\r
+# Standard Restore template, to be changed by Console program\r
+#  Only one such job is needed for all Jobs/Clients/Storage ...\r
+#\r
+Job {\r
+  Name = "RestoreFiles"\r
+  Type = Restore\r
+  Client=@client_name@\r
+  FileSet="Test Set"\r
+  Storage = File\r
+  Pool = Default\r
+  Messages = Standard\r
+  Where = "C:\\tmp\\bacula-restores"\r
+}\r
+\r
+#\r
+# Note: Windows path separators do NOT work correctly in FileSets.\r
+#\r
+# List of files to be backed up\r
+FileSet {\r
+  Name = "Test Set"\r
+  Include {\r
+    Options {\r
+      signature = MD5\r
+      ignore case = yes\r
+    }\r
+#    \r
+#  Put your list of files here, preceded by 'File =', one per line\r
+#    or include an external list with:\r
+#\r
+#    File = <file-name\r
+#\r
+#  Note: C:/ backs up everything on drive C.\r
+#    if you have other drives such as D:/\r
+#    you will probably want to add them too.\r
+#\r
+#  By default this is defined to point to the Bacula \r
+#    directory to give a reasonable FileSet to backup to\r
+#    disk storage during initial testing.\r
+#\r
+    File = "@BUILD_DIR@"\r
+  }\r
+\r
+#\r
+# If you backup the root directory, the following excluded\r
+#   files can be useful\r
+#\r
+  Exclude {\r
+    Options {\r
+      signature = MD5\r
+      ignore case = yes\r
+    }\r
+    File = C:/Temp\r
+    File = C:/tmp\r
+  }\r
+}\r
+\r
+#\r
+# This is an example which will backup all the hard drives of a Windows System.\r
+#\r
+FileSet {\r
+  Name = "Windows Full Set"\r
+  Enable VSS = yes\r
+  Include {\r
+    Options {\r
+      Signature = MD5\r
+      Exclude = yes\r
+      IgnoreCase = yes\r
+      EnhancedWild = yes\r
+      DriveType = fixed\r
+\r
+      # Exclude directories full of lots and lots of useless little files\r
+      WildDir = "[A-Z]:/Documents and Settings/*/Cookies"\r
+      WildDir = "[A-Z]:/Documents and Settings/*/Recent"\r
+      WildDir = "[A-Z]:/Documents and Settings/*/{Local Settings,LOCALS~1}/History"\r
+      WildDir = "[A-Z]:/Documents and Settings/*/{Local Settings,LOCALS~1}/Temp"\r
+      WildDir = "[A-Z]:/Documents and Settings/*/{Local Settings,LOCALS~1}/Temporary Internet Files"\r
+\r
+      # Exclude directories full of lots and lots of useless little files\r
+      WildDir = "[A-Z]:/{WINNT,Windows}/Profiles/*/Cookies"\r
+      WildDir = "[A-Z]:/{WINNT,Windows}/Profiles/*/Recent"\r
+      WildDir = "[A-Z]:/{WINNT,Windows}/Profiles/*/{Local Settings,LOCALS~1}/History"\r
+      WildDir = "[A-Z]:/{WINNT,Windows}/Profiles/*/{Local Settings,LOCALS~1}/Temp"\r
+      WildDir = "[A-Z]:/{WINNT,Windows}/Profiles/*/{Local Settings,LOCALS~1}/Temporary Internet Files"\r
+\r
+      # Exclude directories full of lots and lots of useless little files\r
+      WildDir = "[A-Z]:/{WINNT,Windows}/system32/config/systemprofile/Cookies"\r
+      WildDir = "[A-Z]:/{WINNT,Windows}/system32/config/systemprofile/Recent"\r
+      WildDir = "[A-Z]:/{WINNT,Windows}/system32/config/systemprofile/{Local Settings,LOCALS~1}/History"\r
+      WildDir = "[A-Z]:/{WINNT,Windows}/system32/config/systemprofile/{Local Settings,LOCALS~1}/Temp"\r
+      WildDir = "[A-Z]:/{WINNT,Windows}/system32/config/systemprofile/{Local Settings,LOCALS~1}/Temporary Internet Files"\r
+\r
+      # Some random bits of Windows we want to ignore\r
+      WildDir = "[A-Z]:/{WINNT,Windows}/Prefetch"\r
+      WildDir = "[A-Z]:/{WINNT,Windows}/msdownld.tmp"\r
+      WildDir = "[A-Z]:/{WINNT,Windows}/Internet Logs"\r
+      WildDir = "[A-Z]:/{WINNT,Windows}/$Nt*Uninstall*"\r
+      WildDir = "[A-Z]:/{WINNT,Windows}/Downloaded Installations"\r
+\r
+      # Temporary directories & files\r
+      WildDir = "[A-Z]:/{WINNT,Windows}/Temp"\r
+      WildDir = "[A-Z]:/Temp"\r
+      WildFile = "*.tmp"\r
+      WildDir = "[A-Z]:/tmp"\r
+\r
+      # Fast Find\r
+      WildFile = "[A-Z]:/ffastun*"\r
+\r
+      # System Restore\r
+      WildDir = "[A-Z]:/System Volume Information"\r
+\r
+      # Windows Update\r
+      WildDir = "[A-Z]:/WUTemp"\r
+\r
+      # Recycle bins\r
+      WildDir = "[A-Z]:/RECYCLE[DR]"\r
+\r
+      # Swap files\r
+      WildFile = "[A-Z]:/pagefile.sys"\r
+      WildFile = "[A-Z]:/hiberfil.sys"\r
+\r
+      # These are programs and are easier to reinstall than restore from\r
+      # backup\r
+      WildDir = "[A-Z]:/cygwin"\r
+      WildDir = "[A-Z]:/{Program Files,PROGRA~1}/Java"\r
+      WildDir = "[A-Z]:/{Program Files,PROGRA~1}/Java Web Start"\r
+      WildDir = "[A-Z]:/{Program Files,PROGRA~1}/JavaSoft"\r
+      WildDir = "[A-Z]:/{Program Files,PROGRA~1}/Microsoft Office"\r
+    }\r
+\r
+    File = "C:/"\r
+    File = "D:/"\r
+    File = "E:/"\r
+    File = "F:/"\r
+    File = "G:/"\r
+    File = "H:/"\r
+    File = "I:/"\r
+    File = "J:/"\r
+    File = "K:/"\r
+    File = "L:/"\r
+    File = "M:/"\r
+    File = "N:/"\r
+    File = "O:/"\r
+    File = "P:/"\r
+    File = "Q:/"\r
+    File = "R:/"\r
+    File = "S:/"\r
+    File = "T:/"\r
+    File = "U:/"\r
+    File = "V:/"\r
+    File = "W:/"\r
+    File = "X:/"\r
+    File = "Y:/"\r
+    File = "Z:/"\r
+  }\r
+}\r
+\r
+#\r
+# When to do the backups, full backup on first sunday of the month,\r
+#  differential (i.e. incremental since full) every other sunday,\r
+#  and incremental backups other days\r
+Schedule {\r
+  Name = "WeeklyCycle"\r
+  Run = Full 1st sun at 23:05\r
+  Run = Differential 2nd-5th sun at 23:05\r
+  Run = Incremental mon-sat at 23:05\r
+}\r
+\r
+# This schedule does the catalog. It starts after the WeeklyCycle\r
+Schedule {\r
+  Name = "WeeklyCycleAfterBackup"\r
+  Run = Full sun-sat at 23:10\r
+}\r
+\r
+# This is the backup of the catalog\r
+FileSet {\r
+  Name = "Catalog"\r
+  Include {\r
+    Options {\r
+      signature = MD5\r
+    }\r
+    File = "@working_dir@\\bacula.sql"\r
+  }\r
+}\r
+\r
+# Client (File Services) to backup\r
+Client {\r
+  Name = @client_name@\r
+  Address = @client_address@\r
+  FDPort = @client_port@\r
+  Catalog = MyCatalog\r
+  Password = "@client_password@"      # password for FileDaemon\r
+  File Retention = 30 days            # 30 days\r
+  Job Retention = 6 months            # six months\r
+  AutoPrune = yes                     # Prune expired Jobs/Files\r
+}\r
+\r
+#\r
+# Second Client (File Services) to backup\r
+#  You should change Name, Address, and Password before using\r
+#\r
+#Client {\r
+#  Name = @client_name@2\r
+#  Address = @client_address@2\r
+#  FDPort = @client_port@\r
+#  Catalog = MyCatalog\r
+#  Password = "@client_password@2"     # password for FileDaemon 2\r
+#  File Retention = 30 days            # 30 days\r
+#  Job Retention = 6 months            # six months\r
+#  AutoPrune = yes                     # Prune expired Jobs/Files\r
+#}\r
+\r
+\r
+# Definition of file storage device\r
+Storage {\r
+  Name = File\r
+# Do not use "localhost" here\r
+  Address = @storage_address@                # N.B. Use a fully qualified name here\r
+  SDPort = @storage_port@\r
+  Password = "@storage_password@"\r
+  Device = FileStorage\r
+  Media Type = File\r
+}\r
+\r
+\r
+\r
+# Definition of DDS tape storage device\r
+#Storage {\r
+#  Name = DDS-4    \r
+#  Do not use "localhost" here\r
+#  Address = @storage_address@                # N.B. Use a fully qualified name here\r
+#  SDPort = @storage_port@\r
+#  Password = "@storage_password@"          # password for Storage daemon\r
+#  Device = DDS-4                      # must be same as Device in Storage daemon\r
+#  Media Type = DDS-4                  # must be same as MediaType in Storage daemon\r
+#  Autochanger = yes                   # enable for autochanger device\r
+#}\r
+\r
+# Definition of 8mm tape storage device\r
+#Storage {\r
+#  Name = "8mmDrive"\r
+#  Do not use "localhost" here\r
+#  Address = @storage_address@                # N.B. Use a fully qualified name here\r
+#  SDPort = @storage_port@\r
+#  Password = "@storage_password@"\r
+#  Device = "Exabyte 8mm"\r
+#  MediaType = "8mm"\r
+#}\r
+\r
+\r
+# Generic catalog service\r
+Catalog {\r
+  Name = MyCatalog\r
+  dbname = bacula; user = bacula; password = ""\r
+}\r
+\r
+# Reasonable message delivery -- send most everything to email address\r
+#  and to the console\r
+Messages {\r
+  Name = Standard\r
+#\r
+# NOTE! If you send to two email or more email addresses, you will need\r
+#  to replace the %r in the from field (-f part) with a single valid\r
+#  email address in both the mailcommand and the operatorcommand.\r
+#\r
+  mailcommand = "\"@bin_dir@\\bsmtp\" -h @smtp_host@ -f \"\(Bacula\) %r\" -s \"Bacula: %t %e of %c %l\" %r"\r
+  operatorcommand = "\"@bin_dir@\\bsmtp\" -h @smtp_host@ -f \"\(Bacula\) %r\" -s \"Bacula: Intervention needed for %j\" %r"\r
+  mail = @job_email@ = all, !skipped            \r
+  operator = @job_email@ = mount\r
+  console = all, !skipped, !saved\r
+#\r
+# WARNING! the following will create a file that you must cycle from\r
+#          time to time as it will grow indefinitely. However, it will\r
+#          also keep all your messages if they scroll off the console.\r
+#\r
+  append = "@working_dir@\\log" = all, !skipped\r
+}\r
+\r
+\r
+#\r
+# Message delivery for daemon messages (no job).\r
+Messages {\r
+  Name = Daemon\r
+  mailcommand = "\"@bin_dir@\\bsmtp\" -h @smtp_host@ -f \"\(Bacula\) %r\" -s \"Bacula daemon message\" %r"\r
+  mail = @job_email@ = all, !skipped            \r
+  console = all, !skipped, !saved\r
+  append = "@working_dir@\\log" = all, !skipped\r
+}\r
+\r
+\r
+\r
+# Default pool definition\r
+Pool {\r
+  Name = Default\r
+  Pool Type = Backup\r
+  Recycle = yes                       # Bacula can automatically recycle Volumes\r
+  AutoPrune = yes                     # Prune expired volumes\r
+  Volume Retention = 365 days         # one year\r
+}\r
+\r
+# Scratch pool definition\r
+Pool {\r
+  Name = Scratch\r
+  Pool Type = Backup\r
+}\r
+\r
+#\r
+# Restricted console used by tray-monitor to get the status of the director\r
+#\r
+Console {\r
+  Name = @monitor_name@\r
+  Password = "@monitor_password@"\r
+  CommandACL = status, .status\r
+}\r
diff --git a/bacula/src/win32/newinstaller/bacula-fd.conf.in b/bacula/src/win32/newinstaller/bacula-fd.conf.in
new file mode 100644 (file)
index 0000000..5d4c7f9
--- /dev/null
@@ -0,0 +1,44 @@
+#
+# Default  Bacula File Daemon Configuration file
+#
+#  For Bacula release @VERSION@ (@DATE@) -- @DISTNAME@ @DISTVER@
+#
+# There is not much to change here except perhaps the
+# File daemon Name
+#
+
+#
+# "Global" File daemon configuration specifications
+#
+FileDaemon {                            # this is me
+  Name = @client_name@
+  FDport = @client_port@                # where we listen for the director
+  WorkingDirectory = "@working_dir@"
+  Pid Directory = "@working_dir@"
+# Plugin Directory = "@fdplugins_dir@"
+  Maximum Concurrent Jobs = @client_maxjobs@
+}
+
+#
+# List Directors who are permitted to contact this File daemon
+#
+Director {
+  Name = @director_name@
+  Password = "@client_password@"
+}
+
+#
+# Restricted Director, used by tray-monitor to get the
+#   status of the file daemon
+#
+Director {
+  Name = @monitor_name@
+  Password = "@monitor_password@"
+  Monitor = yes
+}
+
+# Send all messages except skipped files back to Director
+Messages {
+  Name = Standard
+  director = @director_name@ = all, !skipped, !restored
+}
diff --git a/bacula/src/win32/newinstaller/bacula-logo.bmp b/bacula/src/win32/newinstaller/bacula-logo.bmp
new file mode 100644 (file)
index 0000000..9a9cf97
Binary files /dev/null and b/bacula/src/win32/newinstaller/bacula-logo.bmp differ
diff --git a/bacula/src/win32/newinstaller/bacula-sd.conf.in b/bacula/src/win32/newinstaller/bacula-sd.conf.in
new file mode 100644 (file)
index 0000000..9e66212
--- /dev/null
@@ -0,0 +1,115 @@
+#\r
+# Default Bacula Storage Daemon Configuration file\r
+#\r
+#  For Bacula release @VERSION@ (@DATE@) -- @DISTNAME@ @DISTVER@\r
+#\r
+# You may need to change the name of your tape drive\r
+#   on the "Archive Device" directive in the Device\r
+#   resource.  If you change the Name and/or the \r
+#   "Media Type" in the Device resource, please ensure\r
+#   that bacula-dir.conf has corresponding changes.\r
+#\r
+\r
+Storage {                             # definition of myself\r
+  Name = @storage_name@\r
+  SDPort = @storage_port@                  # Director's port      \r
+  WorkingDirectory = "@working_dir@"\r
+  Pid Directory = "@working_dir@"\r
+  Maximum Concurrent Jobs = @storage_maxjobs@\r
+}\r
+\r
+#\r
+# List Directors who are permitted to contact Storage daemon\r
+#\r
+Director {\r
+  Name = @director_name@\r
+  Password = "@storage_password@"\r
+}\r
+\r
+#\r
+# Restricted Director, used by tray-monitor to get the\r
+#   status of the storage daemon\r
+#\r
+Director {\r
+  Name = @monitor_name@\r
+  Password = "@monitor_password@"\r
+  Monitor = yes\r
+}\r
+\r
+#\r
+# Devices supported by this Storage daemon\r
+# To connect, the Director's bacula-dir.conf must have the\r
+#  same Name and MediaType. \r
+#\r
+\r
+Device {\r
+  Name = FileStorage\r
+  Media Type = File\r
+  Archive Device = "C:\\Tmp"\r
+  LabelMedia = yes                   # lets Bacula label unlabeled media\r
+  Random Access = Yes\r
+  AutomaticMount = yes               # when device opened, read it\r
+  RemovableMedia = no\r
+  AlwaysOpen = no\r
+}\r
+\r
+#\r
+# An autochanger device with two drives\r
+#\r
+#Autochanger {\r
+#  Name = Autochanger\r
+#  Device = Drive-1\r
+#  Device = Drive-2\r
+#  Changer Command = "mtx-changer %c %o %S %a %d"\r
+#  Changer Device = Changer0\r
+#}\r
+\r
+#Device {\r
+#  Name = Drive-1                      #\r
+#  Drive Index = 0\r
+#  Media Type = DLT-8000\r
+#  Device Type = Tape\r
+#  Archive Device = Tape0\r
+#  AutomaticMount = yes               # when device opened, read it\r
+#  AlwaysOpen = yes\r
+#  RemovableMedia = yes\r
+#  RandomAccess = no\r
+#  AutoChanger = yes\r
+#  Alert Command = "tapeinfo -f %c | findstr TapeAlert"\r
+#}\r
+\r
+#Device {\r
+#  Name = Drive-2                      #\r
+#  Drive Index = 1\r
+#  Media Type = DLT-8000\r
+#  Device Type = Tape\r
+#  Archive Device = Tape1\r
+#  AutomaticMount = yes               # when device opened, read it\r
+#  AlwaysOpen = yes\r
+#  RemovableMedia = yes\r
+#  RandomAccess = no\r
+#  AutoChanger = yes\r
+#  Alert Command = "tapeinfo -f %c | findstr TapeAlert"\r
+#}\r
+\r
+#\r
+#Device {\r
+#  Name = DDS-4                        # \r
+#  Media Type = DDS-4\r
+#  Device Type = Tape\r
+#  Archive Device = Tape0\r
+#  AutomaticMount = yes               # when device opened, read it\r
+#  AlwaysOpen = yes\r
+#  RemovableMedia = yes\r
+#  RandomAccess = no\r
+#  Alert Command = "tapeinfo -f %c | findstr TapeAlert"\r
+#}\r
+\r
+# \r
+# Send all messages to the Director, \r
+# mount messages also are sent to the email address\r
+#\r
+Messages {\r
+  Name = Standard\r
+  director = @director_name@ = all\r
+}\r
diff --git a/bacula/src/win32/newinstaller/bconsole.conf.in b/bacula/src/win32/newinstaller/bconsole.conf.in
new file mode 100644 (file)
index 0000000..4f60389
--- /dev/null
@@ -0,0 +1,10 @@
+#\r
+# Bacula User Agent (or Console) Configuration File\r
+#\r
+\r
+Director {\r
+  Name = @director_name@\r
+  DIRport = @director_port@\r
+  address = @director_address@\r
+  Password = "@director_password@"\r
+}\r
diff --git a/bacula/src/win32/newinstaller/build-installer.cmd b/bacula/src/win32/newinstaller/build-installer.cmd
new file mode 100644 (file)
index 0000000..5d77a9f
--- /dev/null
@@ -0,0 +1,70 @@
+@ECHO OFF\r
+SETLOCAL\r
+\r
+SET CWD=%CD%\r
+CD %1..\..\..\r
+SET TOP_DIR=%CD%\r
+CD %CWD%\r
+SET DEPKG_DIR=%TOP_DIR%\depkgs-msvc\r
+SET DOCS_DIR=%TOP_DIR%\docs\manual\r
+\r
+SET BACULA_DLLS=bacula.dll cats_mysql.dll cats_postgresql.dll cats_sqlite3.dll\r
+SET BACULA_EXES=bacula-dir.exe bacula-fd.exe bacula-sd.exe bconsole.exe wx-console.exe\r
+SET BACULA_TOOLS=bcopy.exe bextract.exe bls.exe bscan.exe bsleep.exe bsmtp.exe btape.exe dbcheck.exe scsilist.exe\r
+\r
+SET DEP_DLLS=libeay32.dll pthreadVCE.dll ssleay32.dll zlib1.dll zlib1.dll.manifest wxbase28_vc_bacula.dll wxmsw28_core_vc_bacula.dll libmysql.dll libpq.dll comerr32.dll libintl-2.dll libiconv-2.dll krb5_32.dll\r
+SET DEP_EXES=openssl.exe loaderinfo.exe mt.exe mtx.exe scsitape.exe sed.exe tapeinfo.exe sqlite3.exe sqlite3.exe.manifest expr64.exe snooze.exe mkisofs.exe growisofs.exe dvd-ram-control.exe dvd+rw-booktype.exe dvd+rw-format.exe dvd+rw-mediainfo.exe\r
+\r
+SET SCRIPTS=mtx-changer.cmd disk-changer.cmd dvd-handler.cmd\r
+\r
+SET CATS_MYSQL_CMD=create_mysql_database.cmd drop_mysql_database.cmd make_mysql_tables.cmd drop_mysql_tables.cmd grant_mysql_privileges.cmd\r
+SET CATS_MYSQL_SQL=make_mysql_tables.sql drop_mysql_tables.sql grant_mysql_privileges.sql\r
+SET CATS_PGSQL_CMD=create_postgresql_database.cmd drop_postgresql_database.cmd make_postgresql_tables.cmd drop_postgresql_tables.cmd grant_postgresql_privileges.cmd\r
+SET CATS_PGSQL_SQL=create_postgresql_database.sql make_postgresql_tables.sql drop_postgresql_tables.sql grant_postgresql_privileges.sql\r
+SET CATS_SQLITE_CMD=create_sqlite3_database.cmd drop_sqlite3_database.cmd make_sqlite3_tables.cmd drop_sqlite3_tables.cmd grant_sqlite3_privileges.cmd\r
+SET CATS_SQLITE_SQL=make_sqlite3_tables.sql\r
+SET CATS_CATALOG=make_mysql_catalog_backup.cmd make_postgresql_catalog_backup.cmd make_sqlite3_catalog_backup.cmd delete_catalog_backup.cmd\r
+SET DIRD_FILES=query.sql\r
+SET SSL_FILES=openssl.cnf\r
+\r
+SET DOC_PDF_FILES=%DOCS_DIR%\bacula.pdf %DOCS_DIR%\bacula\*.html %DOCS_DIR%\bacula\*.png %DOCS_DIR%\bacula\*.css\r
+SET DOC_HTML_FILES=%DOCS_DIR%\bacula\*.html %DOCS_DIR%\bacula\*.png %DOCS_DIR%\bacula\*.css\r
+\r
+FOR %%i in ( %BACULA_DLLS% )     DO XCOPY %1%2\%%i %1installer\%2\ /y\r
+FOR %%i in ( %BACULA_EXES% )     DO XCOPY %1%2\%%i %1installer\%2\ /y\r
+FOR %%i in ( %BACULA_TOOLS% )    DO XCOPY %1%2\%%i %1installer\%2\ /y\r
+\r
+FOR %%i in ( %DEP_DLLS% )        DO XCOPY %DEPKG_DIR%\bin\%%i %1installer\%2\ /y\r
+FOR %%i in ( %DEP_EXES% )        DO XCOPY %DEPKG_DIR%\bin\%%i %1installer\%2\ /y\r
+\r
+FOR %%i in ( %SCRIPTS% )         DO XCOPY %1scripts\%%i %1installer\%2\ /y\r
+FOR %%i in ( %CATS_MYSQL_CMD% )  DO XCOPY %1cats\%%i %1installer\%2\ /y\r
+FOR %%i in ( %CATS_MYSQL_SQL% )  DO XCOPY %1cats\%%i %1installer\%2\ /y\r
+FOR %%i in ( %CATS_PGSQL_CMD% )  DO XCOPY %1cats\%%i %1installer\%2\ /y\r
+FOR %%i in ( %CATS_PGSQL_SQL% )  DO XCOPY %1cats\%%i %1installer\%2\ /y\r
+FOR %%i in ( %CATS_SQLITE_CMD% ) DO XCOPY %1cats\%%i %1installer\%2\ /y\r
+FOR %%i in ( %CATS_SQLITE_SQL% ) DO XCOPY %1cats\%%i %1installer\%2\ /y\r
+\r
+FOR %%i in ( %CATS_CATALOG% )    DO XCOPY %1cats\%%i %1installer\%2\ /y\r
+\r
+FOR %%i in ( %DIRD_FILES% )      DO XCOPY %1..\dird\%%i %1installer\%2\ /y\r
+FOR %%i in ( %SSL_FILES% )       DO XCOPY %DEPKG_DIR%\%%i %1installer\%2\ /y\r
+\r
+FOR %%i in ( %DOC_PDF_FILES% )   DO XCOPY %%i %1installer\%2\manual\ /y\r
+\r
+FOR %%i in ( %DOC_HTML_FILES% )  DO XCOPY %%i %1installer\%2\manual\bacula\ /y\r
+\r
+XCOPY %4\x86\Microsoft.VC80.CRT\msvcm80.dll %1installer\%2\ /y\r
+XCOPY %4\x86\Microsoft.VC80.CRT\msvcp80.dll %1installer\%2\ /y\r
+XCOPY %4\x86\Microsoft.VC80.CRT\msvcr80.dll %1installer\%2\ /y\r
+XCOPY %4\x86\Microsoft.VC80.CRT\Microsoft.VC80.CRT.manifest %1installer\%2\ /y\r
+XCOPY %4\Debug_NonRedist\x86\Microsoft.VC80.DebugCRT\msvcm80d.dll %1installer\%2\ /y\r
+XCOPY %4\Debug_NonRedist\x86\Microsoft.VC80.DebugCRT\msvcp80d.dll %1installer\%2\ /y\r
+XCOPY %4\Debug_NonRedist\x86\Microsoft.VC80.DebugCRT\msvcr80d.dll %1installer\%2\ /y\r
+XCOPY %4\Debug_NonRedist\x86\Microsoft.VC80.DebugCRT\Microsoft.VC80.DebugCRT.manifest %1installer\%2\ /y\r
+\r
+PATH %DEPKG_DIR%\nsis;%DEPKG_DIR%\tools;%PATH%\r
+\r
+FOR /F %%i IN ( 'sed -ne "s/.*[ \t]VERSION[ \t][ \t]*\x22\(.*\)\x22/\1/p" ^< ..\..\version.h' ) DO @SET VERSION=%%i \r
+makensis /V3 /DVERSION=%VERSION% /DSRC_DIR=%1installer\%2 /DOUT_DIR=%1%2 /DBUILD_TOOLS=%3 winbacula.nsi\r
+EXIT /B %ERRORLEVEL%\r
diff --git a/bacula/src/win32/newinstaller/bwx-console.conf.in b/bacula/src/win32/newinstaller/bwx-console.conf.in
new file mode 100644 (file)
index 0000000..4f60389
--- /dev/null
@@ -0,0 +1,10 @@
+#\r
+# Bacula User Agent (or Console) Configuration File\r
+#\r
+\r
+Director {\r
+  Name = @director_name@\r
+  DIRport = @director_port@\r
+  address = @director_address@\r
+  Password = "@director_password@"\r
+}\r
diff --git a/bacula/src/win32/newinstaller/client.conf.in b/bacula/src/win32/newinstaller/client.conf.in
new file mode 100644 (file)
index 0000000..5f2abe4
--- /dev/null
@@ -0,0 +1,11 @@
+# Client (File Services) to backup\r
+Client {\r
+  Name = @client_name@\r
+  Address = @client_address@\r
+  FDPort = @client_port@\r
+  Catalog = MyCatalog\r
+  Password = "@client_password@"      # password for FileDaemon\r
+  File Retention = 30 days            # 30 days\r
+  Job Retention = 6 months            # six months\r
+  AutoPrune = yes                     # Prune expired Jobs/Files\r
+}\r
diff --git a/bacula/src/win32/newinstaller/installer.vcproj b/bacula/src/win32/newinstaller/installer.vcproj
new file mode 100644 (file)
index 0000000..18ddc6e
--- /dev/null
@@ -0,0 +1,154 @@
+<?xml version="1.0" encoding="Windows-1252"?>\r
+<VisualStudioProject\r
+       ProjectType="Visual C++"\r
+       Version="8.00"\r
+       Name="installer"\r
+       ProjectGUID="{6D1B0964-FB32-4916-A61C-49D7F715EAD8}"\r
+       RootNamespace="installer"\r
+       >\r
+       <Platforms>\r
+               <Platform\r
+                       Name="Win32"\r
+               />\r
+       </Platforms>\r
+       <ToolFiles>\r
+       </ToolFiles>\r
+       <Configurations>\r
+               <Configuration\r
+                       Name="Debug|Win32"\r
+                       OutputDirectory="$(SolutionDir)$(ConfigurationName)"\r
+                       IntermediateDirectory="$(ConfigurationName)"\r
+                       ConfigurationType="0"\r
+                       >\r
+                       <Tool\r
+                               Name="VCNMakeTool"\r
+                               BuildCommandLine="build-installer $(SolutionDir) $(ConfigurationName) VC8_DEBUG &quot;$(VCInstallDir)redist&quot;&#x0D;&#x0A;"\r
+                               ReBuildCommandLine="del $(SolutionDir)$(ConfigurationName)\winbacula-*.exe&#x0D;&#x0A;build-installer $(SolutionDir) $(ConfigurationName) VC8_DEBUG &quot;$(VCInstallDir)redist&quot;&#x0D;&#x0A;"\r
+                               CleanCommandLine="del $(SolutionDir)$(ConfigurationName)\winbacula-*.exe"\r
+                               Output=""\r
+                               PreprocessorDefinitions="VERSION=$(VERSION);DOC_DIR=..\..\..\..\docs;BUILD_TOOLS=VC8_DEBUG;VC_REDIST_DIR=$(VCInstallDir)redist\Debug_NonRedist\x86\Microsoft.VC80.DebugCRT;DEPKGS_BIN=..\..\..\..\depkgs-msvc\bin;BACULA_BIN=..\$(ConfigurationName);CATS_DIR=..\cats;SCRIPT_DIR=..\scripts"\r
+                               IncludeSearchPath=""\r
+                               ForcedIncludes=""\r
+                               AssemblySearchPath=""\r
+                               ForcedUsingAssemblies=""\r
+                               CompileAsManaged=""\r
+                       />\r
+               </Configuration>\r
+               <Configuration\r
+                       Name="Release|Win32"\r
+                       OutputDirectory="$(SolutionDir)$(ConfigurationName)"\r
+                       IntermediateDirectory="$(ConfigurationName)"\r
+                       ConfigurationType="0"\r
+                       >\r
+                       <Tool\r
+                               Name="VCNMakeTool"\r
+                               BuildCommandLine="build-installer $(SolutionDir) $(ConfigurationName) VC8 &quot;$(VCInstallDir)redist&quot;&#x0D;&#x0A;"\r
+                               ReBuildCommandLine="del $(SolutionDir)$(ConfigurationName)\winbacula-*.exe&#x0D;&#x0A;build-installer $(SolutionDir) $(ConfigurationName) VC8 &quot;$(VCInstallDir)redist&quot;&#x0D;&#x0A;"\r
+                               CleanCommandLine="del $(SolutionDir)$(ConfigurationName)\winbacula-*.exe"\r
+                               Output=""\r
+                               PreprocessorDefinitions=""\r
+                               IncludeSearchPath=""\r
+                               ForcedIncludes=""\r
+                               AssemblySearchPath=""\r
+                               ForcedUsingAssemblies=""\r
+                               CompileAsManaged=""\r
+                       />\r
+               </Configuration>\r
+       </Configurations>\r
+       <References>\r
+       </References>\r
+       <Files>\r
+               <Filter\r
+                       Name="Source Files"\r
+                       Filter="cpp;c;cc;cxx;def;odl;idl;hpj;bat;asm;asmx"\r
+                       UniqueIdentifier="{4FC737F1-C7A5-4376-A066-2A32D752A2FF}"\r
+                       >\r
+               </Filter>\r
+               <Filter\r
+                       Name="Header Files"\r
+                       Filter="h;hpp;hxx;hm;inl;inc;xsd"\r
+                       UniqueIdentifier="{93995380-89BD-4b04-88EB-625FBE52EBFB}"\r
+                       >\r
+                       <File\r
+                               RelativePath=".\resource.h"\r
+                               >\r
+                       </File>\r
+               </Filter>\r
+               <Filter\r
+                       Name="Resource Files"\r
+                       Filter="rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx;tiff;tif;png;wav"\r
+                       UniqueIdentifier="{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}"\r
+                       >\r
+                       <File\r
+                               RelativePath=".\Dialogs.rc"\r
+                               >\r
+                       </File>\r
+               </Filter>\r
+               <File\r
+                       RelativePath=".\bacula-dir.conf.in"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\bacula-fd.conf.in"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\bacula-sd.conf.in"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\bconsole.conf.in"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\build-installer.cmd"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\client.conf.in"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\ConfigPage1.nsh"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\ConfigPage2.nsh"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\DumpLog.nsh"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\InstallType.ini"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\InstallType.nsh"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\Readme.txt"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\storage.conf.in"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\winbacula.nsi"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\WriteTemplates.ini"\r
+                       >\r
+               </File>\r
+               <File\r
+                       RelativePath=".\wx-console.conf.in"\r
+                       >\r
+               </File>\r
+       </Files>\r
+       <Globals>\r
+       </Globals>\r
+</VisualStudioProject>\r
diff --git a/bacula/src/win32/newinstaller/storage.conf.in b/bacula/src/win32/newinstaller/storage.conf.in
new file mode 100644 (file)
index 0000000..5928815
--- /dev/null
@@ -0,0 +1,10 @@
+# Definition of file storage device\r
+Storage {\r
+  Name = File\r
+# Do not use "localhost" here    \r
+  Address = @storage_address@                # N.B. Use a fully qualified name here\r
+  SDPort = @storage_port@\r
+  Password = "@storage_password@"\r
+  Device = FileStorage\r
+  Media Type = File\r
+}\r
diff --git a/bacula/src/win32/newinstaller/winbacula.nsi b/bacula/src/win32/newinstaller/winbacula.nsi
new file mode 100644 (file)
index 0000000..90e7ca9
--- /dev/null
@@ -0,0 +1,994 @@
+; winbsclient.nsi
+;
+; Began as a version written by Michel Meyers (michel@tcnnet.dyndns.org)
+;
+; Adapted by Kern Sibbald for native Win32 Bacula
+;    added a number of elements from Christopher Hull's installer
+;
+; D. Scott Barninger Nov 13 2004
+; added configuration editing for bconsole.conf and bwx-console.conf
+; better explanation in dialog boxes for editing config files
+; added Start Menu items
+; fix uninstall of config files to do all not just bacula-fd.conf
+;
+; D. Scott Barninger Dec 05 2004
+; added specification of default permissions for bacula-fd.conf
+;   - thanks to Jamie Ffolliott for pointing me at cacls
+; added removal of working-dir files if user selects to remove config
+; uninstall is now 100% clean
+;
+; D. Scott Barninger Apr 17 2005
+; 1.36.3 release docs update
+; add pdf manual and menu shortcut
+;
+; Robert Nelson May 15 2006
+; Added server installs and implemented Microsoft install locations
+; Use LogicLib.nsh
+; Added Bacula-SD and Bacula-DIR
+; Replaced ParameterGiven with standard GetOptions
+;
+; Kern Sibbald October 2008
+; Remove server installs
+; Install into single bacula directory
+;  (i.e. undo a large part of what Robert Nelson did)
+;
+; Version $Id: winbacula.nsi 7074 2008-05-31 18:43:21Z kerns $
+;
+; Command line options:
+;
+; /service    - 
+; /start
+;
+; netsh firewall add portopening protocol=tcp port=9102 name="Bacula-FD"
+
+
+!define PRODUCT "Bacula"
+
+;
+; Include the Modern UI
+;
+
+!include "MUI.nsh"
+!include "LogicLib.nsh"
+!include "FileFunc.nsh"
+!include "Sections.nsh"
+!include "StrFunc.nsh"
+!include "WinMessages.nsh"
+;
+; Basics
+;
+Name "Bacula"
+OutFile "${OUT_DIR}\winbaculasystems-${VERSION}.exe"
+SetCompressor lzma
+InstallDir "$PROGRAMFILES\bacula"
+
+InstallDirRegKey HKLM "Software\Bacula" "InstallLocation"
+
+InstType "Client"
+
+!insertmacro GetParent
+
+${StrCase}
+${StrRep}
+${StrTok}
+${StrTrimNewLines}
+
+;
+; Pull in pages
+;
+
+!define      MUI_COMPONENTSPAGE_SMALLDESC
+
+!define      MUI_HEADERIMAGE
+!define      MUI_BGCOLOR                739AB9
+!define      MUI_HEADERIMAGE_BITMAP     "bacula-logo.bmp"
+
+!InsertMacro MUI_PAGE_WELCOME
+!InsertMacro MUI_PAGE_LICENSE "..\..\..\LICENSE"
+Page custom EnterInstallType
+!define      MUI_PAGE_CUSTOMFUNCTION_SHOW PageComponentsShow
+!InsertMacro MUI_PAGE_COMPONENTS
+!define      MUI_PAGE_CUSTOMFUNCTION_PRE PageDirectoryPre
+!InsertMacro MUI_PAGE_DIRECTORY
+Page custom EnterConfigPage1 LeaveConfigPage1
+Page custom EnterConfigPage2 LeaveConfigPage2
+!Define      MUI_PAGE_CUSTOMFUNCTION_LEAVE LeaveInstallPage
+!InsertMacro MUI_PAGE_INSTFILES
+Page custom EnterWriteTemplates
+!Define      MUI_FINISHPAGE_SHOWREADME $INSTDIR\Readme.txt
+!InsertMacro MUI_PAGE_FINISH
+
+!InsertMacro MUI_UNPAGE_WELCOME
+!InsertMacro MUI_UNPAGE_CONFIRM
+!InsertMacro MUI_UNPAGE_INSTFILES
+!InsertMacro MUI_UNPAGE_FINISH
+
+!define      MUI_ABORTWARNING
+
+!InsertMacro MUI_LANGUAGE "English"
+
+!InsertMacro GetParameters
+!InsertMacro GetOptions
+
+DirText "Setup will install Bacula Systems ${VERSION} to the directory specified below. To install in a different folder, click Browse and select another folder."
+
+!InsertMacro MUI_RESERVEFILE_INSTALLOPTIONS
+;
+; Global Variables
+;
+Var OptService
+Var OptStart
+Var OptSilent
+
+Var CommonFilesDone
+
+Var OsIsNT
+
+Var HostName
+
+Var ConfigClientName
+Var ConfigClientPort
+Var ConfigClientMaxJobs
+Var ConfigClientPassword
+Var ConfigClientInstallService
+Var ConfigClientStartService
+
+Var ConfigStorageName
+Var ConfigStoragePort
+Var ConfigStorageMaxJobs
+Var ConfigStoragePassword
+Var ConfigStorageInstallService
+Var ConfigStorageStartService
+
+Var ConfigDirectorName
+Var ConfigDirectorPort
+Var ConfigDirectorMaxJobs
+Var ConfigDirectorPassword
+Var ConfigDirectorAddress
+Var ConfigDirectorMailServer
+Var ConfigDirectorMailAddress
+Var ConfigDirectorDB
+Var ConfigDirectorInstallService
+Var ConfigDirectorStartService
+
+Var ConfigMonitorName
+Var ConfigMonitorPassword
+
+Var LocalDirectorPassword
+Var LocalHostAddress
+
+Var MySQLPath
+Var MySQLVersion
+Var PostgreSQLPath
+Var PostgreSQLVersion
+
+Var AutomaticInstall
+Var InstallType
+
+!define NewInstall      0
+!define UpgradeInstall  1
+!define MigrateInstall  2
+
+Var OldInstallDir
+Var PreviousComponents
+Var NewComponents
+
+; Bit 0 = File Service
+;     1 = Storage Service
+;     2 = Director Service
+;     3 = Command Console
+;     4 = Graphical Console
+;     5 = Documentation (PDF)
+;     6 = Documentation (HTML)
+
+!define ComponentFile                   1
+!define ComponentStorage                2
+!define ComponentDirector               4
+!define ComponentTextConsole            8
+!define ComponentGUIConsole             16
+!define ComponentPDFDocs                32
+!define ComponentHTMLDocs               64
+
+!define ComponentsRequiringUserConfig           31
+!define ComponentsFileAndStorage                3
+!define ComponentsFileAndStorageAndDirector     7
+!define ComponentsDirectorAndTextGuiConsoles    28
+!define ComponentsTextAndGuiConsoles            24
+
+Var HDLG
+Var HCTL
+
+Function .onInit
+  Push $R0
+  Push $R1
+
+  ; Process Command Line Options
+  StrCpy $OptService 1
+  StrCpy $OptStart 1
+  StrCpy $OptSilent 0
+  StrCpy $CommonFilesDone 0
+  StrCpy $OsIsNT 0
+  StrCpy $AutomaticInstall 0
+  StrCpy $InstallType ${NewInstall}
+  StrCpy $OldInstallDir ""
+  StrCpy $PreviousComponents 0
+  StrCpy $NewComponents 0
+  StrCpy $MySQLPath ""
+  StrCpy $MySQLVersion ""
+  StrCpy $PostgreSQLPath ""
+  StrCpy $PostgreSQLVersion ""
+  StrCpy $LocalDirectorPassword ""
+
+  ${GetParameters} $R0
+
+  ClearErrors
+  ${GetOptions} $R0 "/noservice" $R1
+  IfErrors +2
+    StrCpy $OptService 0
+
+  ClearErrors
+  ${GetOptions} $R0 "/nostart" $R1
+  IfErrors +2
+    StrCpy $OptStart 0
+
+  IfSilent 0 +2
+    StrCpy $OptSilent 1
+
+  ReadRegStr $R0 HKLM "SOFTWARE\Microsoft\Windows NT\CurrentVersion" CurrentVersion
+  ${If} $R0 != ""
+    StrCpy $OsIsNT 1
+  ${EndIf}
+
+  Call GetComputerName
+  Pop $HostName
+
+  Call GetHostName
+  Pop $LocalHostAddress
+
+  Call GetUserName
+
+  ; Configuration Defaults
+
+  StrCpy $ConfigClientName               "$HostName-fd"
+  StrCpy $ConfigClientPort               9102
+  StrCpy $ConfigClientMaxJobs            2
+  ;StrCpy $ConfigClientPassword
+  StrCpy $ConfigClientInstallService     "$OptService"
+  StrCpy $ConfigClientStartService       "$OptStart"
+
+
+  StrCpy $ConfigMonitorName              "$HostName-mon"
+  ;StrCpy $ConfigMonitorPassword
+
+  InitPluginsDir
+  File "/oname=$PLUGINSDIR\openssl.exe"  "${SRC_DIR}\openssl.exe"
+  File "/oname=$PLUGINSDIR\libeay32.dll" "${SRC_DIR}\libeay32.dll"
+  File "/oname=$PLUGINSDIR\ssleay32.dll" "${SRC_DIR}\ssleay32.dll"
+  File "/oname=$PLUGINSDIR\sed.exe"      "${SRC_DIR}\sed.exe"
+
+  !InsertMacro MUI_INSTALLOPTIONS_EXTRACT "InstallType.ini"
+  !InsertMacro MUI_INSTALLOPTIONS_EXTRACT "WriteTemplates.ini"
+
+  SetPluginUnload alwaysoff
+
+  nsExec::Exec '"$PLUGINSDIR\openssl.exe" rand -base64 -out $PLUGINSDIR\pw.txt 33'
+  pop $R0
+  ${If} $R0 = 0
+   FileOpen $R1 "$PLUGINSDIR\pw.txt" r
+   IfErrors +4
+     FileRead $R1 $R0
+     ${StrTrimNewLines} $ConfigClientPassword $R0
+     FileClose $R1
+  ${EndIf}
+
+  SetPluginUnload manual
+
+  nsExec::Exec '"$PLUGINSDIR\openssl.exe" rand -base64 -out $PLUGINSDIR\pw.txt 33'
+  pop $R0
+  ${If} $R0 = 0
+   FileOpen $R1 "$PLUGINSDIR\pw.txt" r
+   IfErrors +4
+     FileRead $R1 $R0
+     ${StrTrimNewLines} $ConfigMonitorPassword $R0
+     FileClose $R1
+  ${EndIf}
+
+  Pop $R1
+  Pop $R0
+FunctionEnd
+
+Function .onSelChange
+  Call UpdateComponentUI
+FunctionEnd
+
+Function InstallCommonFiles
+  ${If} $CommonFilesDone = 0
+    SetOutPath "$INSTDIR"
+    File "Readme.txt"
+
+    SetOutPath "$INSTDIR"
+!if "${BUILD_TOOLS}" == "VC8"
+    File "${SRC_DIR}\msvcm80.dll"
+    File "${SRC_DIR}\msvcp80.dll"
+    File "${SRC_DIR}\msvcr80.dll"
+    File "${SRC_DIR}\Microsoft.VC80.CRT.manifest"
+    File "${SRC_DIR}\pthreadVCE.dll"
+!endif
+!if "${BUILD_TOOLS}" == "VC8_DEBUG"
+    File "${SRC_DIR}\msvcm80.dll"
+    File "${SRC_DIR}\msvcp80.dll"
+    File "${SRC_DIR}\msvcr80.dll"
+    File "${SRC_DIR}\Microsoft.VC80.CRT.manifest"
+    File "${SRC_DIR}\msvcm80d.dll"
+    File "${SRC_DIR}\msvcp80d.dll"
+    File "${SRC_DIR}\msvcr80d.dll"
+    File "${SRC_DIR}\Microsoft.VC80.DebugCRT.manifest"
+    File "${SRC_DIR}\pthreadVCE.dll"
+!endif
+!if "${BUILD_TOOLS}" == "MinGW"
+    File "${SRC_DIR}\mingwm10.dll"
+    File "${SRC_DIR}\pthreadGCE.dll"
+!endif
+    File "${SRC_DIR}\libeay32.dll"
+    File "${SRC_DIR}\ssleay32.dll"
+    File "${SRC_DIR}\zlib1.dll"
+!if "${BUILD_TOOLS}" == "VC8"
+    File "${SRC_DIR}\zlib1.dll.manifest"
+!endif
+!If "${BUILD_TOOLS}" == "VC8_DEBUG"
+    File "${SRC_DIR}\zlib1.dll.manifest"
+!endif
+    File "/oname=$INSTDIR\openssl.cnf" "${SRC_DIR}\openssl.cnf"
+    File "${SRC_DIR}\openssl.exe"
+    File "${SRC_DIR}\bsleep.exe"
+    File "${SRC_DIR}\bsmtp.exe"
+    File "${SRC_DIR}\bacula.dll"
+    File "${SRC_DIR}\expr64.exe"
+    File "${SRC_DIR}\snooze.exe"
+
+    CreateShortCut "$SMPROGRAMS\Bacula\Documentation\View Readme.lnk" "write.exe" '"$INSTDIR\Readme.txt"'
+
+    StrCpy $CommonFilesDone 1
+  ${EndIf}
+FunctionEnd
+
+Section "-Initialize"
+
+  WriteRegStr   HKLM Software\Bacula InstallLocation "$INSTDIR"
+
+  Call GetSelectedComponents
+  Pop $R2
+  WriteRegDWORD HKLM Software\Bacula Components $R2
+
+  ; remove start menu items
+  SetShellVarContext all
+
+  Delete /REBOOTOK "$SMPROGRAMS\Bacula\Configuration\*"
+  Delete /REBOOTOK "$SMPROGRAMS\Bacula\Documentation\*"
+  Delete /REBOOTOK "$SMPROGRAMS\Bacula\*"
+  RMDir "$SMPROGRAMS\Bacula\Configuration"
+  RMDir "$SMPROGRAMS\Bacula\Documentation"
+  RMDir "$SMPROGRAMS\Bacula"
+  CreateDirectory "$SMPROGRAMS\Bacula"
+  CreateDirectory "$SMPROGRAMS\Bacula\Configuration"
+  CreateDirectory "$SMPROGRAMS\Bacula\Documentation"
+
+  CreateDirectory "$INSTDIR"
+  CreateDirectory "$INSTDIR\working"
+
+  SetOutPath "$INSTDIR"
+  File "..\..\..\LICENSE"
+  Delete /REBOOTOK "$INSTDIR\License.txt"
+
+  FileOpen $R1 $PLUGINSDIR\config.sed w
+  FileWrite $R1 "s;@VERSION@;${VERSION};g$\r$\n"
+  FileWrite $R1 "s;@DATE@;${__DATE__};g$\r$\n"
+  FileWrite $R1 "s;@DISTNAME@;Windows;g$\r$\n"
+
+!If "$BUILD_TOOLS" == "MinGW"
+  StrCpy $R2 "MinGW32"
+!Else
+  StrCpy $R2 "MVS"
+!EndIf
+
+  Call GetHostName
+  Exch $R3
+  Pop $R3
+
+  FileWrite $R1 "s;@DISTVER@;$R2;g$\r$\n"
+
+  ${StrRep} $R2 "$INSTDIR\working" "\" "\\\\"
+  FileWrite $R1 's;@working_dir@;$R2;g$\r$\n'
+  ${StrRep} $R2 "$INSTDIR\working" "\" "\\"
+  FileWrite $R1 's;@working_dir_cmd@;$R2;g$\r$\n'
+
+  ${StrRep} $R2 "$INSTDIR" "\" "\\\\"
+  FileWrite $R1 's;@bin_dir@;$R2;g$\r$\n'
+  ${StrRep} $R2 "$INSTDIR" "\" "\\"
+  FileWrite $R1 's;@bin_dir_cmd@;$R2;g$\r$\n'
+
+  ${StrRep} $R2 "$INSTDIR\plugins" "\" "\\\\"
+  FileWrite $R1 's;@fdplugins_dir@;$R2;g$\r$\n'
+
+  ${StrRep} $R2 "$INSTDIR" "\" "/"
+  FileWrite $R1 "s;@BUILD_DIR@;$R2;g$\r$\n"
+
+  FileWrite $R1 "s;@client_address@;$LocalHostAddress;g$\r$\n"
+
+  ${If} "$ConfigClientName" != ""
+    FileWrite $R1 "s;@client_name@;$ConfigClientName;g$\r$\n"
+  ${EndIf}
+  ${If} "$ConfigClientPort" != ""
+    FileWrite $R1 "s;@client_port@;$ConfigClientPort;g$\r$\n"
+  ${EndIf}
+  ${If} "$ConfigClientMaxJobs" != ""
+    FileWrite $R1 "s;@client_maxjobs@;$ConfigClientMaxJobs;g$\r$\n"
+  ${EndIf}
+  ${If} "$ConfigClientPassword" != ""
+    FileWrite $R1 "s;@client_password@;$ConfigClientPassword;g$\r$\n"
+  ${EndIf}
+  ${If} "$ConfigMonitorName" != ""
+    FileWrite $R1 "s;@monitor_name@;$ConfigMonitorName;g$\r$\n"
+  ${EndIf}
+  ${If} "$ConfigMonitorPassword" != ""
+    FileWrite $R1 "s;@monitor_password@;$ConfigMonitorPassword;g$\r$\n"
+  ${EndIf}
+
+  FileClose $R1
+
+
+  ${If} ${FileExists} "$OldInstallDir\bin\bacula-fd.exe"
+    nsExec::ExecToLog '"$OldInstallDir\bin\bacula-fd.exe" /kill'     ; Shutdown any bacula that could be running
+    Sleep 3000
+    nsExec::ExecToLog '"$OldInstallDir\bin\bacula-fd.exe" /remove'   ; Remove existing service
+  ${EndIf}
+
+  ${If} ${FileExists} "$OldInstallDir\bin\bacula-sd.exe"
+    nsExec::ExecToLog '"$OldInstallDir\bin\bacula-sd.exe" /kill'     ; Shutdown any bacula that could be running
+    Sleep 3000
+    nsExec::ExecToLog '"$OldInstallDir\bin\bacula-sd.exe" /remove'   ; Remove existing service
+  ${EndIf}
+
+  ${If} ${FileExists} "$OldInstallDir\bin\bacula-dir.exe"
+    nsExec::ExecToLog '"$OldInstallDir\bin\bacula-dir.exe" /kill'     ; Shutdown any bacula that could be running
+    Sleep 3000
+    nsExec::ExecToLog '"$OldInstallDir\bin\bacula-dir.exe" /remove'   ; Remove existing service
+  ${EndIf}
+
+SectionEnd
+
+SectionGroup "Client" SecGroupClient
+
+Section "File Service" SecFileDaemon
+  SectionIn 1 2 3
+
+  SetOutPath "$INSTDIR\plugins"
+  File "${SRC_DIR}\exchange-fd.dll"
+
+  SetOutPath "$INSTDIR"
+
+  File "${SRC_DIR}\bacula-fd.exe"
+
+    File "/oname=$PLUGINSDIR\bacula-fd.conf" "bacula-fd.conf.in"
+
+    StrCpy $0 "$INSTDIR"
+    StrCpy $1 bacula-fd.conf
+    Call ConfigEditAndCopy
+
+  StrCpy $0 bacula-fd
+  StrCpy $1 "File Service"
+  StrCpy $2 $ConfigClientInstallService
+  StrCpy $3 $ConfigClientStartService
+
+  Call InstallDaemon
+
+  CreateShortCut "$SMPROGRAMS\Bacula\Configuration\Edit Client Configuration.lnk" "write.exe" '"$INSTDIR\bacula-fd.conf"'
+SectionEnd
+
+SectionGroupEnd
+
+
+SectionGroup "Consoles" SecGroupConsoles
+
+Section "Command Console" SecConsole
+  SectionIn 1 2 3
+
+  SetOutPath "$INSTDIR"
+
+  File "${SRC_DIR}\bconsole.exe"
+  Call InstallCommonFiles
+
+  CreateShortCut "$SMPROGRAMS\Bacula\bconsole.lnk" "$INSTDIR\bconsole.exe" '-c "$INSTDIR\bconsole.conf"' "$INSTDIR\bconsole.exe" 0
+  CreateShortCut "$SMPROGRAMS\Bacula\Configuration\Edit Command Console Configuration.lnk" "write.exe" '"$INSTDIR\bconsole.conf"'
+
+SectionEnd
+
+Section "Graphical Console" SecWxConsole
+  SectionIn 1 2 3
+  
+  SetOutPath "$INSTDIR"
+
+  Call InstallCommonFiles
+!if "${BUILD_TOOLS}" == "VC8"
+  File "${SRC_DIR}\wxbase28_vc_bacula.dll"
+  File "${SRC_DIR}\wxmsw28_core_vc_bacula.dll"
+!endif
+!If "${BUILD_TOOLS}" == "VC8_DEBUG"
+  File "${SRC_DIR}\wxbase28_vc_bacula.dll"
+  File "${SRC_DIR}\wxmsw28_core_vc_bacula.dll"
+!endif
+!if "${BUILD_TOOLS}" == "MinGW"
+  File "${SRC_DIR}\wxbase28_gcc_bacula.dll"
+  File "${SRC_DIR}\wxmsw28_core_gcc_bacula.dll"
+!endif
+
+  File "${SRC_DIR}\bwx-console.exe"
+
+    File "/oname=$PLUGINSDIR\bwx-console.conf" "bwx-console.conf.in"
+    StrCpy $0 "$INSTDIR"
+    StrCpy $1 bwx-console.conf
+    Call ConfigEditAndCopy
+
+  ; Create Start Menu entry
+  CreateShortCut "$SMPROGRAMS\Bacula\bwx-console.lnk" "$INSTDIR\bwx-console.exe" '-c "$INSTDIR\bwx-console.conf"' "$INSTDIR\bwx-console.exe" 0
+  CreateShortCut "$SMPROGRAMS\Bacula\Configuration\Edit Graphical Console Configuration.lnk" "write.exe" '"$INSTDIR\bwx-console.conf"'
+SectionEnd
+
+SectionGroupEnd
+
+SectionGroup "Documentation" SecGroupDocumentation
+
+Section "Documentation (Acrobat Format)" SecDocPdf
+  SectionIn 1 2 3
+
+  SetOutPath "$INSTDIR\doc"
+  CreateDirectory "$INSTDIR\doc"
+
+  File "${SRC_DIR}\manual\bacula.pdf"
+  CreateShortCut "$SMPROGRAMS\Bacula\Documentation\Manual.lnk" '"$INSTDIR\doc\bacula.pdf"'
+SectionEnd
+
+Section "Documentation (HTML Format)" SecDocHtml
+  SectionIn 3
+
+  SetOutPath "$INSTDIR\doc"
+  CreateDirectory "$INSTDIR\doc"
+
+  File "${SRC_DIR}\manual\bacula\*.html"
+  File "${SRC_DIR}\manual\bacula\*.png"
+  File "${SRC_DIR}\manual\bacula\*.css"
+  CreateShortCut "$SMPROGRAMS\Bacula\Documentation\Manual (HTML).lnk" '"$INSTDIR\doc\index.html"'
+SectionEnd
+
+SectionGroupEnd
+
+Section "-Finish"
+  Push $R0
+
+  ${If} $OsIsNT = 1
+    nsExec::ExecToLog 'cmd.exe /C echo Y|cacls "$INSTDIR" /T /G SYSTEM:F Administrators:F'
+    nsExec::ExecToLog 'cmd.exe /C echo Y|cacls "$INSTDIR" /T /G SYSTEM:F Administrators:F'
+  ${EndIf}
+
+  ; Write the uninstall keys for Windows & create Start Menu entry
+  WriteRegStr   HKLM "Software\Microsoft\Windows\CurrentVersion\Uninstall\Bacula" "DisplayName" "Bacula"
+  WriteRegStr   HKLM "Software\Microsoft\Windows\CurrentVersion\Uninstall\Bacula" "InstallLocation" "$INSTDIR"
+  WriteRegStr   HKLM "Software\Microsoft\Windows\CurrentVersion\Uninstall\Bacula" "DisplayVersion" "${VERSION}"
+  ${StrTok} $R0 "${VERSION}" "." 0 0
+  WriteRegDWORD HKLM "Software\Microsoft\Windows\CurrentVersion\Uninstall\Bacula" "VersionMajor" $R0
+  ${StrTok} $R0 "${VERSION}" "." 1 0
+  WriteRegDWORD HKLM "Software\Microsoft\Windows\CurrentVersion\Uninstall\Bacula" "VersionMinor" $R0
+  WriteRegDWORD HKLM "Software\Microsoft\Windows\CurrentVersion\Uninstall\Bacula" "NoModify" 1
+  WriteRegDWORD HKLM "Software\Microsoft\Windows\CurrentVersion\Uninstall\Bacula" "NoRepair" 1
+  WriteRegStr   HKLM "Software\Microsoft\Windows\CurrentVersion\Uninstall\Bacula" "URLUpdateInfo" "http://sourceforge.net/project/showfiles.php?group_id=50727"
+  WriteRegStr   HKLM "Software\Microsoft\Windows\CurrentVersion\Uninstall\Bacula" "URLInfoAbout" "http://www.bacula.org"
+  WriteRegStr   HKLM "Software\Microsoft\Windows\CurrentVersion\Uninstall\Bacula" "HelpLink" "http://www.bacula.org/?page=support"
+  WriteRegStr   HKLM "Software\Microsoft\Windows\CurrentVersion\Uninstall\Bacula" "UninstallString" '"$INSTDIR\uninstall.exe"'
+  WriteUninstaller "$INSTDIR\Uninstall.exe"
+  CreateShortCut "$SMPROGRAMS\Bacula\Uninstall Bacula.lnk" "$INSTDIR\Uninstall.exe" "" "$INSTDIR\Uninstall.exe" 0
+  Pop $R0
+SectionEnd
+
+; Extra Page descriptions
+
+LangString DESC_SecFileDaemon ${LANG_ENGLISH} "Install Bacula File Daemon on this system."
+LangString DESC_SecConsole ${LANG_ENGLISH} "Install command console program on this system."
+LangString DESC_SecWxConsole ${LANG_ENGLISH} "Install graphical console program on this system."
+LangString DESC_SecDocPdf ${LANG_ENGLISH} "Install documentation in Acrobat format on this system."
+LangString DESC_SecDocHtml ${LANG_ENGLISH} "Install documentation in HTML format on this system."
+
+LangString TITLE_ConfigPage1 ${LANG_ENGLISH} "Configuration"
+LangString SUBTITLE_ConfigPage1 ${LANG_ENGLISH} "Set installation configuration."
+
+LangString TITLE_ConfigPage2 ${LANG_ENGLISH} "Configuration (continued)"
+LangString SUBTITLE_ConfigPage2 ${LANG_ENGLISH} "Set installation configuration."
+
+LangString TITLE_InstallType ${LANG_ENGLISH} "Installation Type"
+LangString SUBTITLE_InstallType ${LANG_ENGLISH} "Choose installation type."
+
+LangString TITLE_WriteTemplates ${LANG_ENGLISH} "Create Templates"
+LangString SUBTITLE_WriteTemplates ${LANG_ENGLISH} "Create resource templates for inclusion in the Director's configuration file."
+
+!InsertMacro MUI_FUNCTION_DESCRIPTION_BEGIN
+  !InsertMacro MUI_DESCRIPTION_TEXT ${SecFileDaemon} $(DESC_SecFileDaemon)
+  !InsertMacro MUI_DESCRIPTION_TEXT ${SecConsole} $(DESC_SecConsole)
+  !InsertMacro MUI_DESCRIPTION_TEXT ${SecWxConsole} $(DESC_SecWxConsole)
+  !InsertMacro MUI_DESCRIPTION_TEXT ${SecDocPdf} $(DESC_SecDocPdf)
+  !InsertMacro MUI_DESCRIPTION_TEXT ${SecDocHtml} $(DESC_SecDocHtml)
+!InsertMacro MUI_FUNCTION_DESCRIPTION_END
+
+; Uninstall section
+
+UninstallText "This will uninstall Bacula. Hit next to continue."
+
+Section "Uninstall"
+  ; Shutdown any baculum that could be running
+  nsExec::ExecToLog '"$INSTDIR\bacula-fd.exe" /kill'
+  Sleep 3000
+
+  ReadRegDWORD $R0 HKLM "Software\Bacula" "Service_Bacula-fd"
+  ${If} $R0 = 1
+    ; Remove bacula service
+    nsExec::ExecToLog '"$INSTDIR\bacula-fd.exe" /remove'
+    nsExec::ExecToLog '"$INSTDIR\plugins\exchange-fd.dll" /remove'
+  ${EndIf}
+  
+  ; remove registry keys
+  DeleteRegKey HKLM "Software\Microsoft\Windows\CurrentVersion\Uninstall\Bacula"
+  DeleteRegKey HKLM "Software\Bacula"
+
+  ; remove start menu items
+  SetShellVarContext all
+  Delete /REBOOTOK "$SMPROGRAMS\Bacula\*"
+  RMDir "$SMPROGRAMS\Bacula"
+
+  ; remove files and uninstaller (preserving config for now)
+  Delete /REBOOTOK "$INSTDIR\doc\*"
+  Delete /REBOOTOK "$INSTDIR\*"
+
+  ; Check for existing installation
+  MessageBox MB_YESNO|MB_ICONQUESTION \
+  "Would you like to delete the current configuration files and the working state file?" IDNO NoDel
+    Delete /REBOOTOK "$INSTDIR\*"
+    Delete /REBOOTOK "$INSTDIR\working\*"
+    Delete /REBOOTOK "$PLUGINSDIR\bacula-*.conf"
+    Delete /REBOOTOK "$PLUGINSDIR\*console.conf"
+    Delete /REBOOTOK "$PLUGINSDIR\*conf.in"
+    Delete /REBOOTOK "$PLUGINSDIR\openssl.exe"
+    Delete /REBOOTOK "$PLUGINSDIR\libeay32.dll"
+    Delete /REBOOTOK "$PLUGINSDIR\ssleay32.dll"
+    Delete /REBOOTOK "$PLUGINSDIR\sed.exe"    
+    Delete /REBOOTOK "$PLUGINSDIR\pw.txt"     
+    Delete /REBOOTOK "$PLUGINSDIR\*.sed" 
+    Delete /REBOOTOK "$PLUGINSDIR\*.cmd"    
+    Delete /REBOOTOK "$PLUGINSDIR\*.sql"    
+    RMDir "$INSTDIR\working"
+    RMDir "$INSTDIR"
+NoDel:
+
+  ; remove directories used
+  RMDir "$INSTDIR\doc"
+  RMDir "$INSTDIR"
+SectionEnd
+
+;
+; $0 - Service Name (ie Bacula-FD)
+; $1 - Service Description (ie Bacula File Daemon)
+; $2 - Install as Service
+; $3 - Start Service now
+;
+Function InstallDaemon
+  Call InstallCommonFiles
+
+  WriteRegDWORD HKLM "Software\Bacula" "Service_$0" $2
+  
+  ${If} $2 = 1
+    nsExec::ExecToLog '"$INSTDIR\$0.exe" /install -c "$INSTDIR\$0.conf"'
+
+    ${If} $OsIsNT <> 1
+      File "Start.bat"
+      File "Stop.bat"
+    ${EndIf}
+
+    ; Start the service?
+
+    ${If} $3 = 1  
+      ${If} $OsIsNT = 1
+        nsExec::ExecToLog 'net start $0'
+      ${Else}
+        Exec '"$INSTDIR\$0.exe" -c "$INSTDIR\$0.conf"'
+      ${EndIf}
+    ${EndIf}
+  ${Else}
+    CreateShortCut "$SMPROGRAMS\Bacula\Start $1.lnk" "$INSTDIR\$0.exe" '-c "$INSTDIR\$0.conf"' "$INSTDIR\$0.exe" 0
+  ${EndIf}
+FunctionEnd
+
+Function GetComputerName
+  Push $R0
+  Push $R1
+  Push $R2
+
+  System::Call "kernel32::GetComputerNameA(t .R0, *i ${NSIS_MAX_STRLEN} R1) i.R2"
+
+  ${StrCase} $R0 $R0 "L"
+
+  Pop $R2
+  Pop $R1
+  Exch $R0
+FunctionEnd
+
+!define ComputerNameDnsFullyQualified   3
+
+Function GetHostName
+  Push $R0
+  Push $R1
+  Push $R2
+
+  ${If} $OsIsNT = 1
+    System::Call "kernel32::GetComputerNameExA(i ${ComputerNameDnsFullyQualified}, t .R0, *i ${NSIS_MAX_STRLEN} R1) i.R2 ?e"
+    ${If} $R2 = 0
+      Pop $R2
+      DetailPrint "GetComputerNameExA failed - LastError = $R2"
+      Call GetComputerName
+      Pop $R0
+    ${Else}
+      Pop $R2
+    ${EndIf}
+  ${Else}
+    Call GetComputerName
+    Pop $R0
+  ${EndIf}
+
+  Pop $R2
+  Pop $R1
+  Exch $R0
+FunctionEnd
+
+!define NameUserPrincipal 8
+
+Function GetUserName
+  Push $R0
+  Push $R1
+  Push $R2
+
+  ${If} $OsIsNT = 1
+    System::Call "secur32::GetUserNameExA(i ${NameUserPrincipal}, t .R0, *i ${NSIS_MAX_STRLEN} R1) i.R2 ?e"
+    ${If} $R2 = 0
+      Pop $R2
+      DetailPrint "GetUserNameExA failed - LastError = $R2"
+      Pop $R0
+      StrCpy $R0 ""
+    ${Else}
+      Pop $R2
+    ${EndIf}
+  ${Else}
+      StrCpy $R0 ""
+  ${EndIf}
+
+  ${If} $R0 == ""
+    System::Call "advapi32::GetUserNameA(t .R0, *i ${NSIS_MAX_STRLEN} R1) i.R2 ?e"
+    ${If} $R2 = 0
+      Pop $R2
+      DetailPrint "GetUserNameA failed - LastError = $R2"
+      StrCpy $R0 ""
+    ${Else}
+      Pop $R2
+    ${EndIf}
+  ${EndIf}
+
+  Pop $R2
+  Pop $R1
+  Exch $R0
+FunctionEnd
+
+Function ConfigEditAndCopy
+  Push $R1
+
+  ${If} ${FileExists} "$0\$1"
+    StrCpy $R1 ".new"
+  ${Else}
+    StrCpy $R1 ""
+  ${EndIf}
+
+  nsExec::ExecToLog '$PLUGINSDIR\sed.exe -f "$PLUGINSDIR\config.sed" -i.bak "$PLUGINSDIR\$1"'
+  CopyFiles "$PLUGINSDIR\$1" "$0\$1$R1"
+
+  Pop $R1
+FunctionEnd
+
+Function GetSelectedComponents
+  Push $R0
+  StrCpy $R0 0
+  ${If} ${SectionIsSelected} ${SecFileDaemon}
+    IntOp $R0 $R0 | ${ComponentFile}
+  ${EndIf}
+  ${If} ${SectionIsSelected} ${SecConsole}
+    IntOp $R0 $R0 | ${ComponentTextConsole}
+  ${EndIf}
+  ${If} ${SectionIsSelected} ${SecWxConsole}
+    IntOp $R0 $R0 | ${ComponentGUIConsole}
+  ${EndIf}
+  ${If} ${SectionIsSelected} ${SecDocPdf}
+    IntOp $R0 $R0 | ${ComponentPDFDocs}
+  ${EndIf}
+  ${If} ${SectionIsSelected} ${SecDocHtml}
+    IntOp $R0 $R0 | ${ComponentHTMLDocs}
+  ${EndIf}
+  Exch $R0
+FunctionEnd
+
+Function PageComponentsShow
+
+  Call SelectPreviousComponents
+  Call UpdateComponentUI
+FunctionEnd
+
+Function PageDirectoryPre
+  ${If} $AutomaticInstall = 1
+  ${OrIf} $InstallType = ${UpgradeInstall}
+    Abort
+  ${EndIf}
+FunctionEnd
+
+Function LeaveInstallPage
+  Push "$INSTDIR\install.log"
+  Call DumpLog
+FunctionEnd
+
+Function EnterWriteTemplates
+  Push $R0
+  Push $R1
+
+  Call GetSelectedComponents
+  Pop $R0
+
+  IntOp $R0 $R0 & ${ComponentDirector}
+  IntOp $R1 $NewComponents & ${ComponentsFileAndStorage}
+
+  ${If} $R0 <> 0
+  ${OrIf} $R1 = 0
+    Pop $R1
+    Pop $R0
+    Abort
+  ${EndIf}
+
+  IntOp $R0 $NewComponents & ${ComponentFile}
+  ${If} $R0 = 0
+    WriteINIStr "$PLUGINSDIR\WriteTemplates.ini" "Field 2" State 0
+    WriteINIStr "$PLUGINSDIR\WriteTemplates.ini" "Field 2" Flags DISABLED
+    DeleteINIStr "$PLUGINSDIR\WriteTemplates.ini" "Field 3" State
+    WriteINIStr "$PLUGINSDIR\WriteTemplates.ini" "Field 3" Flags REQ_SAVE|FILE_EXPLORER|WARN_IF_EXIST|DISABLED
+  ${Else}
+    WriteINIStr "$PLUGINSDIR\WriteTemplates.ini" "Field 2" State 1
+    DeleteINIStr "$PLUGINSDIR\WriteTemplates.ini" "Field 2" Flags
+    WriteINIStr "$PLUGINSDIR\WriteTemplates.ini" "Field 3" State "C:\$ConfigClientName.conf"
+    WriteINIStr "$PLUGINSDIR\WriteTemplates.ini" "Field 5" Flags REQ_SAVE|FILE_EXPLORER|WARN_IF_EXIST
+  ${EndIf}
+
+
+  !InsertMacro MUI_HEADER_TEXT "$(TITLE_WriteTemplates)" "$(SUBTITLE_WriteTemplates)"
+  !InsertMacro MUI_INSTALLOPTIONS_DISPLAY "WriteTemplates.ini"
+
+  !InsertMacro MUI_INSTALLOPTIONS_READ $R0 "WriteTemplates.ini" "Field 2" State
+  ${If} $R0 <> 0
+    File "/oname=$PLUGINSDIR\client.conf.in" "client.conf.in"
+
+    nsExec::ExecToLog '$PLUGINSDIR\sed.exe -f "$PLUGINSDIR\config.sed" -i.bak "$PLUGINSDIR\client.conf.in"'
+    !InsertMacro MUI_INSTALLOPTIONS_READ $R0 "WriteTemplates.ini" "Field 3" State
+    ${If} $R0 != ""
+      CopyFiles "$PLUGINSDIR\client.conf.in" "$R0"
+    ${EndIf}
+  ${EndIf}
+
+
+  Pop $R1
+  Pop $R0
+FunctionEnd
+
+Function SelectPreviousComponents
+  ${If} $InstallType <> ${NewInstall}
+    IntOp $R1 $PreviousComponents & ${ComponentFile}
+    ${If} $R1 <> 0
+      !InsertMacro SelectSection ${SecFileDaemon}
+      !InsertMacro SetSectionFlag ${SecFileDaemon} ${SF_RO}
+    ${Else}
+      !InsertMacro UnselectSection ${SecFileDaemon}
+      !InsertMacro ClearSectionFlag ${SecFileDaemon} ${SF_RO}
+    ${EndIf}
+    IntOp $R1 $PreviousComponents & ${ComponentTextConsole}
+    ${If} $R1 <> 0
+      !InsertMacro SelectSection ${SecConsole}
+      !InsertMacro SetSectionFlag ${SecConsole} ${SF_RO}
+    ${Else}
+      !InsertMacro UnselectSection ${SecConsole}
+      !InsertMacro ClearSectionFlag ${SecConsole} ${SF_RO}
+    ${EndIf}
+    IntOp $R1 $PreviousComponents & ${ComponentGUIConsole}
+    ${If} $R1 <> 0
+      !InsertMacro SelectSection ${SecWxConsole}
+      !InsertMacro SetSectionFlag ${SecWxConsole} ${SF_RO}
+    ${Else}
+      !InsertMacro UnselectSection ${SecWxConsole}
+      !InsertMacro ClearSectionFlag ${SecWxConsole} ${SF_RO}
+    ${EndIf}
+    IntOp $R1 $PreviousComponents & ${ComponentPDFDocs}
+    ${If} $R1 <> 0
+      !InsertMacro SelectSection ${SecDocPdf}
+      !InsertMacro SetSectionFlag ${SecDocPdf} ${SF_RO}
+    ${Else}
+      !InsertMacro UnselectSection ${SecDocPdf}
+      !InsertMacro ClearSectionFlag ${SecDocPdf} ${SF_RO}
+    ${EndIf}
+    IntOp $R1 $PreviousComponents & ${ComponentHTMLDocs}
+    ${If} $R1 <> 0
+      !InsertMacro SelectSection ${SecDocHtml}
+      !InsertMacro SetSectionFlag ${SecDocHtml} ${SF_RO}
+    ${Else}
+      !InsertMacro UnselectSection ${SecDocHtml}
+      !InsertMacro ClearSectionFlag ${SecDocHtml} ${SF_RO}
+    ${EndIf}
+  ${EndIf}
+FunctionEnd
+
+Function UpdateComponentUI
+  Push $R0
+  Push $R1
+
+  Call GetSelectedComponents
+  Pop $R0
+
+  IntOp $R1 $R0 ^ $PreviousComponents
+  IntOp $NewComponents $R0 & $R1
+
+  ${If} $InstallType <> ${NewInstall}
+    IntOp $R1 $NewComponents & ${ComponentFile}
+    ${If} $R1 <> 0
+      !InsertMacro SetSectionFlag ${SecFileDaemon} ${SF_BOLD}
+    ${Else}
+      !InsertMacro ClearSectionFlag ${SecFileDaemon} ${SF_BOLD}
+    ${EndIf}
+    IntOp $R1 $NewComponents & ${ComponentTextConsole}
+    ${If} $R1 <> 0
+      !InsertMacro SetSectionFlag ${SecConsole} ${SF_BOLD}
+    ${Else}
+      !InsertMacro ClearSectionFlag ${SecConsole} ${SF_BOLD}
+    ${EndIf}
+    IntOp $R1 $NewComponents & ${ComponentGUIConsole}
+    ${If} $R1 <> 0
+      !InsertMacro SetSectionFlag ${SecWxConsole} ${SF_BOLD}
+    ${Else}
+      !InsertMacro ClearSectionFlag ${SecWxConsole} ${SF_BOLD}
+    ${EndIf}
+    IntOp $R1 $NewComponents & ${ComponentPDFDocs}
+    ${If} $R1 <> 0
+      !InsertMacro SetSectionFlag ${SecDocPdf} ${SF_BOLD}
+    ${Else}
+      !InsertMacro ClearSectionFlag ${SecDocPdf} ${SF_BOLD}
+    ${EndIf}
+    IntOp $R1 $NewComponents & ${ComponentHTMLDocs}
+    ${If} $R1 <> 0
+      !InsertMacro SetSectionFlag ${SecDocHtml} ${SF_BOLD}
+    ${Else}
+      !InsertMacro ClearSectionFlag ${SecDocHtml} ${SF_BOLD}
+    ${EndIf}
+  ${EndIf}
+
+  GetDlgItem $R0 $HWNDPARENT 1
+
+  IntOp $R1 $NewComponents & ${ComponentsRequiringUserConfig}
+  ${If} $R1 = 0
+    SendMessage $R0 ${WM_SETTEXT} 0 "STR:Install"
+  ${Else}
+    SendMessage $R0 ${WM_SETTEXT} 0 "STR:&Next >"
+  ${EndIf}
+
+  Pop $R1
+  Pop $R0
+FunctionEnd
+
+
+!include "InstallType.nsh"
+!include "ConfigPage1.nsh"
+!include "ConfigPage2.nsh"
+!include "DumpLog.nsh"
index 07d307404ba059d350030fe56dd70121ea1f54c4..31b233785f55870bbc235f48df2d0799af2afa5f 100644 (file)
@@ -11,6 +11,7 @@ mixed priorities
 
 General:
 11Jan09
+kes  Add src/win32/newinstaller -- single file installer
 kes  Attempt to explicitly call gmake when needed, or if not found
      skip the calls.  This should fix the FreeBSD regression/build.
 10Jan09