2008-02-25 16:07:48 +00:00
if grep n8r /proc/cmdline > /dev/null 2>&1;
2007-10-26 22:44:33 +00:00
then
stty crtscts
fi
for x in 0 1 2 3 4 5 6 7 8
do
mknod /dev/vcs$x c 7 $x
mknod /dev/vcsa$x c 7 $[$x+128]
done
chmod 644 /dev/vcs*
chown root /dev/vcs*
2012-04-11 13:39:51 +00:00
if [ -r /tmp/updates/etc/pki/tls/certs/ca-bundle.crt ]; then
cp -f /tmp/updates/etc/pki/tls/certs/ca-bundle.crt /etc/pki/tls/certs/
fi
2013-09-13 07:16:13 -07:00
2014-05-09 02:02:45 -07:00
#there is no boot option to set dns search domain in kickstart file,
#the search domain in /etc/resolv.conf is set in the pre installation script
export MANAGEDADDRESSMODE=#MANAGEDADDRESSMODE#
export SEARCHDOMAIN=#GETNODEDOMAIN:THISNODE#
if [ "$MANAGEDADDRESSMODE" == "static" ]; then
echo "#appended by %pre " >> /etc/resolv.conf
echo "search $SEARCHDOMAIN" >> /etc/resolv.conf
fi
2013-09-13 07:16:13 -07:00
2013-08-15 20:18:47 -07:00
cat >/tmp/baz.py <<EOF
#!/usr/bin/python
import socket
import sys
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
sock.connect(('#XCATVAR:XCATMASTER#',#TABLE:site:key=xcatiport:value#))
print sys.argv[1]
response = sock.recv(100)
if(response == "ready\n"):
sock.send(sys.argv[1]+"\n")
response = sock.recv(100)
sock.close()
EOF
2007-10-26 22:44:33 +00:00
cat >/tmp/foo.py <<EOF
#!/usr/bin/python
import socket
import os
import linecache
import re
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
sock.connect(('#XCATVAR:XCATMASTER#',#TABLE:site:key=xcatiport:value#))
response = sock.recv(100)
if(response == "ready\n"):
sock.send("installmonitor\n")
response = sock.recv(100)
sock.close()
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
sock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
port = 3001
sock.bind(('', port))
sock.listen(5)
try:
while 1:
newSocket, address = sock.accept()
while 1:
received = newSocket.recv(200)
if not received:
break
command = re.split('\s+',received)
if(command[0] == "stat"):
ilog = ""
firstline = ""
line = ""
post = 0
percent = 0
count = 0
numpack = 0
2014-02-10 13:59:14 -05:00
if(os.path.isfile('/tmp/packaging.log')):
ilog = '/tmp/packaging.log'
2007-10-26 22:44:33 +00:00
if(os.path.isfile('/mnt/sysimage/root/install.log')):
ilog = '/mnt/sysimage/root/install.log'
if(os.path.isfile('/mnt/sysimage/tmp/install.log')):
ilog = '/mnt/sysimage/tmp/install.log'
if(os.path.isfile('/mnt/sysimage/root/post.log')):
ilog = '/mnt/sysimage/root/post.log'
post = 1
if(ilog):
count = len(open(ilog).readlines())
firstline = linecache.getline(ilog,1)
line = linecache.getline(ilog,count)
linecache.clearcache()
if(line and not post):
r1 = re.compile("^Installing (\d+) ")
m1 = r1.search(firstline)
if m1:
numpack = int(m1.group(1))
if(numpack > 0):
percent = int(((count - 2) * 100)/numpack + .5)
if(percent > 100):
percent = 100
if(percent < 0):
percent = 0
r2 = re.compile("^Installing (.*)\.")
m2 = r2.search(line)
if m2:
newline = m2.group(1)
newline = newline + " ("
newline = newline + str(percent)
newline = newline + "%)"
# newline = newline + " ["
# count = count - 2
# newline = newline + str(count)
# newline = newline + "/"
# newline = newline + str(numpack)
# newline = newline + "]"
else:
newline = "prep"
line = "installing " + newline
if(line and post):
line = "installing " + line
if(not line):
line = "installing prep"
newSocket.send(line)
break
# if(command[0] == "sh"): #DEBUG purposes only, wide open root priv command here.
# newcommand = ""
# for i in command[1:]:
# newcommand = newcommand + i + " "
# output = os.popen(newcommand).read()
# newSocket.send(output)
# break
if(command[0] == "screendump"):
newcommand = "cat /dev/vcs"
for i in command[1:]:
newcommand = newcommand + i
output = os.popen(newcommand).read()
newSocket.send(output)
break
newSocket.close()
finally:
sock.close()
EOF
chmod 755 /tmp/foo.py
2013-08-15 20:18:47 -07:00
chmod 755 /tmp/baz.py
NODESTATUS=#TABLEBLANKOKAY:site:key=nodestatus:value#
if [ -z "$NODESTATUS" ] || [ "$NODESTATUS" != "0" -a "$NODESTATUS" != "N" -a "$NODESTATUS" != "n" ]; then
/tmp/baz.py "installstatus installing" &
fi
2007-10-26 22:44:33 +00:00
2013-09-13 07:16:13 -07:00
2007-10-26 22:44:33 +00:00
/tmp/foo.py >/foo.log 2>&1 &
2013-09-13 07:16:13 -07:00
2011-09-20 15:51:01 +00:00
#time to ascertain fstype and PReP/UEFI/legacy
2012-04-26 18:41:18 +00:00
#also, find first available block device (sda or vda likely)
#TODO: pick a likely non-SAN target if possible
shopt -s nullglob
for disk in /dev/vd*[^0-9];do
if [ -z "$firstdirectdisk" ]; then firstdirectdisk=$disk; fi #remember first disk as a guess of medium resort
eddname=$(/lib/udev/edd_id $disk 2> /dev/null)
if [ ! -z "$eddname" -a "$eddname" = "int13_dev80" ]; then
instdisk=$disk
break
fi
done
2013-09-13 07:16:13 -07:00
2012-04-26 18:41:18 +00:00
if [ -z "$instdisk" ]; then
for disk in /dev/sd*[^0-9]; do
eddname=$(/lib/udev/edd_id $disk 2> /dev/null)
if [ ! -z "$eddname" -a "$eddname" = "int13_dev80" ]; then
instdisk=$disk
break
fi
currdriver=`udevadm info --attribute-walk --name $disk |grep DRIVERS|grep -v '""'|grep -v '"sd"'|head -n 1|sed -e 's/[^"]*"//' -e 's/"//'`
case "$currdriver" in
"ata_piix4"|"PMC MaxRAID"|"ahci"|"megaraid_sas") #certainly direct
if [ -z "$firstdirectdisk" ]; then firstdirectdisk=$disk; fi #remember first disk as a guess of medium resort
;;
2014-04-18 10:50:58 -04:00
"mptsas"|"mpt2sas"|"mpt3sas") #*PROBABLY* not SAN, but SAS SAN is possible
2012-04-26 18:41:18 +00:00
if [ -z "$probablyfirstdirectdisk" ]; then probablyfirstdirectdisk=$disk; fi #remember first disk as a guess of medium resort
;;
*)
if [ -z "$firstdisk" ]; then firstdisk=$disk; fi #remember first disk as a guess of medium resort
;;
esac
done
fi
2013-09-13 07:16:13 -07:00
2012-04-26 18:41:18 +00:00
if [ -z "$instdisk" ]; then
if [ ! -z "$firstdirectdisk" ]; then
instdisk=$firstdirectdisk
elif [ ! -z "$probablyfirstdirectdisk" ]; then
instdisk=$probablyfirstdirectdisk
elif [ ! -z "$firstdisk" ]; then
instdisk=$firstdisk
fi
fi
2011-09-20 16:03:43 +00:00
modprobe ext4 >& /dev/null
modprobe ext4dev >& /dev/null
2011-09-20 15:51:01 +00:00
if grep ext4dev /proc/filesystems > /dev/null; then
FSTYPE=ext3
elif grep ext4 /proc/filesystems > /dev/null; then
FSTYPE=ext4
else
FSTYPE=ext3
fi
2014-06-02 13:33:57 -04:00
BOOTFSTYPE=ext3
EFIFSTYPE=vfat
if uname -r|grep ^3.*el7 > /dev/null; then
FSTYPE=xfs
BOOTFSTYPE=xfs
EFIFSTYPE=efi
fi
2013-09-13 07:16:13 -07:00
2011-09-20 15:51:01 +00:00
if [ `uname -m` = "ppc64" ]; then
2012-06-05 13:42:40 +00:00
echo 'part None --fstype "PPC PReP Boot" --ondisk '$instdisk' --size 8' >> /tmp/partitioning
2011-09-20 15:51:01 +00:00
fi
if [ -d /sys/firmware/efi ]; then
2014-04-11 11:27:13 -04:00
echo 'bootloader --driveorder='$instdisk >> /tmp/partitioning
2014-06-02 13:33:57 -04:00
echo 'part /boot/efi --size 50 --ondisk '$instdisk' --fstype $EFIFSTYPE' >> /tmp/partitioning
2014-04-11 11:27:13 -04:00
else
echo 'bootloader' >> /tmp/partitioning
2011-09-20 15:51:01 +00:00
fi
2011-11-17 20:56:23 +00:00
2011-09-20 15:51:01 +00:00
#TODO: ondisk detection, /dev/disk/by-id/edd-int13_dev80 for legacy maybe, and no idea about efi. at least maybe blacklist SAN if mptsas/mpt2sas/megaraid_sas seen...
2014-06-02 13:33:57 -04:00
echo "part /boot --size 256 --fstype $BOOTFSTYPE --ondisk $instdisk" >> /tmp/partitioning
2012-04-26 18:41:18 +00:00
echo "part swap --recommended --ondisk $instdisk" >> /tmp/partitioning
echo "part / --size 1 --grow --ondisk $instdisk --fstype $FSTYPE" >> /tmp/partitioning
2011-09-20 15:51:01 +00:00
2012-06-25 13:39:15 +00:00
#XCA_PARTITION_SCRIPT#
2013-05-31 08:51:20 +00:00
2013-09-13 07:16:13 -07:00
2013-05-31 08:51:20 +00:00
# The following code is to generate the repository for the installation
cat /proc/cmdline
2013-09-13 07:16:13 -07:00
NEXTSERVER=`cat /proc/cmdline | grep http | head -n 1`
NEXTSERVER=${NEXTSERVER#*http://}
NEXTSERVER=${NEXTSERVER%%:*}
export nextserver=$NEXTSERVER
2013-05-31 08:51:20 +00:00
#INSTALL_SOURCES_IN_PRE#
2013-09-13 07:16:13 -07:00