/[pxelator]/lib/PXElator/config.pm
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Diff of /lib/PXElator/config.pm

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 460 by dpavlin, Sat Jan 2 17:45:58 2010 UTC revision 513 by dpavlin, Wed Jul 21 17:56:42 2010 UTC
# Line 14  use File::Slurp; Line 14  use File::Slurp;
14    
15  our $mounted;  our $mounted;
16    
17  sub available { qw/katalog debian_live webconverger debirf tinycore nfsroot openvz printer wrt/ };  our $server;
18    our $server_ip;
19    
20    sub available { qw/katalog debian_live webconverger debirf tinycore nfsroot openvz printer wrt clonezilla ubuntu memdisk/ };
21    
22  sub debian_live {  sub debian_live {
23          my ($ip) = @_;          my ($ip) = @_;
# Line 33  sub debian_live { Line 36  sub debian_live {
36  default debian_live  default debian_live
37  label debian_live  label debian_live
38          kernel vmlinuz1          kernel vmlinuz1
39          append initrd=initrd1.img fetch=http://${server::ip}:7777/debian_live/debian-live-501-i386-standard.squashfs boot=live nopersistent hostname=$hostname union=aufs noprompt          append initrd=initrd1.img fetch=http://$server_ip:7777/debian_live/debian-live-501-i386-standard.squashfs boot=live nopersistent hostname=$hostname union=aufs noprompt
40          });          });
41    
42  }  }
# Line 56  sub webconverger { Line 59  sub webconverger {
59          my $hostname = client::conf( $ip => 'hostname' ) || 'webconverger';          my $hostname = client::conf( $ip => 'hostname' ) || 'webconverger';
60    
61          my $homepage = client::conf( $ip => 'webconverger/homepage'          my $homepage = client::conf( $ip => 'webconverger/homepage'
62                  , default => "http://${server::ip}:7777/client" );                  , default => "http://$server_ip:7777/client" );
63          my $fetch    = client::conf( $ip => 'webconverger/fetch'          my $fetch    = client::conf( $ip => 'webconverger/fetch'
64                  , default => "http://${server::ip}:7777/webconverger/iso/live/filesystem.squashfs" );                  , default => "http://$server_ip:7777/webconverger/iso/live/filesystem.squashfs" );
65    
66          pxelinux::config_for_ip( $ip, qq{          pxelinux::config_for_ip( $ip, qq{
67    
68  default webconverger  default webconverger
69  label webconverger  label webconverger
70          kernel iso/live/vmlinuz-2.6.30-backports.1-486          kernel iso/live/vmlinuz-2.6.30-backports.1-486
71          append initrd=iso/live/initrd.img-2.6.30-backports.1-486 fetch=$fetch boot=live quiet nosudo splash video=vesa:ywrap,mtrr vga=788 nopersistent username=webc hostname=$hostname union=aufs homepage=$homepage locale=hr noprompt          append initrd=iso/live/initrd.img-2.6.30-backports.1-486 fetch=$fetch boot=live quiet nosudo splash video=vesa:ywrap,mtrr vga=788 nopersistent username=webc hostname=$hostname union=aufs homepage=$homepage locale=hr noprompt kioskresetstation=10
72    
73          });          });
74    
# Line 76  sub katalog { Line 79  sub katalog {
79          $mounted->{"webconverger/$ip"} ||= upstream::iso( 'http://download.webconverger.com/webc-5.5.iso' );          $mounted->{"webconverger/$ip"} ||= upstream::iso( 'http://download.webconverger.com/webc-5.5.iso' );
80          my $hostname = client::conf( $ip => 'hostname' ) || 'katalog';          my $hostname = client::conf( $ip => 'hostname' ) || 'katalog';
81          my $homepage = client::conf( $ip => 'webconverger/homepage' => "http://koha.ffzg.hr" );          my $homepage = client::conf( $ip => 'webconverger/homepage' => "http://koha.ffzg.hr" );
82          my $fetch    = client::conf( $ip => 'webconverger/fetch' => "http://${server::ip}:7777/webconverger/custom.squashfs" );          my $fetch    = client::conf( $ip => 'webconverger/fetch' => "http://$server_ip:7777/webconverger/custom.squashfs" );
83    
84          pxelinux::config_for_ip( $ip, qq{          pxelinux::config_for_ip( $ip, qq{
85    
# Line 124  label linux Line 127  label linux
127          });          });
128  }  }
129    
130    sub clonezilla {
131            my $ip = shift;
132            upstream::iso( 'http://sourceforge.net/projects/clonezilla/files/clonezilla_live_alternative_testing/clonezilla-live-20100503-lucid.iso/download' );
133            pxelinux::config_for_ip( $ip, qq{
134    
135    default linux
136    label linux
137            kernel iso/live/vmlinuz
138            append initrd=iso/live/initrd.img boot=live union=aufs noswap noprompt vga=788 fetch=http://$server_ip:7777/clonezilla/iso/live/filesystem.squashfs
139    
140            });
141    }
142    
143    sub ubuntu {
144            my $ip = shift;
145            upstream::iso( 'http://mirrors.us.kernel.org/ubuntu-releases/lucid/ubuntu-10.04-desktop-i386.iso' );
146    
147            my $export = "$server::base_dir/tftp/ubuntu/iso";
148            my $exported = `exportfs | grep $export`;
149            if ( $exported ne $export ) {
150                    warn "exportfs $exported\n";
151                    system "sudo exportfs -i -o rw,async,no_root_squash,no_subtree_check,fsid=999 $ip:$export";
152            }
153            pxelinux::config_for_ip( $ip, qq{
154    
155    default linux
156    label linux
157            kernel iso/casper/vmlinuz
158            append initrd=iso/casper/initrd.lz boot=casper netboot=nfs nfsroot=$server_ip:$export --
159    
160            });
161    }
162    
163    sub memdisk {
164            my $ip = shift;
165    
166            my $dir = "$server::base_dir/tftp/memdisk";
167            mkdir $dir unless -e $dir;
168    
169            symlink '/usr/lib/syslinux/memdisk', "$dir/memdisk" unless -e "$dir/memdisk";
170    
171            my $image = client::conf( $ip => 'memdisk.image' );
172    
173            if ( ! $image ) {
174                    $image = 'freedos.gz';
175                    upstream::mirror_file 'http://www.ibiblio.org/pub/micro/pc-stuff/freedos/files/distributions/unofficial/balder/balder10.imz' => "$dir/$image";
176                    warn "using $image [default FreeDOS]\n";
177            } else {
178                    $image =~ s{^.+/tftp/memdisk/}{} && warn "using $image\n";
179            }
180    
181            pxelinux::config_for_ip( $ip, qq{
182    
183    default $image
184    label $image
185            kernel memdisk
186            append initrd=$image
187    
188            });
189    }
190    
191  sub in_chroot {  sub in_chroot {
192          my ( $dir, $command ) = @_;          my ( $dir, $command ) = @_;
193          write_file "$dir/tmp/inside.sh", $command;          write_file "$dir/tmp/inside.sh", $command;
# Line 133  sub in_chroot { Line 197  sub in_chroot {
197  sub nfsroot {  sub nfsroot {
198          my $ip = shift || die "no ip?";          my $ip = shift || die "no ip?";
199    
200            my $dist = 'lenny';
201            $dist = 'squeeze';
202    
203          my $nfsroot = "$server::base_dir/tftp/nfsroot";          my $nfsroot = "$server::base_dir/tftp/nfsroot";
204          my $debian_mirror = server::conf_default( 'debian_mirror', 'http://ftp.debian.org/debian' );          my $debian_mirror = server::conf_default( 'debian_mirror', 'http://ftp.debian.org/debian' );
205    
# Line 145  sub nfsroot { Line 212  sub nfsroot {
212    
213          if ( ! -e $debootstrap ) {          if ( ! -e $debootstrap ) {
214    
215                  system "sudo debootstrap --arch i386 lenny $debootstrap $debian_mirror";                  system "sudo debootstrap --arch i386 $dist $debootstrap $debian_mirror";
216    
217                  file::append "$debootstrap/etc/apt/sources.list.d/non-free.list", "deb $debian_mirror lenny non-free\n";                  file::append "$debootstrap/etc/apt/sources.list.d/non-free.list", "deb $debian_mirror $dist non-free\n";
218                  in_chroot     $debootstrap => 'apt-get update';                  in_chroot     $debootstrap => 'apt-get update';
219    
220                  file::append "$debootstrap/etc/kernel-img.conf", "do_initrd = Yes\n";                  file::append "$debootstrap/etc/kernel-img.conf", "do_initrd = Yes\n";
221                  in_chroot     $debootstrap => 'apt-get install -y --force-yes atl2-modules-2.6-686 firmware-bnx2';                  in_chroot     $debootstrap => 'apt-get -f install -y --force-yes locales linux-image-2.6-686 firmware-bnx2';
                 in_chroot     $debootstrap => 'apt-get -f install -y --force-yes locales';      # linux-image-2.6-686  
222    
223                    # this can fails on some distros, so we run it alone
224                    in_chroot     $debootstrap => 'apt-get install -y --force-yes atl2-modules-2.6-686';
225                  file::append "$debootstrap/etc/initramfs-tools/modules", "atl2\n";                  file::append "$debootstrap/etc/initramfs-tools/modules", "atl2\n";
226                  file::change("$debootstrap/etc/initramfs-tools/initramfs.conf",  'BOOT=local' => 'BOOT=nfs' ) &&  
227                    file::change "$debootstrap/etc/initramfs-tools/initramfs.conf",  'BOOT=local' => 'BOOT=nfs';
228                  in_chroot     $debootstrap => 'update-initramfs -u';                  in_chroot     $debootstrap => 'update-initramfs -u';
229    
230          }          }
# Line 177  sub nfsroot { Line 246  sub nfsroot {
246                    
247          }          }
248    
249          my $server = server::as_hash_for $ip;          my $exported = `exportfs | grep $export`;
250            if ( $exported ne $export ) {
251                    warn "exportfs $exported\n";
252                    system "sudo exportfs -i -o rw,async,no_root_squash,no_subtree_check,fsid=999 $ip:$export";
253            }
254    
255          my $hostname = client::conf( $ip => 'hostname' ) || 'nfsroot';          my $hostname = client::conf( $ip => 'hostname' ) || 'nfsroot';
256          file::replace "$export/etc/hostname", $hostname;          file::replace "$export/etc/hostname", $hostname;
# Line 200  iface eth0 inet dhcp Line 273  iface eth0 inet dhcp
273                  file::append "$export/etc/rc.local", $_;                  file::append "$export/etc/rc.local", $_;
274          } ( '/srv/sysadmin-cookbook/recepies/amt/serial-console.sh' );          } ( '/srv/sysadmin-cookbook/recepies/amt/serial-console.sh' );
275    
276          pxelinux::config_for_ip( $ip, qq{          pxelinux::config_ip_boot( $ip, "$export/boot", "root=/dev/nfs nfsroot=$server->{ip}:$export ro ip=dhcp" );
277    
 default nfsroot  
 label nfsroot  
         kernel debootstrap/vmlinuz  
         append initrd=debootstrap/initrd.img root=/dev/nfs nfsroot=$server->{ip}:$export ro ip=dhcp  
   
         });  
278  }  }
279    
280  sub openvz {  sub openvz {
# Line 219  sub wrt         {} Line 286  sub wrt         {}
286    
287  sub for_ip {  sub for_ip {
288          my $ip = shift || return;          my $ip = shift || return;
289            $server = server::as_hash_for $ip;
290            $server_ip = $server->{ip} || die "no server ip";
291          my $config = client::conf( $ip => 'config' ) || return;          my $config = client::conf( $ip => 'config' ) || return;
292          eval $config . '($ip)';          eval $config . '($ip)'; # must be last
 #       $tftp::dir = "$server::base_dir/tftp/$pxelinux::path_prefix";  
293  }  }
294    
295  warn 'loaded';  warn 'loaded';

Legend:
Removed from v.460  
changed lines
  Added in v.513

  ViewVC Help
Powered by ViewVC 1.1.26