From 8b87438a394d6c4756ad1753fb290f1af967b136 Mon Sep 17 00:00:00 2001
From: Mario Fetka <mario.fetka@gmail.com>
Date: Fri, 15 Jul 2011 22:27:42 +0200
Subject: [PATCH] initial checkin

---
 CLIENT_DATA/setup.ins                        | 218 +++++++++++++++++++
 LinLibertineOTF_5.1.3_2011_06_21.tgz.sha1sum |   1 +
 OPSI/changelog.txt                           |   0
 OPSI/control                                 |  33 +++
 OPSI/postinst                                |   9 +
 OPSI/preinst                                 |   9 +
 build.sh                                     | 132 +++++++++++
 fontreg-2.1.3-redist.7z.sha1sum              |   1 +
 libertine.png.sha1sum                        |   1 +
 9 files changed, 404 insertions(+)
 create mode 100644 CLIENT_DATA/setup.ins
 create mode 100644 LinLibertineOTF_5.1.3_2011_06_21.tgz.sha1sum
 create mode 100644 OPSI/changelog.txt
 create mode 100644 OPSI/control
 create mode 100644 OPSI/postinst
 create mode 100644 OPSI/preinst
 create mode 100644 build.sh
 create mode 100644 fontreg-2.1.3-redist.7z.sha1sum
 create mode 100644 libertine.png.sha1sum

