[164] | 1 | #!/usr/bin/perl -w
|
---|
[153] | 2 |
|
---|
| 3 | # Script to be used as pbscript to create a potentialy
|
---|
| 4 | # missing pb account on the QEMU VM, and adds it to sudo
|
---|
[166] | 5 |
|
---|
| 6 | # Needs to be extented with the pb Distribution.pm module at the end externally
|
---|
[153] | 7 | #
|
---|
[163] | 8 | # Needs to use root account to connect to the VM
|
---|
[153] | 9 |
|
---|
| 10 | # You need to specify here your local public SSH key used to access
|
---|
| 11 | # the pb account in the VM later on
|
---|
| 12 |
|
---|
[164] | 13 | use strict;
|
---|
| 14 | use File::Basename;
|
---|
[153] | 15 |
|
---|
[164] | 16 | my $file = "/tmp/pbkey";
|
---|
[153] | 17 |
|
---|
[164] | 18 | open(PBFILE,"> $file") || die "Unable to open $file";
|
---|
| 19 | print PBFILE "ssh-dss AAAAB3NzaC1kc3MAAACBAMC06bNLMu8ZBJv3Hi77+fi+GUhtQScIbGKru86C/IP27EjrmYhPVccbu8kpX6SDHIouhpZ00gaefP3zHjLUmPKlXkMNUNjxx5JNLPoHhSIuUvoSTNoh9gsi31abAvzbW+RNer7rvBJO4ytNJRdsuNxBwqjxK04JEmatds+aKTQjAAAAFQDHaNmIuvYZ0RtNBVe+tzTzxxCQmQAAAIA4o89Xob2VBRtQKBjmWVAuTS14qiqnQUPNloaRkM+r2odI+NJDFc+WXOIG9QAPKKt1jvFOBOX9Mu3/xwiDLnAGhxud98FoyHevSpIWUld7rG4j1aww1WxolFWY/iPyAvDDMW3iysCoqQeSOlpRd9Mz/dq6/P/VcizhdGOKyc3JBgAAAIAA1eY+BoneiQ/tQ8j3GYbMTu6U7VzZ2OaoVeQn4NtZmPl+ZeQIj83nFpo99mYCbaBPqnZToERndl+ljp/JX5pamwj6RcLIDCyiB6MXLbQSWj0goegU1htp5aMd3NcyR2Jy8gCnf0QjDr7j23Q+CFGExtRb/nsDmaG5W9D6QSWQ/g== bruno\@victoria\n";
|
---|
| 20 | close(PBFILE);
|
---|
| 21 | chmod 0644,$file;
|
---|
| 22 |
|
---|
| 23 | $file="/etc/passwd";
|
---|
| 24 | open(PBFILE,$file) || die "Unable to open $file";
|
---|
| 25 | my $found = 0;
|
---|
| 26 | while (<PBFILE>) {
|
---|
| 27 | $found = 1 if (/^pb:/);
|
---|
| 28 | }
|
---|
| 29 | close(PBFILE);
|
---|
| 30 |
|
---|
| 31 | if ( $found == 0 ) {
|
---|
| 32 | if ( ! -d "/home" ) {
|
---|
| 33 | mkdir "/home";
|
---|
| 34 | }
|
---|
[176] | 35 | system "groupadd pb";
|
---|
[179] | 36 | system "useradd pb -g pb -m -d /home/pb";
|
---|
[164] | 37 | }
|
---|
| 38 |
|
---|
[203] | 39 | # For root
|
---|
| 40 | mkdir ".ssh",0700;
|
---|
| 41 | system 'cp /tmp/pbkey .ssh/authorized_keys';
|
---|
| 42 | chmod 0600,".ssh/authorized_keys";
|
---|
| 43 |
|
---|
| 44 | # For pb
|
---|
[171] | 45 | chdir "/home/pb";
|
---|
| 46 | mkdir ".ssh",0700;
|
---|
| 47 | system 'cp /tmp/pbkey .ssh/authorized_keys';
|
---|
| 48 | chmod 0600,".ssh/authorized_keys";
|
---|
| 49 | system 'chown -R pb:pb .ssh';
|
---|
| 50 |
|
---|
[153] | 51 | # No passwd for pb only keys
|
---|
[164] | 52 | $file="/etc/shadow";
|
---|
| 53 | open(PBFILE,$file) || die "Unable to open $file";
|
---|
[166] | 54 | open(PBOUT,"> $file.new") || die "Unable to open $file.new";
|
---|
[164] | 55 | while (<PBFILE>) {
|
---|
| 56 | s/^pb:\!\!:/pb:*:/;
|
---|
[185] | 57 | s/^pb:\!:/pb:*:/; #SLES 9 e.g.
|
---|
[166] | 58 | print PBOUT $_;
|
---|
[164] | 59 | }
|
---|
| 60 | close(PBFILE);
|
---|
[166] | 61 | close(PBOUT);
|
---|
| 62 | rename("$file.new",$file);
|
---|
[167] | 63 | chmod 0640,$file;
|
---|
[164] | 64 |
|
---|
[295] | 65 | # pb has to be added to portage group on gentoo
|
---|
| 66 |
|
---|
[164] | 67 | unlink "/tmp/pbkey";
|
---|
| 68 |
|
---|
| 69 | my ($ddir, $dver, $dfam, $dtype, $pbsuf) = pb_distro_init();
|
---|
[176] | 70 | print "distro tuple: ".join(',',($ddir, $dver, $dfam, $dtype, $pbsuf))."\n";
|
---|
[164] | 71 |
|
---|
[158] | 72 | # Get and install pb
|
---|
[164] | 73 | if ( $ddir eq "fedora" ) {
|
---|
| 74 | system "yum clean all";
|
---|
[169] | 75 | system "yum update -y";
|
---|
| 76 | my $arch=`uname -m`;
|
---|
| 77 | my $opt = "";
|
---|
| 78 | chomp($arch);
|
---|
| 79 | if ($arch eq "x86_64") {
|
---|
| 80 | $opt="--exclude=*.i?86";
|
---|
| 81 | }
|
---|
[171] | 82 |
|
---|
[226] | 83 | #my $topbuilddir=`rpmquery --eval '%{_topdir}' 2> /dev/null`;
|
---|
| 84 | #chomp($topbuilddir);
|
---|
[171] | 85 |
|
---|
[311] | 86 | system "yum -y $opt install neon newt-devel slang-devel autoconf automake libtool gcc rpm-build wget gcc-c++ docbook-utils-pdf ImageMagick man patch cdrecord mkisofs ntp sudo perl-DateManip perl-ExtUtils-MakeMaker";
|
---|
[181] | 87 | } elsif (( $dfam eq "rh" ) || ($ddir eq "sles") || (($ddir eq "suse") && (($dver eq "10.1") || ($dver eq "10.0"))) || (($ddir eq "mandrake") && ($dver eq "10.1"))) {
|
---|
[175] | 88 | # Suppose pkg are installed already
|
---|
[200] | 89 | system "rpm -e lsb 2>&1 > /dev/null";
|
---|
[291] | 90 | system "rm -rf DateManip* ; wget http://search.cpan.org/CPAN/authors/id/S/SB/SBECK/Date-Manip-5.46.tar.gz ; tar xvfz Date-Manip-5.46.tar.gz ; cd Date-Manip* ; perl Makefile.PL ; make ; make install ; cd .. ";
|
---|
[191] | 91 | } elsif ($ddir eq "suse") {
|
---|
| 92 | # New OpenSuSE
|
---|
[291] | 93 | system "export TERM=linux ; liste=\"\" ; for i in neon newt-devel slang-devel autoconf automake libtool make gcc wget gcc-c++ docbook-utils ImageMagick man patch mkisofs sudo perl-DateManip perl-File-HomeDir xntp; do rpm -q \$i 1> /dev/null 2> /dev/null ; if [ \$\? != 0 ]; then liste=\"\$liste \$i\"; fi; done; echo \"Liste: \$liste\" ; if [ \"\$liste\" != \"\" ]; then yast2 -i \$liste ; fi";
|
---|
[164] | 94 | } elsif ( $dfam eq "md" ) {
|
---|
[175] | 95 | if (( $dver eq "2006.0" ) || ( $dver eq "10.2" )) {
|
---|
[171] | 96 | # mondo not available
|
---|
[291] | 97 | system "urpmi.update -a ; urpmi --auto neon newt-devel slang-devel glibc-static-devel autoconf automake libtool gcc rpm-build wget gcc-c++ docbook-utils-pdf ImageMagick sudo man patch mkisofs cdrecord ntp-client perl-DateManip";
|
---|
[171] | 98 | } else {
|
---|
[291] | 99 | system "urpmi.update -a ; urpmi --auto neon newt-devel slang-devel glibc-static-devel autoconf automake libtool gcc rpm-build wget gcc-c++ sudo docbook-utils-pdf ImageMagick man patch mondo mkisofs cdrecord ntp-client perl-DateManip";
|
---|
[171] | 100 | }
|
---|
[164] | 101 | } elsif ( $dfam eq "du" ) {
|
---|
[203] | 102 | if (( $dver eq "3.1" ) && ($ddir eq "debian")) {
|
---|
[291] | 103 | system "apt-get update; apt-get -y install autoconf automake libtool g++ wget patch mondo groff imagemagick docbook-utils docbook2x docbook-to-man ssh dpkg-dev sudo debian-builder dh-make fakeroot libnewt-dev ntpdate libncurses5-dev libdate-manip-perl";
|
---|
[268] | 104 | } elsif (( $dver eq "7.10" ) && ($ddir eq "ubuntu")) {
|
---|
[291] | 105 | system "apt-get update; apt-get -y install autoconf automake libtool g++ wget patch groff imagemagick docbook-utils docbook2x docbook-to-man openssh-server dpkg-dev sudo debian-builder dh-make fakeroot libnewt-dev ntpdate libncurses5-dev libdate-manip-perl wodim genisoimage afio buffer";
|
---|
[268] | 106 | } else {
|
---|
[291] | 107 | system "apt-get update; apt-get -y install autoconf automake libtool g++ wget patch mondo groff imagemagick docbook-utils docbook2x docbook-to-man openssh-server dpkg-dev sudo debian-builder dh-make fakeroot libnewt-dev ntpdate libncurses5-dev libdate-manip-perl";
|
---|
[203] | 108 | }
|
---|
[164] | 109 | } elsif ( $dfam eq "gen" ) {
|
---|
[291] | 110 | #system "emerge -u system ; emerge neon newt slang autoconf automake subversion libtool gcc wget vim man groff lynx grub afio buffer sudo ntp DateManip";
|
---|
[164] | 111 | } else {
|
---|
| 112 | print "No pkg to install\n";
|
---|
| 113 | }
|
---|
[158] | 114 |
|
---|
[203] | 115 | # Adapt sudoers
|
---|
| 116 | $file="/etc/sudoers";
|
---|
| 117 | open(PBFILE,$file) || die "Unable to open $file";
|
---|
| 118 | open(PBOUT,"> $file.new") || die "Unable to open $file.new";
|
---|
| 119 | while (<PBFILE>) {
|
---|
[226] | 120 | next if (/^pb /);
|
---|
[203] | 121 | s/Defaults[ \t]+requiretty//;
|
---|
| 122 | print PBOUT $_;
|
---|
| 123 | }
|
---|
| 124 | close(PBFILE);
|
---|
[226] | 125 | print PBOUT "pb ALL=(ALL) NOPASSWD:ALL\n";
|
---|
[203] | 126 | close(PBOUT);
|
---|
| 127 | rename("$file.new",$file);
|
---|
| 128 | chmod 0440,$file;
|
---|
| 129 |
|
---|
| 130 | # Suse wants sudoers as 640
|
---|
[274] | 131 | if (($ddir eq "sles") || (($ddir eq "suse")) && ($dver ne "10.3")) {
|
---|
[203] | 132 | chmod 0640,$file;
|
---|
| 133 | }
|
---|
| 134 |
|
---|
[171] | 135 | # Sync date
|
---|
| 136 | system "/usr/sbin/ntpdate ntp.home.musique-ancienne.org";
|
---|
| 137 |
|
---|
[226] | 138 | system "rm -rf project-builder-* ; wget --passive-ftp ftp://ftp.mondorescue.org/src/project-builder-latest.tar.gz ; tar xvfz project-builder-latest.tar.gz ; cd project-builder-* ; perl Makefile.PL ; make ; make install ; cd ..";
|
---|
[166] | 139 |
|
---|