UUP converter 0.2.0

- Fixed some typos
- Fixed broken winre.wim adding
- Changed names of images shown in installer to better ones
- Changed ISO image names and labels to contain more information
This commit is contained in:
mkuba50 2018-12-26 00:37:10 +01:00
parent 4e043f4403
commit b3ec35a65c

View File

@ -1,7 +1,7 @@
#!/bin/bash #!/bin/bash
scriptName="UUP Converter v0.1.1" scriptName="UUP Converter v0.2.0"
editions="analogonecore editions='analogonecore
andromeda andromeda
cloude cloude
clouden clouden
@ -80,9 +80,9 @@ serverstorageworkgroupevalcore
serverweb serverweb
serverwebcore serverwebcore
starter starter
startern" startern'
bootSourcesList="sources/alert.gif bootSourcesList='sources/alert.gif
sources/api-ms-win-core-apiquery-l1-1-0.dll sources/api-ms-win-core-apiquery-l1-1-0.dll
sources/api-ms-win-downlevel-advapi32-l1-1-0.dll sources/api-ms-win-downlevel-advapi32-l1-1-0.dll
sources/api-ms-win-downlevel-advapi32-l1-1-1.dll sources/api-ms-win-downlevel-advapi32-l1-1-1.dll
@ -221,7 +221,7 @@ sources/..-.*/wdsclient.dll.mui
sources/..-.*/wdsimage.dll.mui sources/..-.*/wdsimage.dll.mui
sources/..-.*/wimprovider.dll.mui sources/..-.*/wimprovider.dll.mui
sources/..-.*/WinDlp.dll.mui sources/..-.*/WinDlp.dll.mui
sources/..-.*/winsetup.dll.mui" sources/..-.*/winsetup.dll.mui'
infoColor="\033[1;94m" infoColor="\033[1;94m"
errorColor="\033[1;91m" errorColor="\033[1;91m"
@ -305,9 +305,9 @@ fi
list= list=
lang=$(echo "$metadataFiles" | grep _..-.*.esd | head -1 | sed 's/.*_//g;s/.esd//g') lang=$(grep "_..-.*.esd" <<< "$metadataFiles" | head -1 | sed 's/.*_//g;s/.esd//g')
metadataFiles=$(echo "$metadataFiles" | grep "$lang" | sort | uniq) metadataFiles=$(grep "$lang" <<< "$metadataFiles" | sort | uniq)
firstMetadata=$(echo "$metadataFiles" | head -1) firstMetadata=$(head -1 <<< "$metadataFiles")
tempDir=`mktemp -d` tempDir=`mktemp -d`
extractDir="$tempDir/extract" extractDir="$tempDir/extract"
@ -354,7 +354,10 @@ fi
echo "" echo ""
echo -e "$infoColor""Exporting winre.wim...""$resetColor" echo -e "$infoColor""Exporting winre.wim...""$resetColor"
wimlib-imagex export "$firstMetadata" 2 "$tempDir/winre.wim" --compress=maximum --boot
wimlib-imagex export "$firstMetadata" 2 "$tempDir/winre.wim" \
--compress=maximum --boot
if [ $? != 0 ]; then if [ $? != 0 ]; then
echo -e "$errorColor""Failed to export winre.wim""$resetColor" echo -e "$errorColor""Failed to export winre.wim""$resetColor"
cleanup cleanup
@ -364,27 +367,48 @@ fi
echo "" echo ""
echo -e "$infoColor""Creating boot.wim...""$resetColor" echo -e "$infoColor""Creating boot.wim...""$resetColor"
cp "$tempDir/winre.wim" ISODIR/sources/boot.wim cp "$tempDir/winre.wim" ISODIR/sources/boot.wim
wimlib-imagex info ISODIR/sources/boot.wim 1 "Microsoft Windows PE" --image-property FLAGS=9 >/dev/null
wimlib-imagex extract ISODIR/sources/boot.wim 1 --dest-dir="$tempDir" "/Windows/System32/config/SOFTWARE" --no-acls >/dev/null wimlib-imagex info ISODIR/sources/boot.wim 1 "Microsoft Windows PE" \
--image-property FLAGS=9 >/dev/null
wimlib-imagex extract ISODIR/sources/boot.wim 1 --dest-dir="$tempDir" \
"/Windows/System32/config/SOFTWARE" --no-acls >/dev/null
if [ $? != 0 ]; then if [ $? != 0 ]; then
echo -e "$errorColor""Failed to extract registry""$resetColor" echo -e "$errorColor""Failed to extract registry""$resetColor"
cleanup cleanup
exit 1 exit 1
fi fi
echo -e "cd Microsoft\\Windows NT\\CurrentVersion\nnv 1 SystemRoot\ned SystemRoot\nX:\\\$Windows.~bt\\Windows\ncd WinPE\nnv 1 InstRoot\ned InstRoot\nX:\\\$Windows.~bt\nq\ny\n" | chntpw -e "$tempDir/SOFTWARE" >/dev/null echo 'cd Microsoft\Windows NT\CurrentVersion
wimlib-imagex update ISODIR/sources/boot.wim 1 --command "add $tempDir/SOFTWARE /Windows/System32/config/SOFTWARE" >/dev/null nv 1 SystemRoot
wimlib-imagex update ISODIR/sources/boot.wim 1 --command "delete /Windows/System32/winpeshl.ini" >/dev/null ed SystemRoot
X:\$Windows.~bt\Windows
cd WinPE
nv 1 InstRoot
ed InstRoot
X:\$Windows.~bt
q
y' | chntpw -e "$tempDir/SOFTWARE" >/dev/null
wimlib-imagex update ISODIR/sources/boot.wim 1 \
--command "add $tempDir/SOFTWARE /Windows/System32/config/SOFTWARE" >/dev/null
wimlib-imagex update ISODIR/sources/boot.wim 1 \
--command "delete /Windows/System32/winpeshl.ini" >/dev/null
wimlib-imagex export "$tempDir/winre.wim" 1 \
ISODIR/sources/boot.wim "Microsoft Windows Setup"
wimlib-imagex export "$tempDir/winre.wim" 1 ISODIR/sources/boot.wim "Microsoft Windows Setup"
if [ $? != 0 ]; then if [ $? != 0 ]; then
echo -e "$errorColor""Failed to create second index of boot.wim""$resetColor" echo -e "$errorColor""Failed to create second index of boot.wim""$resetColor"
cleanup cleanup
exit 1 exit 1
fi fi
wimlib-imagex extract "$firstMetadata" 3 "/Windows/System32/xmllite.dll" --no-acls --dest-dir="ISODIR/sources" >/dev/null wimlib-imagex extract "$firstMetadata" 3 "/Windows/System32/xmllite.dll" \
--no-acls --dest-dir="ISODIR/sources" >/dev/null
wimlib-imagex info ISODIR/sources/boot.wim 2 --image-property FLAGS=2 >/dev/null wimlib-imagex info ISODIR/sources/boot.wim 2 --image-property FLAGS=2 >/dev/null
wimlib-imagex info ISODIR/sources/boot.wim 2 --boot >/dev/null wimlib-imagex info ISODIR/sources/boot.wim 2 --boot >/dev/null
@ -405,7 +429,7 @@ done
wimlib-imagex update ISODIR/sources/boot.wim 2 <"$tempDir/update.txt" >/dev/null wimlib-imagex update ISODIR/sources/boot.wim 2 <"$tempDir/update.txt" >/dev/null
if [ $? != 0 ]; then if [ $? != 0 ]; then
echo -e "$errorColor""Failed add required files to second index of boot.wim""$resetColor" echo -e "$errorColor""Failed to add required files to second index of boot.wim""$resetColor"
cleanup cleanup
exit 1 exit 1
fi fi
@ -414,34 +438,65 @@ wimlib-imagex optimize ISODIR/sources/boot.wim
rm "ISODIR/sources/xmllite.dll" rm "ISODIR/sources/xmllite.dll"
echo "" echo ""
echo -e "$infoColor""Creating install.$type...""$resetColor" indexesExported=0
for metadata in $metadataFiles; do for metadata in $metadataFiles; do
metadataName=`basename $metadata .esd` currentInfo=`wimlib-imagex info "$metadata" 3`
echo -e "$infoColor""Exporting $metadataName...""$resetColor"
wimlib-imagex export "$metadata" 3 ISODIR/sources/install.$type "$metadataName" $compressParam --ref="$uupDir/*.esd" --ref "$tempDir/*.esd" currentEdition=`grep -i "^Edition ID:" <<< "$currentInfo" | sed "s/.* //g"`
editionName="Windows 10 $currentEdition"
echo -e "$infoColor""Exporting $editionName to install.$type...""$resetColor"
wimlib-imagex export "$metadata" 3 ISODIR/sources/install.$type \
"$editionName" $compressParam --ref="$uupDir/*.esd" --ref "$tempDir/*.esd"
if [ $? != 0 ]; then if [ $? != 0 ]; then
echo -e "$errorColor""Failed export index to install.$type""$resetColor" echo -e "$errorColor""Failed to export $editionName to install.$type""$resetColor"
cleanup cleanup
exit 1 exit 1
fi fi
let indexesExported++
echo "" echo ""
echo -e "$infoColor""Adding winre.wim for $metadataName...""$resetColor" echo -e "$infoColor""Adding winre.wim for $editionName...""$resetColor"
wimlib-imagex update ISODIR/sources/install.$type 1 --command "add $tempDir/winre.wim /Windows/System32/Recovery/winre.wim" wimlib-imagex update ISODIR/sources/install.$type $indexesExported \
--command "add $tempDir/winre.wim /Windows/System32/Recovery/winre.wim"
echo "" echo ""
done done
info=`wimlib-imagex info "$firstMetadata" 3` info=`wimlib-imagex info "$firstMetadata" 3`
major=`echo "$info" | grep -i "^Major Version:" | sed "s/.* //g"` build=`grep -i "^Build:" <<< "$info" | sed "s/.* //g"`
minor=`echo "$info" | grep -i "^Minor Version:" | sed "s/.* //g"` spbuild=`grep -i "^Service Pack Build:" <<< "$info" | sed "s/.* //g"`
build=`echo "$info" | grep -i "^Build:" | sed "s/.* //g"` arch=`grep -i "^Architecture:" <<< "$info" | sed "s/.* //g"`
spbuild=`echo "$info" | grep -i "^Service Pack Build:" | sed "s/.* //g"`
label="$major.$minor.$build.$spbuild""_$lang" if [ "$arch" == "x86_64" ]; then
arch="x64"
fi
if [ $indexesExported -gt 1 ]; then
isoEdition="MULTI"
else
isoEdition=`grep -i "^Edition ID:" <<< "$info" | sed "s/.* //g"`
fi
isoLabel=`tr "[:lower:]" "[:upper:]" <<< "${build}.${spbuild}_${arch}_${lang}"`
isoName=`tr "[:lower:]" "[:upper:]" <<< "${build}.${spbuild}_${isoEdition}_${arch}_${lang}.iso"`
if [ -e "$isoName" ]; then
rm "$isoName"
fi
echo -e "$infoColor""Creating ISO image...""$resetColor" echo -e "$infoColor""Creating ISO image...""$resetColor"
genisoimage -b "boot/etfsboot.com" --no-emul-boot --eltorito-alt-boot -e "efi/microsoft/boot/efisys.bin" --no-emul-boot --udf --hide "*" -V "$label" -o "$label.iso" ISODIR find ISODIR -exec touch {} +
genisoimage -b "boot/etfsboot.com" --no-emul-boot \
--eltorito-alt-boot -e "efi/microsoft/boot/efisys.bin" --no-emul-boot \
--udf --hide "*" -V "$isoLabel" -o "$isoName" ISODIR
if [ $? != 0 ]; then if [ $? != 0 ]; then
echo -e "$errorColor""Failed to create ISO""$resetColor" echo -e "$errorColor""Failed to create ISO image""$resetColor"
cleanup cleanup
exit 1 exit 1
fi fi