Merge branch 'master' of disconnected-by-peer.at:go-opsi/itwatch
Conflicts: builder/README-builder.txt
This commit is contained in:
commit
cd982a3534
287
CLIENT_DATA/custom/custom.cfg.template
Executable file
287
CLIENT_DATA/custom/custom.cfg.template
Executable file
@ -0,0 +1,287 @@
|
|||||||
|
// itWatch Endpoint Security - Konfigurationsdatei
|
||||||
|
// -------------------------------------------------
|
||||||
|
//
|
||||||
|
// Zur Verwendung bei einer Installation ohne Benutzerinteraktion
|
||||||
|
// und/oder Konfiguration ohne Benutzerinteraktion
|
||||||
|
//
|
||||||
|
// (c) itWatch GmbH - München 2011
|
||||||
|
//
|
||||||
|
// -------------------------------------------------
|
||||||
|
//
|
||||||
|
[Configuration]
|
||||||
|
//
|
||||||
|
// --------------- Policy festlegen ---------------
|
||||||
|
//
|
||||||
|
// POLICY: Gibt an, welche Policy Daten für den Client repliziert und aktiv werden.
|
||||||
|
// Beachten Sie bitte, dass hier nur der Policy Namen angegeben wird - ohne Zusatz ".dwd".
|
||||||
|
//
|
||||||
|
// Beispiel für Verwendung Policy Name "Standard":
|
||||||
|
// Bitte hier gewünschten Wert eintragen; ein Wert ist gültig
|
||||||
|
Policy = standard
|
||||||
|
//
|
||||||
|
//-------------- Pfad für Erstinstallation und/oder Lokalem Betrieb (Standalone Inst) ------
|
||||||
|
//
|
||||||
|
// DEFAULTPOLICYPATH: Gibt an, aus welchem Verzeichnis die im Wert "POLICY" festgelegte Policy
|
||||||
|
// nach Erstinstallation oder bei lokalem Betrieb (Standalone Inst) gelesen wird.
|
||||||
|
// Die Policy muss als Datei im DEFAULTPOLICYPATH stehen; verwenden Sie hierzu
|
||||||
|
// die Funktion "Policy importieren" (mit Berechtigungen) in der itWatch Administration
|
||||||
|
// nachdem Sie die gewünschten Policy Einstellungen getroffen und die itWatch Berechtigungen (
|
||||||
|
// eingetellt haben.
|
||||||
|
// Stellen Sie sicher, dass über die Software Verteilung diese Datei mit ins
|
||||||
|
// entsprechende Verzeichnis während der Installation kopiert wird.
|
||||||
|
// Nach unserer Empfehlung sollte das Default Policy Verzeichnis immer lokal
|
||||||
|
// sein (kein Netzverzeichnis). Wenn Sie das Programmverzeichnis als Default Policy
|
||||||
|
// Verzeichnis wählen, ist auch sichergestellt, dass der Anwender die Policy Datei
|
||||||
|
// nicht manipulieren kann.
|
||||||
|
// Die Verwendung des DEFAULTPOLICYPATH stellt sicher, dass die gewünschte Policy
|
||||||
|
// sofort nach Reboot der Installation aktiv werden kann.
|
||||||
|
// Falls der Wert nicht angegeben wird, wird das itWatch Programmverzeichnis
|
||||||
|
// verwendet.
|
||||||
|
//
|
||||||
|
// Beispiele für die Verwendung des Default Policy Verzeichnisses:
|
||||||
|
// Bitte hier gewünschten Wert eintragen; ein Wert ist gültig
|
||||||
|
// Abhängig vom verwendeten Betriebssystem den gültigen Pfad auswählen, bzw. entsprechend auskommentieren
|
||||||
|
// Pfadangabe für x86 Betriebssysteme
|
||||||
|
DefaultPolicyPath = C:\Programme\itWatch
|
||||||
|
// Pfadangabe für x64 Betriebssysteme
|
||||||
|
// DefaultPolicyPath = C:\Program Files (x86)\itWatch
|
||||||
|
//
|
||||||
|
// ---------- Replikationstyp festlegen -----------
|
||||||
|
//
|
||||||
|
// ReplicationType: Definiert den Replikationstyp.
|
||||||
|
// REGISTRY = Registry Replikation
|
||||||
|
// FTP = FTP Replikation
|
||||||
|
// DIR = Direcory/File Replikation. Server-Angabe wird nicht ausgewertet.
|
||||||
|
//
|
||||||
|
// Beispiel für Verwendung Registry Replikation:
|
||||||
|
// Bitte hier gewünschten Wert eintragen; ein Wert ist gültig
|
||||||
|
ReplicationType = Registry
|
||||||
|
//
|
||||||
|
// --------- Replikationsmodus festlegen -----------
|
||||||
|
//
|
||||||
|
// REPLICATION: Definiert den Replikationsmodus.
|
||||||
|
// Mögliche Werte (und alle Kombinationen daraus):
|
||||||
|
// BOOT = Replikation erfolgt beim Systemstart zum Bootzeitpunkt
|
||||||
|
// Auswahl nur möglich für File Replikation;
|
||||||
|
// beachten Sie bitte, dass auf Netzlaufwerke gewöhnlich zu
|
||||||
|
// diesem Zeitpunkt nicht zugegriffen werden kann
|
||||||
|
// LOGON = Replikatin erfolgt bei Benutzeranmeldung
|
||||||
|
// CYCLE = Zyklisch, "RepCycle" gibt die Zykluszeit an
|
||||||
|
// Auswahl nicht möglich für FTP Replikation
|
||||||
|
// USER UNLOCK = Replikation erfolgt beim Entsperren der Arbeitsstation
|
||||||
|
//
|
||||||
|
// Beispiel für Replikation bei Benutzeranmeldung:
|
||||||
|
// Bitte hier gewünschten Wert eintragen; mehrere Werte sind möglich
|
||||||
|
// Replication = LOGON, CYCLE, USER UNLOCK
|
||||||
|
Replication = LOGON
|
||||||
|
//
|
||||||
|
// -------- Parameter für zyklische Replikation -----
|
||||||
|
//
|
||||||
|
// REPCYCLE: Definiert den Replikationszyklus in Minuten für automatische, zyklische Replikation
|
||||||
|
//
|
||||||
|
// Beispiel für einen Replikationszyklus von 2 Minuten:
|
||||||
|
// Bitte hier gewünschten Wert eintragen; ein Wert ist gültig
|
||||||
|
RepCycle = 2
|
||||||
|
//
|
||||||
|
// -------- Parameter für Registry Replikation ------
|
||||||
|
//
|
||||||
|
// SERVER: Gibt den Replikationsserver an.
|
||||||
|
// * als Server konfiguriert den automatischen Modus mit Replikation gegen PDC/BDC.
|
||||||
|
// Dieser Wert ist nicht erforderlich für Dateireplikation/FTP.
|
||||||
|
//
|
||||||
|
// Beispiel für Server=lokaler Rechner (Lokale Installation/Standalone):
|
||||||
|
// Bitte hier gewünschten Wert eintragen; ein Wert ist gültig
|
||||||
|
SERVER = .
|
||||||
|
// Beispiel für Server = itWatchPDC
|
||||||
|
// Bitte hier gewünschten Wert eintragen und Auskommentierung (//) entfernen; ein Wert ist gültig
|
||||||
|
// SERVER = itWatchPDC
|
||||||
|
//
|
||||||
|
// -------- Parameter für Datei Replikation ------
|
||||||
|
//
|
||||||
|
// POLICYDIR: Gibt für DIR- und FTP- Replikation das Quellverzeichnis der Policy Datei an.
|
||||||
|
// Nicht notwendig für REG Replikation
|
||||||
|
//
|
||||||
|
// Beispiel für Quellverzeichnis=lokaler Rechner
|
||||||
|
// Bitte hier gewünschten Wert eintragen und Auskommentierung (//) entfernen; ein Wert ist gültig
|
||||||
|
//PolicyDir = .
|
||||||
|
//
|
||||||
|
// Beispiel für Quellverzeichnis=Netz
|
||||||
|
// Bitte hier gewünschten Wert eintragen und Auskommentierung (//) entfernen; ein Wert ist gültig
|
||||||
|
//PolicyDir = \\servername\policies
|
||||||
|
//
|
||||||
|
// --------- Parameter für Replikation von FTP ------
|
||||||
|
//
|
||||||
|
// FTPPort: Definiert den FTPPort
|
||||||
|
//
|
||||||
|
// Beispiel für FTP Port 21:
|
||||||
|
// Bitte hier gewünschten Wert eintragen und Auskommentierung (//) entfernen; ein Wert ist gültig
|
||||||
|
//FTPPort = 21
|
||||||
|
//
|
||||||
|
// - - - - - - - - - - - - -
|
||||||
|
//
|
||||||
|
// POLICYDIR: Gibt für DIR- und FTP- Replikation das Quellverzeichnis der Policy Datei an.
|
||||||
|
// Nicht notwendig für REG Replikation
|
||||||
|
//
|
||||||
|
// Beispiel für Quellverzeichnis=FTP Dir=Root
|
||||||
|
// Bitte hier gewünschten Wert eintragen und Auskommentierung (//) entfernen; ein Wert ist gültig
|
||||||
|
//PolicyDir = .
|
||||||
|
// Beispiel für Quellverzeichnis=FTP Dir=SubDir
|
||||||
|
// Bitte hier gewünschten Wert eintragen und Auskommentierung (//) entfernen; ein Wert ist gültig
|
||||||
|
//PolicyDir = policies
|
||||||
|
//
|
||||||
|
// - - - - - - - - - - - - -
|
||||||
|
//
|
||||||
|
// FTPACCOUNT: Gibt den Account für eine FTP Replikation an.
|
||||||
|
// Nicht notwendig für REGISTRY oder DIR Replikation
|
||||||
|
// Wenn FTP Replikationstyp gewählt ist und diese Angabe fehlt, wird der anonymus FTP Account verwendet.
|
||||||
|
//
|
||||||
|
// Beispiel für FTP Account "TU001":
|
||||||
|
// Bitte hier gewünschten Wert eintragen und Auskommentierung (//) entfernen; ein Wert ist gültig
|
||||||
|
//FTPACCOUNT = TU001
|
||||||
|
//
|
||||||
|
// - - - - - - - - - - - - -
|
||||||
|
//
|
||||||
|
// FTPPASSWORD: Gibt das Passwort für den FTP Account an
|
||||||
|
// Angabe in Klartext erforderlich FTP Replikation
|
||||||
|
//
|
||||||
|
// Beispiel für FTP Passwort:
|
||||||
|
// Bitte hier gewünschten Wert eingeben und Auskommentierung (//) entfernen; ein Wert ist gültig
|
||||||
|
//FTPASSWORD = TEST
|
||||||
|
//
|
||||||
|
// --------- Administrationsserver festlegen ---------------------------
|
||||||
|
//
|
||||||
|
// PolicyRepository: Legt fest, wo der Datenbestand (Admin Server) liegt,
|
||||||
|
// mit dem die itWatch Administration arbeitet.
|
||||||
|
// Nur erforderlich für die Administrationskomponente.
|
||||||
|
//
|
||||||
|
// Beispiel für itWatch wird verbunden mit lokaler Rechner:
|
||||||
|
// Bitte hier gewünschten Wert (Rechner Name) eingeben. Ein Wert ist gültig.
|
||||||
|
PolicyRepository = .
|
||||||
|
// Beispiel für itWatch Administration wird verbunden mit Windows Server "PDCmyDomain":
|
||||||
|
// Bitte hier gewünschtn Wert eintragen und Auskommentierung (//) entfernen; ein Wert ist gültig
|
||||||
|
// PolicyRepository = PDCmyDomain
|
||||||
|
//
|
||||||
|
// --------- Ereignisbehandlung festlegen ------------------------------
|
||||||
|
//
|
||||||
|
// LOGLEVEL: Legt den Detaillierungsgrad der Protokollierung fest.
|
||||||
|
// Mögliche Werte:
|
||||||
|
// NONE (oder leer) = keine Meldungen (Stufe 0)
|
||||||
|
// ERROR = Fehlermeldungen (Stufe 1)
|
||||||
|
// ERROR, WARNING, INFORMATION = Fehlermeldungen, Warnhinweise und Informationen (Stufe 2)
|
||||||
|
// DETAILED = vollständige, detaillierte Protokollierung (Stufe 3)
|
||||||
|
//
|
||||||
|
// Beispiel für Protokollierung von Fehlermeldungen; Logeinträge der ausgewählten Stufen 0 - 3 werden in
|
||||||
|
// eine Datei "itWESSLog.csv" geschrieben, die sich in Windows XP im Verzeichnis
|
||||||
|
// z.B. C:\Dokumente und Einstellungen\All Users\Anwendungsdaten\itWatch\Logs" befindet.
|
||||||
|
// Dort jeweils in einem Unterverzeichnis mit dem Datum des letzten Starts des Loggings.
|
||||||
|
// In Microsoft Vista oder windows 7 ist die Datei in %ProgramData%\itWatch\Logs zu finden.
|
||||||
|
//
|
||||||
|
// Bitte hier gewünschten Wert vorgeben:
|
||||||
|
LogLevel = Error
|
||||||
|
// Beispiel für eine geringe Protokollierung (Stufe 1).
|
||||||
|
// LogLevel = NONE
|
||||||
|
// Beispiel für keine Protokollierung (Stufe 0)
|
||||||
|
// LogLevel = ERROR, WARNING, INFORMATION
|
||||||
|
// Beispiel für Stufe 2
|
||||||
|
// LogLevel = DETAILED
|
||||||
|
// Beispiel für eine sehr umfangreiche Protokollierung (Stufe 3)
|
||||||
|
//
|
||||||
|
// -------- DEvCon Konfiguration ---------------------------------------
|
||||||
|
//
|
||||||
|
// DEvConService: An-/Abschalten des DEvCon Services für den Client
|
||||||
|
// Mögliche Werte: ON|OFF
|
||||||
|
// DEvConService=ON (Aktierung)
|
||||||
|
// DEvConService=OFF (Deaktivierung)
|
||||||
|
// Beachten Sie bitte, dass "DEvConService = ON" erforderlich ist, wenn Sie von
|
||||||
|
// Ereignisfiltern an Ihrer Policy Gebrauch machen wollen, oder die transparente
|
||||||
|
// Verschlüsselung im Hintergrund aktiviert werden soll
|
||||||
|
//
|
||||||
|
// Beispiel für DEvCon Service wird für den Client aktiviert:
|
||||||
|
// Bitte hier gewünschten Wert angeben; ein Wert ist gültig
|
||||||
|
DEvConService = ON
|
||||||
|
// Beispiel für DEvCon Service wird für den Client deaktiviert:
|
||||||
|
// DEvConService = OFF
|
||||||
|
//
|
||||||
|
// ------- Parameter für DEvCon Konfiguration ---------------------------
|
||||||
|
//
|
||||||
|
// DEvConServer: Gibt den Namen des Servers an, auf dem das itWatch Management Center (DCView)
|
||||||
|
// installiert und aktiviert wurde und für diesen Client Ereignisse entgegennehmen
|
||||||
|
// soll.
|
||||||
|
// Dieser Client muss dazu in der für ihn gültigen Policy Ereignisfilter
|
||||||
|
// mit Aktion ausführen "Ereignisse an DEvCon melden" aktiviert haben.
|
||||||
|
//
|
||||||
|
// Environmentvariablen werden aufgelöst, wenn als %Variable% angegeben ist.
|
||||||
|
// Default Einstellung ist '.' für den lokalen Rechner
|
||||||
|
//
|
||||||
|
// Dieser Wert muss nur angegeben werden, wenn die Funktion itWatch Management Center
|
||||||
|
// verwendet wird.
|
||||||
|
//
|
||||||
|
// Beispiel für itWatch Management Center liegt auf lokalem Rechner
|
||||||
|
// Bitte hier gewünschten Wert angeben und Auskommentierung (//) entfernen; ein Wert ist gültig
|
||||||
|
// DEvConServer = .
|
||||||
|
// Beispiel für itWatch Management Center liegt auf Rechnername "itWatchPDC"
|
||||||
|
// Bitte hier gewünschten Wert angeben und Auskommentierung (//) entfernen; ein Wert ist gültig
|
||||||
|
// DEvConServer = itWatchPDC
|
||||||
|
//
|
||||||
|
// - - - - - - - - - - - - -
|
||||||
|
//
|
||||||
|
//DEvConBuffer: Gibt die Größe des lokalen Ereignispuffers an. Solange der DEvCon Service die Ereignisse
|
||||||
|
// nicht an den angegebenen DEvCon Server liefern kann, werden die Ereignisse in diesen
|
||||||
|
// Puffer geschrieben.
|
||||||
|
// Defaultwert ist 1000
|
||||||
|
//
|
||||||
|
// Beispiel für die Größe des lokalen Ereignispuffers:
|
||||||
|
// Bitte hier gewünschten Wert angeben; ein Wert ist gültig
|
||||||
|
DEvConBuffer = 1000
|
||||||
|
//
|
||||||
|
// - - - - - - - - - - - - -
|
||||||
|
//
|
||||||
|
// DEvConUserID: Gibt an, ob die ID des angemeldeten Benutzers an das itWatch Managmeent Center (DCView)
|
||||||
|
// übertragen wird
|
||||||
|
// Mögliche Werte: ON|OFF
|
||||||
|
// Default ist OFF, keine Übertragung
|
||||||
|
//
|
||||||
|
// Beispiel für das Einschalten der Übertragung der ID des angemeldeten Benutzers
|
||||||
|
// Bitte hier gewünschten Wert angeben; ein Wert ist gültig
|
||||||
|
DEvConUserID = ON
|
||||||
|
// Beispiel für das Einschalten der Übertragung der ID des angemeldeten Benutzers
|
||||||
|
// Bitte hier gewünschten Wert angeben; ein Wert ist gültig
|
||||||
|
// DEvConUserID = OFF
|
||||||
|
//
|
||||||
|
// - - - - - - - - - - - - -
|
||||||
|
//
|
||||||
|
// EFXEnabled: Gibt an, ob die transparente Verschlüsselung im Hintergrund aktiv wird.
|
||||||
|
// Mögliche Werte: ON|OFF
|
||||||
|
// Default ist OFF, keine Verschlüsselung im Hintergrund
|
||||||
|
//
|
||||||
|
// Beispiel für eine aktive Hintergrundverschlüsselung/transparente Verschlüsselung
|
||||||
|
// Bitte hier gewünschten Wert angeben; ein Wert ist gültig
|
||||||
|
// EFXEnabled = ON
|
||||||
|
// Beispiel für eine inaktive Hintergrundverschlüsselung/transparente Verschlüsselung
|
||||||
|
// Bitte hier gewünschten Wert angeben; ein Wert ist gültig
|
||||||
|
EFXEnabled = OFF
|
||||||
|
//
|
||||||
|
// - - - - - - - - - - - - -
|
||||||
|
//
|
||||||
|
// KMSService: An-/Abschalten des Key Management Service
|
||||||
|
// Mögliche Werte: ON|OFF
|
||||||
|
//
|
||||||
|
// Beispiel für KMService wird für den Client aktiviert:
|
||||||
|
// Bitte hier gewünschten Wert angeben; ein Wert ist gültig
|
||||||
|
// KMSService = ON
|
||||||
|
// Beispiel für KMService wird für den Client deaktiviert:
|
||||||
|
KMSService = OFF
|
||||||
|
//
|
||||||
|
// - - - - - - - - - - - - -
|
||||||
|
//
|
||||||
|
// KMSServer: Gibt den Namen des Schlüsselverwaltungs-Servers an; auf dem der itWatch KM Server installiert wurde und
|
||||||
|
// aktiv ist und für diesen Client das Key Management der PDWatch Company Key Verschlüsselung
|
||||||
|
// verwaltet.
|
||||||
|
// Default ist "." für LocalMachine
|
||||||
|
//
|
||||||
|
// Beispiel für itWatch KM Server = itWatchPDC
|
||||||
|
// Bitte hier gewünschten Wert eingeben und Auskommentierung (//) entfernen; ein Wert ist gültig
|
||||||
|
// KMSServer = itWatchPDC
|
||||||
|
//
|
||||||
|
// -------------- Ende Konfigurationsdatei --------------------------------------------------------
|
||||||
|
|
@ -17,6 +17,9 @@ DefVar $LicenseRequired$
|
|||||||
DefVar $LicenseKey$
|
DefVar $LicenseKey$
|
||||||
DefVar $LicensePool$
|
DefVar $LicensePool$
|
||||||
|
|
||||||
|
; Token BUILDER_VARIABLES will be replace by builder.sh
|
||||||
|
@@BUILDER_VARIABLES@@
|
||||||
|
|
||||||
Set $LogDir$ = "%SystemDrive%\tmp"
|
Set $LogDir$ = "%SystemDrive%\tmp"
|
||||||
|
|
||||||
; ----------------------------------------------------------------
|
; ----------------------------------------------------------------
|
||||||
@ -75,6 +78,9 @@ else
|
|||||||
; comment "Successful Installation"
|
; comment "Successful Installation"
|
||||||
; endif
|
; endif
|
||||||
|
|
||||||
|
comment "Trigger reboot"
|
||||||
|
ExitWindows /Reboot
|
||||||
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
[Winbatch_install]
|
[Winbatch_install]
|
||||||
@ -83,8 +89,8 @@ endif
|
|||||||
;
|
;
|
||||||
; === MSI package =======================================================================================
|
; === MSI package =======================================================================================
|
||||||
; You may use the parameter PIDKEY=$Licensekey$
|
; You may use the parameter PIDKEY=$Licensekey$
|
||||||
msiexec /i "%ScriptPath%\X86FILE" /l* "$LogDir$\$ProductId$.install_log.txt" /qb! ALLUSERS=2 REBOOT=ReallySuppress CONFIGURATIONPATH="%ScriptPath%\custom\custom.cfg"
|
msiexec /i "%ScriptPath%\itWESS-Client_German.msi" /l* "$LogDir$\$ProductId$.install_log.txt" /qb! ALLUSERS=2 REBOOT=ReallySuppress CONFIGURATIONPATH="%ScriptPath%\custom\custom.cfg"
|
||||||
;
|
|
||||||
|
|
||||||
[Files_install]
|
[Files_install]
|
||||||
; Example of recursively copying some files into the installation directory:
|
; Example of recursively copying some files into the installation directory:
|
||||||
|
@ -17,6 +17,9 @@ DefVar $LicensePool$
|
|||||||
|
|
||||||
Set $LogDir$ = "%SystemDrive%\tmp"
|
Set $LogDir$ = "%SystemDrive%\tmp"
|
||||||
|
|
||||||
|
; Token BUILDER_VARIABLES will be replace by builder.sh
|
||||||
|
@@BUILDER_VARIABLES@@
|
||||||
|
|
||||||
; ----------------------------------------------------------------
|
; ----------------------------------------------------------------
|
||||||
; - Please edit the following values -
|
; - Please edit the following values -
|
||||||
; ----------------------------------------------------------------
|
; ----------------------------------------------------------------
|
||||||
@ -35,6 +38,9 @@ Message "Uninstalling " + $ProductId$ + " ..."
|
|||||||
if FileExists("%ScriptPath%\delsub32.ins")
|
if FileExists("%ScriptPath%\delsub32.ins")
|
||||||
comment "Start uninstall sub section"
|
comment "Start uninstall sub section"
|
||||||
Sub "%ScriptPath%\delsub32.ins"
|
Sub "%ScriptPath%\delsub32.ins"
|
||||||
|
|
||||||
|
comment "Trigger reboot"
|
||||||
|
ExitWindows /Reboot
|
||||||
endif
|
endif
|
||||||
|
|
||||||
if $LicenseRequired$ = "true"
|
if $LicenseRequired$ = "true"
|
||||||
|
@ -1,18 +0,0 @@
|
|||||||
############################
|
|
||||||
# define methods to overwrite library methods here
|
|
||||||
# refer to the the builder.sh to check the methods
|
|
||||||
############################
|
|
||||||
|
|
||||||
#builder_read_config_pre() {
|
|
||||||
# echo "** USER: Cal.ling BEFORE builder__read_confi"
|
|
||||||
#}
|
|
||||||
|
|
||||||
#builder_read_config() {
|
|
||||||
# echo "** USER: Calling INSTEAD-OF builder_read_config"
|
|
||||||
#}
|
|
||||||
|
|
||||||
#builder__read_confif() {
|
|
||||||
# echo "** USER: Calling AFTER builder__read_config"
|
|
||||||
#}
|
|
||||||
|
|
||||||
|
|
41
builder-product.cfg
Normal file
41
builder-product.cfg
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
############################
|
||||||
|
# Setup product information
|
||||||
|
############################
|
||||||
|
VENDOR="itwatch.de"
|
||||||
|
PN="itwatch"
|
||||||
|
VERSION="4.10.19"
|
||||||
|
RELEASE="3"
|
||||||
|
PRIORITY="0"
|
||||||
|
ADVICE=""
|
||||||
|
|
||||||
|
# Status integration, testing, release
|
||||||
|
STATUS="review"
|
||||||
|
|
||||||
|
#################
|
||||||
|
# Setup url for downloading the binaries
|
||||||
|
################
|
||||||
|
|
||||||
|
# all downloads should not have any traling parameters like ?downlaodid=1234 .....(should rewrite in python)
|
||||||
|
# You can setup many URL's separated by ";"
|
||||||
|
|
||||||
|
# Format: basename ; URL1 ; URL2 ; ...
|
||||||
|
ICON_FILE_INDEX=0
|
||||||
|
|
||||||
|
# Format: basename ; URL1 ; URL2 ; ...
|
||||||
|
#FILE1="itWESS-Client_German.msi;http://ivyrepos.dtnet.de/v-$PN/itwatch/itwatch/4.10.19/itWESS-Client_German.msi;http://internal.graz.disconnected-by-peer.at/Orig/itWatch/itWESS/HB/4.10.19/itWESS-Client_German.msi"
|
||||||
|
#FILE2="itWESS-64bit_German.msi;http://ivyrepos.dtnet.de/itwatch/itwatch/4.10.19/itWESS-64bit_German.msi;http://internal.graz.disconnected-by-peer.at/Orig/itWatch/itWESS/HB/4.10.19/itWESS-64bit_German.msi"
|
||||||
|
|
||||||
|
FILE[0]="itWatchLogo.jpg"
|
||||||
|
SOURCE[0]="http://www.itwatch.de/logos/itWatchLogo.jpg"
|
||||||
|
WINST[0]=IconFile
|
||||||
|
|
||||||
|
FILE[1]="itWESS-Client_German.msi"
|
||||||
|
SOURCE[1]="http://ivyrepos.dtnet.de/v-$PN/itwatch/itwatch/4.10.19/itWESS-Client_German.msi;http://internal.graz.disconnected-by-peer.at/Orig/itWatch/itWESS/HB/4.10.19/itWESS-Client_German.msi"
|
||||||
|
ARCH[1]="X86"
|
||||||
|
WINST[1]=itWESS
|
||||||
|
|
||||||
|
FILE[2]="itWESS-64bit_German.msi"
|
||||||
|
SOURCE[2]="http://ivyrepos.dtnet.de/itwatch/itwatch/4.10.19/itWESS-64bit_German.msi;http://internal.graz.disconnected-by-peer.at/Orig/itWatch/itWESS/HB/4.10.19/itWESS-64bit_German.msi"
|
||||||
|
ARCH[2]="X86_64"
|
||||||
|
WINST[2]=itWESS64
|
||||||
|
|
52
builder-targets-cb.sh
Normal file
52
builder-targets-cb.sh
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
##############################################################################
|
||||||
|
# This optional file "builder-targets-cb.sh" will be called by builder.sh
|
||||||
|
#
|
||||||
|
# You can overwrite target functions like
|
||||||
|
# config, prepare, retrieve, create, package, publish, commit, cleanup
|
||||||
|
# and define callback functions
|
||||||
|
# cb_package_makeproductfile
|
||||||
|
#
|
||||||
|
##############################################################################
|
||||||
|
|
||||||
|
#function config() {
|
||||||
|
# echo "Config"
|
||||||
|
# builder_config
|
||||||
|
#}
|
||||||
|
|
||||||
|
#function prepare() {
|
||||||
|
# echo "Prepare"
|
||||||
|
# builder_prepare
|
||||||
|
#}
|
||||||
|
|
||||||
|
function retrieve() {
|
||||||
|
echo "Retrieve"
|
||||||
|
builder_retrieve
|
||||||
|
}
|
||||||
|
|
||||||
|
function create() {
|
||||||
|
echo "Create"
|
||||||
|
builder_create
|
||||||
|
}
|
||||||
|
|
||||||
|
function package() {
|
||||||
|
echo "Package"
|
||||||
|
builder_package
|
||||||
|
}
|
||||||
|
|
||||||
|
function cb_package_makeproductfile() {
|
||||||
|
echo "May add/replace files to the files to $inst_dir"
|
||||||
|
}
|
||||||
|
|
||||||
|
function publish() {
|
||||||
|
echo "Publish"
|
||||||
|
builder_publish
|
||||||
|
}
|
||||||
|
|
||||||
|
function commit() {
|
||||||
|
echo "Commit"
|
||||||
|
# builder_commit
|
||||||
|
}
|
||||||
|
function cleanup() {
|
||||||
|
echo "Cleanup: output_dir: $output_dir"
|
||||||
|
# builder_cleanup
|
||||||
|
}
|
@ -1,32 +0,0 @@
|
|||||||
##############################
|
|
||||||
# Prerequirements:
|
|
||||||
# - Setup your environment variable inside the shell, e.g. ~/.bashrc
|
|
||||||
# export BUILD_LOCAL_CFG=/home/dschwager/work/build_local.cfg
|
|
||||||
# check the sample build_local.cfg located inside the itwatch project
|
|
||||||
##############################
|
|
||||||
|
|
||||||
# requirements
|
|
||||||
yum install plowshare
|
|
||||||
yum install ImageMagick
|
|
||||||
yum install git
|
|
||||||
|
|
||||||
# Define your local, private, individual, not-project dependent build setup
|
|
||||||
# in the file ~/.builder.cfg OR by using the environment variable BUILD_LOCAL_CFG
|
|
||||||
# pointing the the configuration.
|
|
||||||
# export BUILD_LOCAL_CFG=/home/dschwager/work/itwatch/build_local.cfg
|
|
||||||
# If no files are availble, the default values will be use.
|
|
||||||
|
|
||||||
# Start build
|
|
||||||
builder.sh <path-to-the-project>
|
|
||||||
builder.sh /home/dschwager/work/itwatch
|
|
||||||
|
|
||||||
# Force downloading vendor files
|
|
||||||
DIST_FORCE_DOWNLOAD=1 builder.sh /home/dschwager/work/itwatch
|
|
||||||
|
|
||||||
# Force upload independent of existing OPSI-Package in repository
|
|
||||||
OPSI_REPOS_FORCE_UPLOAD=1 builder.sh /home/dschwager/work/itwatch
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
================================================================================
|
|
@ -1,41 +0,0 @@
|
|||||||
###################################################
|
|
||||||
# build-default.cfg
|
|
||||||
# Default values for OPSI builder system
|
|
||||||
####################################################
|
|
||||||
|
|
||||||
##################################
|
|
||||||
# Global variables
|
|
||||||
#################################
|
|
||||||
TMP_DIR=/tmp
|
|
||||||
|
|
||||||
##################################
|
|
||||||
# OPSI repository settings
|
|
||||||
#################################
|
|
||||||
# Basedirectory storing OPSI-packages after building
|
|
||||||
OPSI_REPOS_BASE_DIR=$HOME/.opsi-repository
|
|
||||||
|
|
||||||
# Directory- and filename pattern
|
|
||||||
OPSI_REPOS_PRODUCT_DIR=${OPSI_REPOS_BASE_DIR}/${STATUS}/${VENDOR}/${PN}/${VERSION}-${RELEASE}
|
|
||||||
|
|
||||||
# OPSI-package filepattern
|
|
||||||
OPSI_REPOS_FILE_PATTERN=${PN}_${VERSION}-${RELEASE}.opsi
|
|
||||||
|
|
||||||
# Force alway upload to opsi repos
|
|
||||||
# OPSI_REPOS_FORCE_UPLOAD=1
|
|
||||||
|
|
||||||
|
|
||||||
###############################
|
|
||||||
# Distribution / Vendor settings
|
|
||||||
###############################
|
|
||||||
|
|
||||||
# Directory downloading/cacheing the artifacts like MSI package or icons from the vendor webside
|
|
||||||
DIST_CACHE_DIR=$HOME/.opsi-dist-cache/${PN}-${VERSION}
|
|
||||||
|
|
||||||
# private dist repository. You can use all variables from release.cfg insde the URL
|
|
||||||
# this optinal URL will be the FIRST url to check for downloading vendor stuff.
|
|
||||||
# To copy a local file, the repos should start with file://
|
|
||||||
DIST_PRIVATE_REPOS=file://$HOME/opsi-dist.private/$VENDOR/$PN/$VERSION
|
|
||||||
|
|
||||||
# Force always downloading dist files
|
|
||||||
# DIST_FORCE_DOWNLOAD=1
|
|
||||||
|
|
@ -1,204 +0,0 @@
|
|||||||
#####################
|
|
||||||
# Call user entry point
|
|
||||||
####################
|
|
||||||
|
|
||||||
call_entry_point() {
|
|
||||||
|
|
||||||
# Entry point
|
|
||||||
type $1 &>/dev/null
|
|
||||||
if [ $? == 0 ] ; then
|
|
||||||
$1
|
|
||||||
fi
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
#####################
|
|
||||||
# Read config
|
|
||||||
####################
|
|
||||||
|
|
||||||
# read private build configuration
|
|
||||||
#test -f "$BUILD_LOCAL_CFG" && . $BUILD_LOCAL_CFG
|
|
||||||
|
|
||||||
builder_read_config() {
|
|
||||||
|
|
||||||
|
|
||||||
# Check temp dir
|
|
||||||
test -d ${TMP_DIR}
|
|
||||||
builder_check_error "temp directory not available: $TMP_DIR"
|
|
||||||
|
|
||||||
# Source product release configuration
|
|
||||||
test -f ${PRODUCT_DIR}/product.cfg
|
|
||||||
builder_check_error "can't read release configuration: ${PRODUCT_DIR}/product.cfg"
|
|
||||||
. $PRODUCT_DIR/product.cfg
|
|
||||||
|
|
||||||
# set default build configuration and source the user dependent file
|
|
||||||
. $BASEDIR/build-default.cfg
|
|
||||||
|
|
||||||
# Source local build configuration (must be done AFTER sourcing the release.cfg)
|
|
||||||
test -f $HOME/.builder.cfg && . $HOME/.builder.cfg && echo "Loaded builder configuration: $HOME/.builder.cfg"
|
|
||||||
test -f "$BUILD_LOCAL_CFG" && . $BUILD_LOCAL_CFG && echo "Loaded builder configuration: $BUILD_LOCAL_CFG"
|
|
||||||
|
|
||||||
# Check variables
|
|
||||||
if [ -z ${OPSI_REPOS_BASE_DIR} ] || [ ! -d ${OPSI_REPOS_BASE_DIR} ] ; then
|
|
||||||
echo "configuration error: OPSI_REPOS_BASE_DIR directory does not exist: $OPSI_REPOS_BASE_DIR"
|
|
||||||
exit 2
|
|
||||||
fi
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#####################
|
|
||||||
# Download all dist files from one of the defined URLs.
|
|
||||||
# and validate the checksum
|
|
||||||
####################
|
|
||||||
builder_download_dist_files() {
|
|
||||||
|
|
||||||
mkdir -p $DIST_CACHE_DIR
|
|
||||||
echo "Distribution directory: $DIST_CACHE_DIR"
|
|
||||||
|
|
||||||
for f1 in $ICON $FILE1 $FILE2 ; do
|
|
||||||
basename=`echo $f1 | cut -d ";" -f1`
|
|
||||||
urls=`echo $f1 | cut -d ";" -f2-`
|
|
||||||
downloaded=0
|
|
||||||
|
|
||||||
# Add private repos to the urls
|
|
||||||
if [ ! -z ${DIST_PRIVATE_REPOS} ]; then
|
|
||||||
urls="${DIST_PRIVATE_REPOS}/$basename;$urls"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# check existence of CRC file
|
|
||||||
if [ ! -e ${PRODUCT_DIR}/${basename}.sha1sum ] ; then
|
|
||||||
echo "You need to create the checksums with: sha1sum ${DIST_CACHE_DIR}/${basename} > ${PRODUCT_DIR}/${basename}.sha1sum"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "Downloading $basename"
|
|
||||||
# check downloading from the defined URLs
|
|
||||||
for f2 in `echo $urls | sed -e 's/;/\n/g'` ; do
|
|
||||||
if [ $downloaded == 1 ]; then continue; fi
|
|
||||||
|
|
||||||
echo " Info: Downloding from $f2"
|
|
||||||
|
|
||||||
# Check, if the URL is a file URL starting with file://
|
|
||||||
if [ -f ${DIST_CACHE_DIR}/$basename ] && [ -z ${DIST_FORCE_DOWNLOAD} ]; then
|
|
||||||
echo " Info: File still cached/downloaded. To force a download, set DIST_FORCE_DOWNLOAD=1"
|
|
||||||
elif [[ $f2 == file://* ]]; then
|
|
||||||
fileurl=`echo $f2 | sed "s/^file:\/\///"`
|
|
||||||
cp $fileurl ${DIST_CACHE_DIR}/$basename 2>/dev/null
|
|
||||||
else
|
|
||||||
rm -f ${DIST_CACHE_DIR}/$basename
|
|
||||||
wget --tries=1 -O ${DIST_CACHE_DIR}/$basename --timeout=5 -q --no-verbose $f2
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ $? == 0 ] ; then
|
|
||||||
# testing the checksum of the downloaded files
|
|
||||||
SHA1SUM=`cat ${PRODUCT_DIR}/${basename}.sha1sum | cut -d " " -f1`
|
|
||||||
CHECKSUM=`sha1sum ${DIST_CACHE_DIR}/$basename | cut -d " " -f1`
|
|
||||||
if [ "$CHECKSUM" == "$SHA1SUM" ] ; then
|
|
||||||
downloaded=1
|
|
||||||
echo " Info: Downloaded successfully"
|
|
||||||
else
|
|
||||||
echo " Error: The checksums do not match - try next URL"
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
echo " Warning: Failed to download file - try next URL"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
echo
|
|
||||||
|
|
||||||
# Ups - no URL works
|
|
||||||
if [ $downloaded != 1 ] ; then
|
|
||||||
echo " Error: can download the file or checksum wrong (sha1sum ${DIST_CACHE_DIR}/${basename} > ${basename}.sha1sum)"
|
|
||||||
exit 1;
|
|
||||||
fi
|
|
||||||
|
|
||||||
done
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#####################
|
|
||||||
# build opsi package
|
|
||||||
#####################
|
|
||||||
builder_package() {
|
|
||||||
|
|
||||||
OUT=$(mktemp -d $TMP_DIR/opsi-builder.XXXXXXXXXX) || { echo "Failed to create temp dir"; exit 1; }
|
|
||||||
|
|
||||||
# Copy files and convert text files to dos format
|
|
||||||
mkdir $OUT/$PN
|
|
||||||
cp -Rv ${PRODUCT_DIR}/OPSI ${PRODUCT_DIR}/CLIENT_DATA $OUT/$PN
|
|
||||||
find $OUT/$PN/CLIENT_DATA -type f | xargs -n1 -iREP sh -c 'file -i $0 | grep "text/plain" && dos2unix $0' REP
|
|
||||||
|
|
||||||
# copy binaries
|
|
||||||
for f1 in $FILE1 $FILE2 ; do
|
|
||||||
basename=`echo $f1 | cut -d ";" -f1`
|
|
||||||
cp ${DIST_CACHE_DIR}/$basename $OUT/$PN/CLIENT_DATA
|
|
||||||
done
|
|
||||||
|
|
||||||
# converting icon file
|
|
||||||
ICONFILE=`echo $ICON | cut -d ";" -f1`
|
|
||||||
convert -colorspace rgb ${DIST_CACHE_DIR}/$ICONFILE -transparent white -background transparent -resize 160x160 \
|
|
||||||
-size 160x160 xc:transparent +swap -gravity center -composite $OUT/$PN/CLIENT_DATA/$PN.png
|
|
||||||
builder_check_error "converting image"
|
|
||||||
|
|
||||||
# replace variables
|
|
||||||
echo Building OPSI-Package
|
|
||||||
sed -e "s!VERSION!$VERSION!g" -e "s!RELEASE!$RELEASE!g" -e "s!PRIORITY!$PRIORITY!g" -e "s!ADVICE!$ADVICE!g" -i $OUT/$PN/OPSI/control
|
|
||||||
sed -e "s!X86FILE!$X86FILE!g" -i $OUT/$PN/CLIENT_DATA/setup32.ins
|
|
||||||
|
|
||||||
# Create changelog based on git - if available
|
|
||||||
if test -d "${PRODUCT_DIR}/.git"; then
|
|
||||||
git log --date-order --date=short | \
|
|
||||||
sed -e '/^commit.*$/d' | \
|
|
||||||
awk '/^Author/ {sub(/\\$/,""); getline t; print $0 t; next}; 1' | \
|
|
||||||
sed -e 's/^Author: //g' | \
|
|
||||||
sed -e 's/>Date: \([0-9]*-[0-9]*-[0-9]*\)/>\t\1/g' | \
|
|
||||||
sed -e 's/^\(.*\) \(\)\t\(.*\)/\3 \1 \2/g' > $OUT/$PN/OPSI/changelog.txt
|
|
||||||
else
|
|
||||||
echo "No git repository present."
|
|
||||||
fi
|
|
||||||
|
|
||||||
# building package
|
|
||||||
pushd ${TMP_DIR}
|
|
||||||
rm -f ${PN}_${VERSION}-${RELEASE}.opsi
|
|
||||||
opsi-makeproductfile -v $OUT/$PN
|
|
||||||
builder_check_error "Building OPSI-package"
|
|
||||||
popd
|
|
||||||
|
|
||||||
# cleanup
|
|
||||||
rm -rf $OUT
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
#####################
|
|
||||||
# build opsi package
|
|
||||||
#####################
|
|
||||||
builder_upload() {
|
|
||||||
|
|
||||||
# Upload file to repository
|
|
||||||
mkdir -p ${OPSI_REPOS_PRODUCT_DIR}
|
|
||||||
cp -av $TMP_DIR/${PN}_${VERSION}-${RELEASE}.opsi ${OPSI_REPOS_PRODUCT_DIR}/${OPSI_REPOS_FILE_PATTERN}
|
|
||||||
builder_check_error "Can't upload file $TMP_DIR/${PN}_${VERSION}-${RELEASE}.opsi to ${OPSI_REPOS_PRODUCT_DIR}/${OPSI_REPOS_FILE_PATTERN}"
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
###################
|
|
||||||
# Commiting changes to repos
|
|
||||||
###################
|
|
||||||
builder_commit() {
|
|
||||||
if test -d ".git"; then
|
|
||||||
echo
|
|
||||||
# echo "builder_commit() not implemented yet."
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
###################
|
|
||||||
# Check error
|
|
||||||
###################
|
|
||||||
builder_check_error() {
|
|
||||||
if [ $? == 1 ] ; then
|
|
||||||
echo "FATAL: $1"
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
@ -1,67 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
#
|
|
||||||
#
|
|
||||||
|
|
||||||
# enabled debug
|
|
||||||
# set -x
|
|
||||||
|
|
||||||
#####################
|
|
||||||
# Main
|
|
||||||
####################
|
|
||||||
builder_main() {
|
|
||||||
# read config
|
|
||||||
call_entry_point builder_read_config_pre
|
|
||||||
builder_read_config
|
|
||||||
call_entry_point builder_read_config_post
|
|
||||||
|
|
||||||
# Check if the package is still build
|
|
||||||
if [ -z "$OPSI_REPOS_FORCE_UPLOAD" ] && [ -f ${OPSI_REPOS_PRODUCT_DIR}/${OPSI_REPOS_FILE_PATTERN} ] ; then
|
|
||||||
echo "ERROR: package ${OPSI_REPOS_PRODUCT_DIR}/${OPSI_REPOS_FILE_PATTERN} already generated"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# download and process dist files
|
|
||||||
call_entry_point builder_download_dist_files_pre
|
|
||||||
builder_download_dist_files
|
|
||||||
call_entry_point builder_download_dist_files_post
|
|
||||||
|
|
||||||
# Start building
|
|
||||||
call_entry_point builder_package_pre
|
|
||||||
builder_package
|
|
||||||
call_entry_point builder_package_post
|
|
||||||
|
|
||||||
# Upload to repos
|
|
||||||
call_entry_point builder_upload_pre
|
|
||||||
builder_upload
|
|
||||||
call_entry_point builder_upload_post
|
|
||||||
|
|
||||||
# git commit
|
|
||||||
call_entry_point builder_commit_pre
|
|
||||||
builder_commit
|
|
||||||
call_entry_point builder_commit_post
|
|
||||||
}
|
|
||||||
|
|
||||||
# get the 'real' directory this program stored in (resolve symbolic links)
|
|
||||||
PRG=$(readlink -f $0)
|
|
||||||
BASEDIR=`dirname "$PRG"`
|
|
||||||
BASEDIR=`cd "$BASEDIR" && pwd`
|
|
||||||
|
|
||||||
# read libraries
|
|
||||||
. $BASEDIR/builder-lib.sh
|
|
||||||
|
|
||||||
# check product directory
|
|
||||||
PRODUCT_DIR=$1
|
|
||||||
test -d $PRODUCT_DIR
|
|
||||||
builder_check_error "no opsi product directory specified: $PRODUCT_DIR"
|
|
||||||
|
|
||||||
# source additional, product dependent methods
|
|
||||||
if [ -f "$PRODUCT_DIR/build-extension.sh" ] ; then
|
|
||||||
. "$PRODUCT_DIR/build-extension.sh"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# call main
|
|
||||||
builder_main
|
|
||||||
|
|
||||||
# exit
|
|
||||||
exit 0
|
|
||||||
|
|
28
product.cfg
28
product.cfg
@ -1,28 +0,0 @@
|
|||||||
############################
|
|
||||||
# Setup product information
|
|
||||||
############################
|
|
||||||
VENDOR="itwatch.de"
|
|
||||||
PN="itwatch"
|
|
||||||
VERSION="4.10.19"
|
|
||||||
RELEASE="1"
|
|
||||||
PRIORITY="0"
|
|
||||||
ADVICE=""
|
|
||||||
|
|
||||||
# Status integration, testing, release
|
|
||||||
STATUS="review"
|
|
||||||
|
|
||||||
#################
|
|
||||||
# Setup url for downloading the binaries
|
|
||||||
################
|
|
||||||
|
|
||||||
# all downloads should not have any traling parameters like ?downlaodid=1234 .....(should rewrite in python)
|
|
||||||
# You can setup many URL's separated by ";"
|
|
||||||
|
|
||||||
# Format: basename ; URL1 ; URL2 ; ...
|
|
||||||
ICON="itWatchLogo.jpg;http://www.itwatch.de/logos/itWatchLogo.jpg"
|
|
||||||
|
|
||||||
# Format: basename ; URL1 ; URL2 ; ...
|
|
||||||
FILE1="itWESS-Client_German.msi;http://ivyrepos.dtnet.de/v-$PN/itwatch/itwatch/4.10.19/itWESS-Client_German.msi;http://internal.graz.disconnected-by-peer.at/Orig/itWatch/itWESS/HB/4.10.19/itWESS-Client_German.msi"
|
|
||||||
|
|
||||||
FILE2="itWESS-64bit_German.msi;http://ivyrepos.dtnet.de/itwatch/itwatch/4.10.19/itWESS-64bit_German.msi;http://internal.graz.disconnected-by-peer.at/Orig/itWatch/itWESS/HB/4.10.19/itWESS-64bit_German.msi"
|
|
||||||
|
|
Loading…
x
Reference in New Issue
Block a user