diff options
Diffstat (limited to 'perl-install/standalone/drakboot')
| -rwxr-xr-x | perl-install/standalone/drakboot | 243 | 
1 files changed, 10 insertions, 233 deletions
| diff --git a/perl-install/standalone/drakboot b/perl-install/standalone/drakboot index 674311067..b4fa43a98 100755 --- a/perl-install/standalone/drakboot +++ b/perl-install/standalone/drakboot @@ -1,8 +1,7 @@  #!/usr/bin/perl  # DrakBoot -# $Id$ -# Copyright (C) 2001-2005 Mandriva +# Copyright (C) 2001-2008 Mandriva  # Yves Duret, Thierry Vignaud  #  # This program is free software; you can redistribute it and/or modify @@ -24,17 +23,12 @@ use diagnostics;  use lib qw(/usr/lib/libDrakX);  use standalone; #- warning, standalone must be loaded very first, for 'explanations' -use c;  use common;  use interactive;  use any;  use bootloader;  use fsedit;  use fs; -use Config; -use POSIX; -use Xconfig::various; -use log;  my $in = 'interactive'->vnew('su'); @@ -43,231 +37,14 @@ fs::get_raw_hds('', $all_hds);  fs::get_info_from_fstab($all_hds);  my $fstab = [ fs::get::fstab($all_hds) ];  my $bootloader = bootloader::read($all_hds); - -if (!$in->isa('interactive::gtk') || any { /^--boot$/ } @ARGV) { -    $::isWizard = 1; -    eval { lilo_choice() }; -    die if $@ && $@ !~ /^wizcancel/; -    $in->exit(0); -} - -require ugtk2; -ugtk2->import(qw(:helpers :wrappers :create)); - -if (any { /^--splash$/ } @ARGV) { -    splash_choice(); -} else { -    autologin_choice(); -} - -sub run_boot_window { -    my ($title, $pack_list, $apply_sub) = @_; - -    my $w = ugtk2->new($title); -    my $window = $w->{window}; -    $::main_window = $w->{real_window}; - -    $window->signal_connect(delete_event => sub { ugtk2->exit(0) }); -    unless ($::isEmbedded) { -        $window->set_border_width(2); -        ### menus definition -        # the menus are not shown but they provides shiny shortcut like C-q -        my @menu_items = ([ N("/_File"), undef, undef, undef, '<Branch>' ], -                          [ N("/File/_Quit"), N("<control>Q"), sub { ugtk2->exit(0) }, undef, '<Item>' ], -                         ); -        create_factory_menu($w->{rwindow}, @menu_items); -        ######### menus end -    } -    gtkadd($window, gtkpack_(Gtk2::VBox->new(0,0), -                             @$pack_list, -                             0, create_okcancel({ -                                                 cancel_clicked => sub { ugtk2->exit(0) }, -                                                 ok_clicked => sub { -                                                     $apply_sub->(); -                                                     ugtk2->exit(0); -                                                 } -                                                }))); -    $window->show_all; -    gtkflush(); -    $w->main; -    $in->exit(0); -} - -sub splash_choice() { -    require bootsplash; -    my ($cur_res, $bootsplash_available) = bootsplash::get_framebuffer_resolution(); -    $bootsplash_available = 1 if $::testing; - -    my $theme = bootsplash::themes_read_sysconfig($cur_res); -    $bootsplash_available or $theme->{enabled} = 0; - -    my $boot_pic = gtkcreate_img($bootsplash::default_thumbnail); -    change_image($boot_pic, $theme->{name}, $cur_res); - -    my $theme_combo = gtkset_size_request(Gtk2::ComboBox->new_with_strings([ bootsplash::themes_list_for_resolution($cur_res) ], $theme->{name}), 10, -1); -    $theme_combo->entry->signal_connect(changed => sub { -                                            $theme->{name} = $theme_combo->entry->get_text; -                                            change_image($boot_pic, $theme->{name}, $cur_res); -                                        }); - -    my $_thm_button = Gtk2::Button->new(N("Install themes")); -    my $_B_create = gtksignal_connect(Gtk2::Button->new(N("Create new theme")), clicked => sub { system('/usr/sbin/draksplash ') }); - -    my $splash_box; -    my $boot_warn = 1; -    run_boot_window(N("Graphical boot theme selection"), -                       [ -                        1, gtkpack_(gtkset_border_width(Gtk2::VBox->new(0, 5), 5), -                                    0, gtksignal_connect(gtkset_active(Gtk2::CheckButton->new(N("Use graphical boot")), $theme->{enabled}), -                                                         clicked => sub { -                                                             $theme->{enabled} = !$theme->{enabled}; -                                                             if ($boot_warn && !$bootsplash_available && $theme->{enabled}) { -                                                                 if ($in->ask_yesorno(N("Warning"), -                                                                                      [ N("Your system bootloader is not in framebuffer mode. To activate graphical boot, select a graphic video mode from the bootloader configuration tool.") . "\n" . -                                                                                        N("Do you want to configure it now?") ])) { -                                                                     enable_framebuffer(); -                                                                     #- it would be nice to get available themes for new cur_res here -                                                                 } -                                                                 $boot_warn = 0; -                                                             } -                                                             $splash_box->set_sensitive($theme->{enabled}); -                                                         }), -                                    0, gtkpack(gtkset_sensitive($splash_box = Gtk2::HBox->new(0, 0), $theme->{enabled}), -                                               gtkadd(gtkcreate_frame(N("Theme")), -                                                    gtkpack__(Gtk2::VBox->new(0, 5), -                                                         $theme_combo, -                                                         gtksignal_connect(gtkset_active(Gtk2::CheckButton->new(N("Display theme\nunder console")), -                                                                                         $theme->{keep_logo}), -                                                                           clicked => sub { invbool(\$theme->{keep_logo}) }) -                                                        ), -                                               ), -                                               Gtk2::VSeparator->new, -                                               gtkpack__(Gtk2::VBox->new(0, 5), $boot_pic)) -                                   ), -                       ], -                       sub { -                           bootsplash::set_logo_console($theme->{keep_logo}); -                           if ($theme->{enabled}) { -                               bootsplash::switch($theme->{name}); -                           } else { -                               bootsplash::remove(); -                           } -                       }); +if (!$bootloader) { +    $in->ask_okcancel('', N("No bootloader found, creating a new configuration"), 0) or $in->exit; +    any::setupBootloaderBeforeStandalone($in->do_pkgs, $bootloader ||= {}, $all_hds, $fstab);  } -sub autologin_choice() { -    my @users = sort(list_users()); -    my @sessions = sort(split(' ', `/usr/sbin/chksession -l`)); - -    my $x_mode = Xconfig::various::runlevel() == 5; -    my $auto_mode = any::get_autologin(); - -    my $user = member($auto_mode->{autologin}, @users) ? $auto_mode->{autologin} : $users[0]; -    if (!$user) { -        # no user, bad but add root anyway: -        $user = "root"; -        push @users, $user; -    } -    my $user_combo = Gtk2::ComboBox->new_with_strings(\@users, $user); -    my $desktop_combo = Gtk2::ComboBox->new_with_strings(\@sessions, if_(member($auto_mode->{desktop}, @sessions), $auto_mode->{desktop})); - -    my $auto_box = create_packtable({ col_spacings => 5, row_spacings => 5, homogenous => 1 }, -                                    [ Gtk2::Label->new(N("Default user")), $user_combo ], -                                    [ Gtk2::Label->new(N("Default desktop")), $desktop_combo ]); -    $auto_box->set_sensitive($auto_mode->{autologin} ? 1 : 0); - -    my @auto_buttons = gtkradio((N("No, I do not want autologin")) x 2, -                                N("Yes, I want autologin with this (user, desktop)")); -    $auto_buttons[1]->signal_connect('toggled' => sub { $auto_box->set_sensitive($auto_buttons[1]->get_active) }); -    $auto_buttons[0]->signal_connect('toggled' => sub { $auto_box->set_sensitive(!$auto_buttons[0]->get_active) }); -    $auto_buttons[1]->set_active(1) if $auto_mode->{autologin}; -    $auto_buttons[0]->set_active(1) if !$auto_mode->{autologin}; - -    my $x_box; -    run_boot_window(N("System mode"), -                    [ -                     1, gtkpack__(Gtk2::VBox->new(0, 5), -                                  gtksignal_connect(gtkset_active(Gtk2::CheckButton->new(N("Launch the graphical environment when your system starts")), -                                                                  $x_mode), -                                                    clicked => sub { -                                                        $x_box->set_sensitive(!$x_mode); -                                                        $x_mode = !$x_mode; -                                                    }), -                                  gtkpack__(gtkset_sensitive($x_box = Gtk2::VBox->new(0, 0), $x_mode), -                                            gtkpack__(Gtk2::VBox->new(0, 0), @auto_buttons), -                                            $auto_box -                                           )) -                    ], -                    sub { -                        Xconfig::various::runlevel($x_mode ? 5 : 3); -                        $::testing and return; -                        if ($auto_buttons[1]->get_active) { -                            any::set_autologin($user_combo->entry->get_text, $desktop_combo->entry->get_text); -                          } else { -                              any::set_autologin(); -                          } -                    }); -} - -sub lilo_choice() { -    do { -        my $before = fs::fstab_to_string($all_hds); -        any::setupBootloader($in, $bootloader, $all_hds, $fstab, $ENV{SECURE_LEVEL}) or $in->exit; -        if ($before ne fs::fstab_to_string($all_hds)) { -            #- for /tmp using tmpfs when "clean /tmp" is chosen -            fs::write_fstab($all_hds); -        } -    } while !any::installBootloader($in, $bootloader, $all_hds); -} - - -#------------------------------------------------------------- -# launch autologin functions -#------------------------------------------------------------- - -sub change_image { -    my ($boot_pic, $theme, $res) = @_; -    my $img_file = bootsplash::theme_get_image_for_resolution($theme, $res); -    -f $img_file or return; -    my $boot_pixbuf = gtkcreate_pixbuf($img_file); -    $boot_pixbuf = $boot_pixbuf->scale_simple(300, 200, 'nearest'); -    $boot_pic->set_from_pixbuf($boot_pixbuf); -} - -sub enable_framebuffer() { -    my $vga = bootsplash::get_framebuffer_resolution(); -    my ($current_entry) = cat_('/proc/cmdline') =~ /^BOOT_IMAGE=(\S+)/; -    my %entries = ( -                   $current_entry => 1 -                  ); -    local $::isWizard = 1; -    local $::Wizard_no_previous = 1; -    local $::Wizard_finished = 1; -    $::Wizard_title = N("Boot Style Configuration"); -    eval { -        $in->ask_from(N("Video mode"), -                      N("Please choose a video mode, it will be applied to each of the boot entries selected below. -Be sure your video card supports the mode you choose."), -                      [ -                       { label => N("Video mode"), val => \$vga, -                         list => [ '', Xconfig::resolution_and_depth::bios_vga_modes() ], -                         format => \&Xconfig::resolution_and_depth::to_string -                       }, -                       map { -                           { text => $_->{label}, val => \$entries{$_->{label}}, type => 'bool' }; -                       } grep { $_->{label} !~ /failsafe|floppy|memtest/ } @{$bootloader->{entries}} -                      ]); -        if ($vga) { -            $vga = $vga->{bios} if ref($vga); -            while (my ($label, $e) = each %entries) { -                $e or next; -                my $entry = find { $_->{label} eq $label } @{$bootloader->{entries}}; -                $entry->{vga} = $vga; -            } -            bootloader::install($bootloader, $all_hds); -        } -    }; -    die if $@ && $@ !~ /^wizcancel/; -    $::WizardWindow->destroy unless $::isEmbedded; -    $vga; -} +$::isWizard = 1; +require security::level; +my $level = security::level::from_string(security::level::get()); +eval { any::setupBootloaderUntilInstalled($in, $bootloader, $all_hds, $fstab, $level) }; +die if $@ && $@ !~ /^wizcancel/; +$in->exit(0); | 
