X-Git-Url: https://piware.de/gitweb/?a=blobdiff_plain;f=postinst-setup;h=1d39d99bb9f425dd4195f5adf0b3ba45d9690846;hb=f43cdf08b7615b830c4375dd4fbe716df9044b25;hp=f743683ad66e0e9050d979c72a33c1c22e46ee54;hpb=d44e342acbd35783d666ae3e005d1843f42545b8;p=bin.git diff --git a/postinst-setup b/postinst-setup index f743683..1d39d99 100755 --- a/postinst-setup +++ b/postinst-setup @@ -1,62 +1,60 @@ #!/bin/sh -e +# move backup to /var +if [ -d /home/martin/backup ] && [ ! -d /var/backups/martin ]; then + cp -a /home/martin/backup /var/backups/martin + rm -rf /home/martin/backup +fi + # install already shipped debs [ -e /mirror ] || ln -s /home/ubuntu-mirror /mirror -mount -o loop /home/martin/download/ubuntu/feisty-alternate-amd64.iso /cdrom +mount -o loop /home/martin/download/ubuntu/gutsy-alternate-amd64.iso /cdrom apt-cdrom -m add -DEBIAN_FRONTEND=noninteractive apt-get -y install build-essential fakeroot devscripts mutt postfix openssh-server +DEBIAN_FRONTEND=noninteractive apt-get -y install build-essential fakeroot devscripts postfix openssh-server bzr -dpkg -i ~martin/download/afio*.deb || exit 1 - -# configuration files -mkdir -p /var/backups/pibackup/ -[ -e /home/full*.cpio ] && mv /home/full*.cpio /var/backups/pibackup/ || true +# root's ssh stuff +if [ ! -d /root/ssh ]; then + mkdir -p /root/.ssh + chmod 700 /root/.ssh + cp /home/martin/.ssh/id_dsa* /home/martin/.ssh/known_hosts /home/martin/.ssh/config /root/.ssh/ +fi -CURBACKUP=`ls -t /var/backups/pibackup/full* | head -n 1` -[ -e "$CURBACKUP" ] || { - echo no current full backup in /var/backups/pibackup - exit 1 -} -cd / -afio -iZ -y '/etc/*' -Y /etc/passwd -Y /etc/group -Y /etc/shadow -Y /etc/fstab $CURBACKUP +# restore /etc bzr branch, rescue the files we do not want to restore +# completely +cd /etc +if [ ! -d /etc/.bzr ]; then + for i in passwd group shadow fstab; do + cp $i $i.originst + done + bzr get bzr+ssh://martin@piware.de/home/martin/backup/desktop-etc /desktop-etc + cp -av /desktop-etc/* /etc/ + cp -av /desktop-etc/.bzr/ /etc/ + rm -rf /desktop-etc + chmod 600 /etc/ssh/ssh_*_key +fi # only restore dchroot part into fstab -cd /tmp -afio -iZ -y /etc/fstab $CURBACKUP -grep -A 200 "^# dchroots" /tmp/etc/fstab >> /etc/fstab -rm -rf /tmp/etc +grep -A 200 "^# dchroots" fstab >> fstab.originst +mv fstab.originst fstab -newaliases -/etc/init.d/postfix restart - -# install users -cat <> /etc/passwd -joe:x:1001:1001:Joe User,,,:/home/joe:/bin/bash -netti:x:1002:1002:Annett Kittel,,,:/home/netti:/bin/bash -EOF -cat <> /etc/shadow -joe:$1$7t1pZTyL$lI7.B/9DtPa6y2BD8wTNZ/:13060:0:99999:7::: -netti:$1$5uq6X7u0$92yOfMH2Nh89Ui.hbaEDp/:12930:0:99999:7::: -EOF -cat <> /etc/group -joe:x:1001: -netti:x:1002: -EOF - -for g in cdrom audio video plugdev scanner; do - for u in joe netti; do - adduser $u $g - done +# only restore the human users from passwd/group +for i in passwd group; do + perl -naF: -e 'print if $F[2] >= 1000 && $F[2] < 60000' $i >> $i.originst + mv $i.originst $i done -# root's ssh stuff -mkdir -p /root/.ssh -chmod 700 /root/.ssh -cp /home/martin/.ssh/id_dsa* /home/martin/.ssh/known_hosts /home/martin/.ssh/config /root/.ssh/ +# only restore some passwords from shadow +egrep 'martin|netti|test|joe' shadow >> shadow.originst +mv shadow.originst shadow + +# update postfix for new configuration +newaliases +/etc/init.d/postfix restart # copy apt cache if [ -d /home/aptcache ]; then find /home/aptcache/ -name "*.deb" -exec cp '{}' /var/cache/apt/archives/ \; + rm -rf /home/aptcache fi # other setup @@ -75,14 +73,26 @@ rm /etc/rcS.d/*pcmcia* /etc/rcS.d/*ppp* ifdown eth0 || true ifup eth0 +# cronjob goo +killall apt-get || true + # install packages from network sources apt-get update -o Acquire::Http::No-Cache=true -DEBIAN_FRONTEND=noninteractive apt-get install -y --force-yes vim bzr bzrtools python-paramiko patchutils offlineimap wipe gnome-gpg diffstat dchroot gtimelog pibackup jigdo-file libtool devhelp python-doc perl-doc manpages-dev gstreamer0.10-plugins-ugly gstreamer0.10-plugins-bad gstreamer0.10-plugins-bad-multiverse gstreamer0.10-plugins-ugly-multiverse gstreamer0.10-ffmpeg xchat debmirror dpatch wdiff dhcp3-server grep-dctrl ccache subversion listadmin ia32-libs quilt apache2 python-dev cryptsetup -apt-get -y build-dep postgresql-8.1 gnome-volume-manager hal pmount cupsys +DEBIAN_FRONTEND=noninteractive apt-get install -y --force-yes vim bzrtools python-paramiko patchutils offlineimap wipe gnome-gpg diffstat dchroot gtimelog rsnapshot jigdo-file libtool devhelp python-doc manpages-dev gstreamer0.10-plugins-ugly gstreamer0.10-plugins-bad gstreamer0.10-plugins-bad-multiverse gstreamer0.10-plugins-ugly-multiverse gstreamer0.10-ffmpeg xchat debmirror dpatch wdiff dhcp3-server grep-dctrl ccache subversion listadmin quilt apache2 python-dev cryptsetup mutt editmoin lintian ia32-libs splix easytag latex-beamer python-gtk2-doc +apt-get -y build-dep postgresql-8.2 gnome-volume-manager hal cupsys apport restricted-manager + +umount /cdrom # other setup ln -s /mirror /var/www/mirror ifdown eth1 ifup eth1 /etc/init.d/dhcp3-server restart +patch /usr/bin/gtimelog ~martin/archiv/gtimelog.wednesday.patch + +# crontabs +crontab -u martin - </dev/null +EOF