forked from puppetlabs-toy-chest/razor-el-mk
-
Notifications
You must be signed in to change notification settings - Fork 0
/
microkernel.ks
213 lines (182 loc) · 5.94 KB
/
microkernel.ks
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
# Kickstart file to build a small Fedora image
# This is based on the work at http://www.thincrust.net
# Also based on https://git.fedorahosted.org/cgit/cloud-kickstarts.git/tree/container/container-small-19.ks
lang en_US.UTF-8
keyboard us
timezone --utc Etc/UTC
auth --useshadow --enablemd5
selinux --permissive
bootloader --timeout=1 --append="acpi=force"
services --enabled=NetworkManager
# Uncomment the next line
# to make the root password be thincrust
# By default the root password is emptied
rootpw --iscrypted $1$uw6MV$m6VtUWPed4SqgoW6fKfTZ/
#
# Partition Information. Change this as necessary
# This information is used by appliance-tools but
# not by the livecd tools.
#
part / --size 4096 --fstype ext4 --ondisk sda
#
# Repositories
#
repo --name=base --mirrorlist=http://mirrorlist.centos.org/?release=7&arch=$basearch&repo=os
repo --name=updates --mirrorlist=http://mirrorlist.centos.org/?release=7&arch=$basearch&repo=updates
repo --name=puppetlabs-products --baseurl=http://yum.puppetlabs.com/el/7/products/$basearch
repo --name=puppetlabs-deps --baseurl=http://yum.puppetlabs.com/el/7/dependencies/$basearch
repo --name=elrepo --baseurl=http://elrepo.org/linux/elrepo/el7/$basearch/
repo --name=elrepo-kernel --baseurl=http://elrepo.org/linux/kernel/el7/$basearch/
#
# Add all the packages after the base packages
#
%packages --excludedocs --nobase
bash
kernel-ml
grub2
e2fsprogs
passwd
policycoreutils
chkconfig
rootfiles
yum
vim-minimal
acpid
tar
# RAZOR-145 Add dmidecode for facter support
dmidecode
# Additional dependency for facter support
virt-what
# Only needed because livecd-tools runs /usr/bin/firewall-offline-cmd
# unconditionally; patch submitted upstream. Remove once released version
# with it is available
firewalld
# SSH access
openssh-clients
openssh-server
# In order to have network connections managed effectively, we use
# NetworkManager. This is ~ 5.9MB of space in the image, but it also means
# that we are (A) using the recommended and default upstream configuration,
# and (B) no longer responsible for doing all the network management
# ourselves. This is, overall, a big win for everyone.
#
# Also, this opens the door to allowing for more complex configurations such
# as 802.1x secured network links, VPN connectivity for communication with the
# host, and so forth -- should we decide we need it.
#
# Ultimately, though, that as the upstream project write:
#
# "Fedora now by default relies on NetworkManager for network
# configuration. This is the case also for minimal installations and server
# installations. We are trying to make NetworkManager as suitable for this
# task as possible."
#
# I hope that doesn't offend. Dropping this in just works! --daniel 2013-11-07
NetworkManager
# Used to update code at runtime
unzip
# Enable stripping
binutils
# We need a ruby env and all of facter's dependencies fulfilled
rubygems
facter
net-tools
dhcp-libs
dhcp-common
dhclient
#
# Packages to Remove
#
-prelink
-setserial
-ed
# Remove the authconfig pieces
-authconfig
-passwd
# Remove the kbd bits
-kbd
-usermode
# file system stuff
-kpartx
-dmraid
-mdadm
-lvm2
-e2fsprogs
-e2fsprogs-libs
# grub
-freetype
-grub2
-grub2-tools
-grubby
-os-prober
# selinux toolchain of policycoreutils, libsemanage, ustr
-policycoreutils
-checkpolicy
-selinux-policy*
-libselinux-python
-libselinux
%end
# Install the microkernel agent
%include mk-install.ks
# Try to minimize the image a bit
%post
# ensure we don't have the same random seed on every image, which
# could be bad for security at a later point...
echo " * purge existing random seed to avoid identical seeds everywhere"
rm -f /var/lib/random-seed
# I can't tell if this should force a new SSH key, or force a fixed one,
# but for now we can ensure that we generate new keys when SSHD is finally
# fined up on the nodes...
#
# We also disable SSHd automatic startup in the final image.
echo " * disable sshd and purge existing SSH host keys"
rm -f /etc/ssh/ssh_host_*key{,.pub}
systemctl disable sshd.service
echo " * removing python precompiled *.pyc files"
find /usr/lib64/python*/ -name *pyc -print0 | xargs -0 rm -f
# This seems to cause 'reboot' resulting in a shutdown on certain platforms
# See https://tickets.puppetlabs.com/browse/RAZOR-100
echo " * disable the mei_me module"
mkdir -p /etc/modprobe.d
cat > /etc/modprobe.d/mei.conf <<EOMEI
blacklist mei_me
install mei_me /bin/true
blacklist mei
install mei /bin/true
EOMEI
echo " * removing trusted CA certificates"
truncate -s0 /usr/share/pki/ca-trust-source/ca-bundle.trust.crt
update-ca-trust
echo " * compressing cracklib dictionary"
gzip -9 /usr/share/cracklib/pw_dict.pwd
echo " * setting up journald and tty2"
echo "SystemMaxUse=15M" >> /etc/systemd/journald.conf
echo "ForwardToSyslog=no" >> /etc/systemd/journald.conf
echo "ForwardToConsole=yes" >> /etc/systemd/journald.conf
echo "TTYPath=/dev/tty2" >> /etc/systemd/journald.conf
# 100MB of locale archive is kind unnecessary; we only do en_US.utf8
# this will clear out everything we don't need; 100MB => 2.1MB.
echo " * minimizing locale-archive binary / memory size"
localedef --list-archive | grep -iv 'en_US' | xargs localedef -v --delete-from-archive
mv /usr/lib/locale/locale-archive /usr/lib/locale/locale-archive.tmpl
/usr/sbin/build-locale-archive
# remove things only needed during the build process
echo " * purging packages needed only during build"
yum -C -y --setopt="clean_requirements_on_remove=1" erase \
syslinux mtools acl ebtables firewalld libselinux-python \
python-decorator dracut hardlink kpartx passwd
echo " * purging all other locale data"
rm -rf /usr/share/locale/*
echo " * cleaning up yum cache, etc"
yum clean all
echo " * truncating various logfiles"
for log in yum.log dracut.log lastlog yum.log; do
truncate -c -s 0 /var/log/${log}
done
echo " * removing /boot, since that lives on the ISO side"
rm -rf /boot/*
%end
%post --nochroot
echo " * disquieting the microkernel boot process"
sed -i -e's/ rhgb//g' -e's/ quiet//g' $LIVE_ROOT/isolinux/isolinux.cfg
%end