diff --git a/CLIENT_DATA/setup.ins b/CLIENT_DATA/setup.ins
new file mode 100644
index 0000000..829896b
--- /dev/null
+++ b/CLIENT_DATA/setup.ins
@@ -0,0 +1,218 @@
+; Copyright (c) uib gmbh (www.uib.de)
+; This sourcecode is owned by uib
+; and published under the Terms of the General Public License.
+; credits: http://www.opsi.org/credits/
+
+[Actions]
+requiredWinstVersion >= "4.10.8.6"
+
+DefVar $MsiId32$
+DefVar $UninstallProgram32$
+DefVar $MsiId64$
+DefVar $UninstallProgram64$
+DefVar $LogDir$
+DefVar $ProductId$  
+DefVar $MinimumSpace$
+DefVar $InstallDir32$
+DefVar $InstallDir64$
+DefVar $ExitCode$
+DefVar $LicenseRequired$
+DefVar $LicenseKey$
+DefVar $LicensePool$
+DefVar $INST_SystemType$
+DefVar $INST_architecture$
+
+Set $INST_SystemType$ = GetSystemType
+set $INST_architecture$ = GetProductProperty("install_architecture","system specific")
+
+
+Set $LogDir$ = "%SystemDrive%\tmp"
+
+; ----------------------------------------------------------------
+; - Please edit the following values                             -
+; ----------------------------------------------------------------
+;$ProductId$ should be the name of the product in opsi
+; therefore please: only lower letters, no umlauts, 
+; no white space use '-' as a seperator
+Set $ProductId$       = "font-linux-libertine"
+Set $MinimumSpace$    = "10 MB"
+; the path were we find the product after the installation
+Set $InstallDir32$      = "%ProgramFiles32Dir%\Libertine"
+Set $InstallDir64$      = "%ProgramFiles64Dir%\Libertine"
+Set $LicenseRequired$ = "false"
+Set $LicensePool$     = "p_" + $ProductId$
+; ----------------------------------------------------------------
+
+if not(HasMinimumSpace ("%SystemDrive%", $MinimumSpace$))
+	LogError "Not enough space on %SystemDrive%, " + $MinimumSpace$ + " on drive %SystemDrive% needed for " + $ProductId$
+	isFatalError
+	; Stop process and set installation status to failed
+else
+	comment "Show product picture"
+	ShowBitmap "%ScriptPath%\" + $ProductId$ + ".png" $ProductId$
+	
+	if FileExists("%ScriptPath%\delsub.ins")
+		comment "Start uninstall sub section"
+		Sub "%ScriptPath%\delsub.ins"
+	endif
+	
+	if $LicenseRequired$ = "true"
+		comment "Licensing required, reserve license and get license key"
+		Sub_get_licensekey
+	endif
+	
+	comment "installing"
+
+	if (($INST_SystemType$ = "x86 System") and ($INST_architecture$ = "system specific")) or ($INST_architecture$ = "both") or ($INST_architecture$ = "32 only")
+		Message "Installing " + $ProductId$ + " 32 Bit..."
+		comment "Start setup program"
+		Winbatch_install_32
+		Sub_check_exitcode
+		comment "Copy files"
+		Files_install_32 /32Bit
+		comment "Patch Registry"
+		Registry_install /32Bit
+		comment "Create shortcuts"
+		LinkFolder_install
+	endif
+
+	if ($INST_SystemType$ = "64 Bit System") and (($INST_architecture$ = "system specific") or ($INST_architecture$ = "both") or ($INST_architecture$ = "64 only"))
+		Message "Installing " + $ProductId$ + " 64 Bit..."
+		comment "Start setup program"
+		Winbatch_install_64
+		Sub_check_exitcode
+		comment "Copy files"
+		Files_install_64 /64Bit
+		comment "Patch Registry"
+		Registry_install /64Bit
+		comment "Create shortcuts"
+		LinkFolder_install
+	endif
+	
+endif
+
+[Winbatch_install_32]
+"%ScriptPath%\files" & "FontReg32.exe /copy"
+
+[Files_install_32]
+; Example of recursively copying some files into the installation directory:
+;
+; copy -s "%ScriptPath%\files\*.*" "$InstallDir32$"
+
+[Winbatch_install_64]
+"%ScriptPath%\files" & "FontReg64.exe /copy"
+
+[Files_install_64]
+; Example of recursively copying some files into the installation directory:
+;
+; copy -s "%ScriptPath%\files\*.*" "$InstallDir64$"
+
+[Registry_install]
+; Example of setting some values of an registry key:
+;
+; openkey [HKEY_LOCAL_MACHINE\Software\$ProductId$]
+; set "name1" = "some string value"
+; set "name2" = REG_DWORD:0001
+; set "name3" = REG_BINARY:00 af 99 cd
+
+[LinkFolder_install]
+; Example of deleting a folder from AllUsers startmenu:
+;
+; set_basefolder common_programs
+; delete_subfolder $ProductId$
+;
+; Example of creating an shortcut to the installed exe in AllUsers startmenu:
+;
+; set_basefolder common_programs
+; set_subfolder $ProductId$
+;
+; set_link
+; 	name: $ProductId$
+; 	target: <path to the program>
+; 	parameters:
+; 	working_dir: $InstallDir$
+; 	icon_file:
+; 	icon_index:
+; end_link
+;
+; Example of creating an shortcut to the installed exe on AllUsers desktop:
+;
+; set_basefolder common_desktopdirectory
+; set_subfolder ""
+;
+; set_link
+; 	name: $ProductId$
+; 	target: <path to the program>
+; 	parameters: <some_param>
+; 	working_dir: $InstallDir$
+; 	icon_file: <path to icon file>
+; 	icon_index: 2
+; end_link
+
+[Sub_get_licensekey]
+if opsiLicenseManagementEnabled
+	comment "License management is enabled and will be used"
+
+	comment "Trying to get a license key"
+	Set $LicenseKey$ = demandLicenseKey ($LicensePool$)
+	; If there is an assignment of exactly one licensepool to the product the following call is possible:
+	; Set $LicenseKey$ = demandLicenseKey ("", $ProductId$)
+	;
+	; If there is an assignment of a license pool to a windows software id, it is possible to use:
+	; DefVar $WindowsSoftwareId$
+	; $WindowsSoftwareId$ = "..."
+	; Set $LicenseKey$ = demandLicenseKey ("", "", $WindowsSoftwareId$)
+	
+	DefVar $ServiceErrorClass$
+	set $ServiceErrorClass$ = getLastServiceErrorClass
+	comment "Error class: " + $ServiceErrorClass$
+	
+	if $ServiceErrorClass$ = "None"
+		comment "Everything fine, we got the license key '" + $LicenseKey$ + "'"
+	else
+		if $ServiceErrorClass$ = "LicenseConfigurationError"
+			LogError "Fatal: license configuration must be corrected"
+			LogError getLastServiceErrorMessage
+			isFatalError
+		else 
+			if $ServiceErrorClass$ = "LicenseMissingError"
+				LogError "Fatal: required license is not supplied"
+				isFatalError
+			endif
+		endif
+	endif
+else
+	LogError "Fatal: license required, but license management not enabled"
+	isFatalError
+endif
+
+
+[Sub_check_exitcode]
+comment "Test for installation success via exit code"
+set $ExitCode$ = getLastExitCode
+; informations to exit codes see
+; http://msdn.microsoft.com/en-us/library/aa372835(VS.85).aspx
+; http://msdn.microsoft.com/en-us/library/aa368542.aspx
+if ($ExitCode$ = "0")
+	comment "Looks good: setup program gives exitcode zero"
+else
+	comment "Setup program gives a exitcode unequal zero: " + $ExitCode$
+	if ($ExitCode$ = "1605")
+		comment "ERROR_UNKNOWN_PRODUCT	1605	This action is only valid for products that are currently installed."
+		comment "Uninstall of a not installed product failed - no problem"
+	else
+		if ($ExitCode$ = "1641")
+			comment "looks good: setup program gives exitcode 1641"
+			comment "ERROR_SUCCESS_REBOOT_INITIATED	1641	The installer has initiated a restart. This message is indicative of a success."
+		else
+			if ($ExitCode$ = "3010")
+				comment "looks good: setup program gives exitcode 3010"
+				comment "ERROR_SUCCESS_REBOOT_REQUIRED	3010	A restart is required to complete the install. This message is indicative of a success."
+			else
+				logError "Fatal: Setup program gives an unknown exitcode unequal zero: " + $ExitCode$
+				isFatalError
+			endif
+		endif
+	endif
+endif
+
diff --git a/LinLibertineOTF_5.1.3_2011_06_21.tgz.sha1sum b/LinLibertineOTF_5.1.3_2011_06_21.tgz.sha1sum
new file mode 100644
index 0000000..02fec7e
--- /dev/null
+++ b/LinLibertineOTF_5.1.3_2011_06_21.tgz.sha1sum
@@ -0,0 +1 @@
+aa91a7c079511907dbd59c90917d6b3396a36699  /usr/portage/distfiles/LinLibertineOTF_5.1.3_2011_06_21.tgz
diff --git a/OPSI/changelog.txt b/OPSI/changelog.txt
new file mode 100644
index 0000000..e69de29
diff --git a/OPSI/control b/OPSI/control
new file mode 100644
index 0000000..339e787
--- /dev/null
+++ b/OPSI/control
@@ -0,0 +1,33 @@
+[Package]
+version: RELEASE
+depends: 
+incremental: False
+
+[Product]
+type: localboot
+id: font-linux-libertine
+name: Linux Libertine Free Font
+description: Linux Libertine Free Font
+advice: ADVICE
+version: VERSION
+priority: PRIORITY
+
+licenseRequired: False
+productClasses: 
+setupScript: setup.ins
+uninstallScript: 
+updateScript: 
+alwaysScript: 
+onceScript: 
+customScript: 
+userLoginScript: 
+
+[ProductProperty]
+type: unicode
+name: install_architecture
+multivalue: False
+editable: False
+description: which architecture (32/64 bit) has to be installed
+values: ["32 only", "64 only", "both", "system specific"]
+default: ["system specific"]
+
diff --git a/OPSI/postinst b/OPSI/postinst
new file mode 100644
index 0000000..a8e33fc
--- /dev/null
+++ b/OPSI/postinst
@@ -0,0 +1,9 @@
+#! /bin/sh
+#
+# postinst script for softprod
+# This script executes after unpacking files from that archive and registering the product at the server.
+#
+# The following environment variables can be used to obtain information about the current installation:
+#   PRODUCT_ID: id of the current product
+#   CLIENT_DATA_DIR: directory which contains the installed client data
+#
diff --git a/OPSI/preinst b/OPSI/preinst
new file mode 100644
index 0000000..15a5320
--- /dev/null
+++ b/OPSI/preinst
@@ -0,0 +1,9 @@
+#! /bin/sh
+#
+# preinst script for softprod
+# This script executes before that package will be unpacked from its archive file.
+#
+# The following environment variables can be used to obtain information about the current installation:
+#   PRODUCT_ID: id of the current product
+#   CLIENT_DATA_DIR: directory where client data will be installed
+#
diff --git a/build.sh b/build.sh
new file mode 100644
index 0000000..ba176ad
--- /dev/null
+++ b/build.sh
@@ -0,0 +1,132 @@
+#!/bin/sh
+PN="font-linux-libertine"
+VERSION="1.5.3"
+RELEASE="1"
+PRIORITY="0"
+ADVICE=""
+TYPE="restrict"
+# all downloads should not have any traling parameters like ?downlaodid=1234 .....(should rewrite in python)
+ICON="http://fontaday.com/wp-content/uploads/2010/07/libertine.png"
+X86="http://code.kliu.org/misc/fontreg/fontreg-2.1.3-redist.7z"
+X86_1="http://sourceforge.net/projects/linuxlibertine/files/linuxlibertine/5.1.3-2/LinLibertineOTF_5.1.3_2011_06_21.tgz"
+#AMD64="http://downloads.sourceforge.net/sevenzip/7z920-x64.msi"
+ICONFILE=${ICON##*/}
+X86FILE=${X86##*/}
+X86FILE_1=${X86_1##*/}
+#AMD64FILE=${AMD64##*/}
+
+	if [ -e /var/tmp/opsi/upload/$TYPE/${PN}_${VERSION}-${RELEASE}.opsi ]
+	then
+		echo "package ${PN}_${VERSION}-${RELEASE}.opsi already generated"
+		exit 1
+	fi
+
+OUT=$(mktemp -d /tmp/output.XXXXXXXXXX) || { echo "Failed to create temp dir"; exit 1; }
+mkdir $OUT/$PN
+cp -Rv OPSI CLIENT_DATA $OUT/$PN
+unix2dos $OUT/$PN/CLIENT_DATA/*
+
+	if [ -e /usr/portage/distfiles/$ICONFILE ]
+	then
+		if [ -e $ICONFILE.sha1sum ]
+		then
+			SHA1SUM=`cat $ICONFILE.sha1sum`
+			CHECKSUM=`sha1sum /usr/portage/distfiles/$ICONFILE`
+			if [ "$CHECKSUM" = "$SHA1SUM" ]
+			then
+				convert -colorspace rgb /usr/portage/distfiles/$ICONFILE -transparent white -background transparent -resize 160x160\> \
+					-size 160x160 xc:transparent +swap -gravity center -composite $OUT/$PN/CLIENT_DATA/$PN.png
+			else
+				echo "The checksums do not match."
+				exit 1
+			fi
+		else
+			echo "You need to create the checksums with: sha1sum /usr/portage/distfiles/$ICONFILE > $ICONFILE.sha1sum"
+			exit 1
+		fi
+	else
+		echo "Downloading file"
+		wget -P /usr/portage/distfiles/ $ICON
+		exit 1
+	fi
+
+	if [ -e /usr/portage/distfiles/$X86FILE ]
+	then
+		if [ -e $X86FILE.sha1sum ]
+		then
+			SHA1SUM=`cat $X86FILE.sha1sum`
+			CHECKSUM=`sha1sum /usr/portage/distfiles/$X86FILE`
+			if [ "$CHECKSUM" = "$SHA1SUM" ]
+			then
+				mkdir -p $OUT/$PN/CLIENT_DATA/files
+				#cp /usr/portage/distfiles/$X86FILE $OUT/$PN/CLIENT_DATA/files
+				7z x -o$OUT/$PN/CLIENT_DATA/files /usr/portage/distfiles/$X86FILE
+				cp $OUT/$PN/CLIENT_DATA/files/bin.x86-32/FontReg.exe $OUT/$PN/CLIENT_DATA/files/FontReg32.exe
+				cp $OUT/$PN/CLIENT_DATA/files/bin.x86-64/FontReg.exe $OUT/$PN/CLIENT_DATA/files/FontReg64.exe
+			else
+				echo "The checksums do not match."
+				exit 1
+			fi
+		else
+			echo "You need to create the checksums with: sha1sum /usr/portage/distfiles/$X86FILE > $X86FILE.sha1sum"
+			exit 1
+		fi
+	else
+		echo "Downloading file"
+		wget -O /usr/portage/distfiles/$X86FILE $X86
+		#plowdown -o /usr/portage/distfiles $X86
+		exit 1
+	fi
+
+	if [ -e /usr/portage/distfiles/$X86FILE_1 ]
+	then
+		if [ -e $X86FILE_1.sha1sum ]
+		then
+			SHA1SUM=`cat $X86FILE_1.sha1sum`
+			CHECKSUM=`sha1sum /usr/portage/distfiles/$X86FILE_1`
+			if [ "$CHECKSUM" = "$SHA1SUM" ]
+			then
+				#cp /usr/portage/distfiles/$X86FILE $OUT/$PN/CLIENT_DATA
+				#mkdir -p $OUT/$PN/CLIENT_DATA/files
+				#7z e -o$OUT/$PN/CLIENT_DATA/files /usr/portage/distfiles/$X86FILE_1
+				tar xzvf /usr/portage/distfiles/$X86FILE_1 -C $OUT/$PN/CLIENT_DATA/files
+			else
+				echo "The checksums do not match."
+				exit 1
+			fi
+		else
+			echo "You need to create the checksums with: sha1sum /usr/portage/distfiles/$X86FILE_1 > $X86FILE_1.sha1sum"
+			exit 1
+		fi
+	else
+		echo "Downloading file"
+		wget -O /usr/portage/distfiles/$X86FILE_1 $X86_1
+		#plowdown -o /usr/portage/distfiles $X86
+		exit 1
+	fi
+
+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" -e "s!AMD64FILE!$AMD64FILE!g" -i $OUT/$PN/CLIENT_DATA/setup.ins
+#sed -e "s!X86FILE!$X86FILE!g" -i $OUT/$PN/CLIENT_DATA/setup32.ins
+
+if test -d ".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."
+    exit 1
+fi
+
+pushd $OUT
+opsi-makeproductfile -v $OUT/$PN
+popd
+
+mkdir -p /var/tmp/opsi/upload/$TYPE/
+cp -afv $OUT/*.opsi /var/tmp/opsi/upload/$TYPE/
+
+#rm -rf $OUT
+
diff --git a/fontreg-2.1.3-redist.7z.sha1sum b/fontreg-2.1.3-redist.7z.sha1sum
new file mode 100644
index 0000000..f18dbe6
--- /dev/null
+++ b/fontreg-2.1.3-redist.7z.sha1sum
@@ -0,0 +1 @@
+a7ded5853f8ea326e944fa111ab15da0fec4c023  /usr/portage/distfiles/fontreg-2.1.3-redist.7z
diff --git a/libertine.png.sha1sum b/libertine.png.sha1sum
new file mode 100644
index 0000000..1252e16
--- /dev/null
+++ b/libertine.png.sha1sum
@@ -0,0 +1 @@
+26acaf400c015b67c05b22864073c5e7625e7064  /usr/portage/distfiles/libertine.png