diff options
Diffstat (limited to 'bin/draknfs')
-rwxr-xr-x | bin/draknfs | 203 |
1 files changed, 107 insertions, 96 deletions
diff --git a/bin/draknfs b/bin/draknfs index d3040f6..22f132f 100755 --- a/bin/draknfs +++ b/bin/draknfs @@ -27,7 +27,6 @@ use common; use network::network; use interactive; use services; -#$ugtk2::wm_icon = 'IC-NFS-48'; my $nfsicon = "/usr/share/mcc/themes/default/draknfs.png"; $ugtk2::wm_icon = $nfsicon; use mygtk2 qw(gtknew gtkset); @@ -270,8 +269,6 @@ sub add_modify_entry { $button->signal_connect(clicked => sub { $file_dialog->show }); # test if modify or add a nfs share - my $dialog = _create_dialog(N("Draknfs entry"), { transient_for => $::main_window, modal => 1 }); - local $::main_window = $dialog; my $anonuid = gtknew('ComboBox', list => [ get_user_or_group('passwd') ]); my $anongid = gtknew('ComboBox', list => [ get_user_or_group('group') ]); @@ -353,100 +350,114 @@ sub add_modify_entry { $_->set_sensitive(0) foreach $anongid, $anonuid; } - my $expender = Gtk2::Expander->new(N("Advanced options")); - $expender->add(gtknew('VBox', spacing => 5, children_tight => [ - $label_and_widgets->($adv_options{sync}, $lsync, help_b($help_global)), - $label_and_widgets->($adv_options{secured}, $lsecure, ""), - $label_and_widgets->($adv_options{ro}, $lr, ""), - $label_and_widgets->($adv_options{subtree_check}, $lsubtree_check, ""), - ]), - ); - $expender->signal_connect(activate => sub { - gtkset($dialog); - gtkflush(); - }); - - $dialog->vbox->set_spacing(5); - gtkpack__($dialog->vbox, - gtknew('Title2', label => N("NFS directory")), - $label_and_widgets->(N("Directory:"), $dir, $button), - gtknew('Title2', label => N("Host access")), - $label_and_widgets->(N("Access:"), $access, help_b($help_access)), - gtknew('Title2', label => N("User ID Mapping")), - $label_and_widgets->(N("User ID:"), $luserid, help_b($help_userid)), - $label_and_widgets->(N("Anonymous user ID:"), $anonuid, ""), - $label_and_widgets->(N("Anonymous Group ID:"), $anongid, ""), - $expender, - create_okcancel({ - cancel_clicked => sub { $dialog->destroy }, - ok_clicked => sub { - my ($anonu, $anong); - if ($anonuid->get_text) { - my ($uid) = $anonuid->get_text =~ /\[(\S*)\]/; - $anonu = "anonuid=" . $uid; - } - if ($anongid->get_text) { - my ($gid) = $anongid->get_text =~ /\[(\S*)\]/; - $anong = "anongid=" . $gid; - } - if ($lsync->get_text =~ /yes/) { $lsync_data = "sync" } elsif ($lsync->get_text =~ /no/) { $lsync_data = "async" } else { undef $lsync_data } - if ($lr->get_text =~ /yes/) { $lr_data = "ro" } elsif ($lr->get_text =~ /no/) { $lr_data = "rw" } else { undef $lr_data } - if ($lsecure->get_text =~ /yes/) { $lsecure_data = "secure" } elsif ($lsecure->get_text =~ /no/) { $lsecure_data = "insecure" } else { undef $lsecure_data } - if ($lsubtree_check->get_text =~ /yes/) { $lsubtree_check_data = "subtree_check" } elsif ($lsubtree_check->get_text =~ /no/) { $lsubtree_check_data = "no_subtree_check" } else { undef $lsubtree_check } - # test $luserid->get_text - my $luserid_toput; - if ($luserid->get_text =~ /$userid_data->{no_root_squash}/) { - $luserid_toput = "no_root_squash"; - undef $anong; undef $anonu; - } elsif ($luserid->get_text =~ /$userid_data->{root_squash}/) { - $luserid_toput = "root_squash"; - } elsif ($luserid->get_text =~ /$userid_data->{no_all_squash}/) { - $luserid_toput = "no_all_squash"; - undef $anong; undef $anonu; - } elsif ($luserid->get_text =~ /$userid_data->{all_squash}/) { - $luserid_toput = "all_squash"; - $anong = "anongid=65534"; - $anonu = "anonuid=65534"; - } - - my $all_right = join(",", grep { defined $_ } $luserid_toput, $anonu, $anong, $lsync_data, $lsecure_data, $lsubtree_check_data, $lr_data); - my $test_dir = $dir->get_text; - if (! $test_dir) { - err_dialog(N("Error"), N("Please specify a directory to share.")) and return; - } - mkdir_p($test_dir) or err_dialog(N("Error"), N("Can't create this directory.")) and return; - #my $test_access = $access->child->get_text; - my $test_access = $access->entry->get_text; - $test_access or err_dialog(N("Error"), N("You must specify hosts access.")) and return; - if ($wanted =~ /add/) { - $iter = $model->append; - $i = "-1"; - push @listshare, { - dir => $dir->get_text, - #access => $access->child->get_text, - access => $access->entry->get_text, - right => $all_right, - options => $options->get_text, - }; - } - $listshare[$i]{right} = $all_right; - #$listshare[$i]{access} = $access->child->get_text; - $listshare[$i]{access} = $access->entry->get_text; - $listshare[$i]{dir} = $dir->get_text; - $listshare[$i]{options} = $options->get_text; - $model->set($iter, - COLUMN_DIR, $listshare[$i]{dir}, - COLUMN_ACCESS, $listshare[$i]{access}, - COLUMN_RIGHT, $all_right, - COLUMN_OPTIONS, $listshare[$i]{options}, - ); - $dialog->destroy; + my $expender = Gtk2::Expander->new(N("Advanced")); + $expender->add(gtkpack_(Gtk2::HBox->new, + 0, gtkpack_(gtkset_border_width(Gtk2::HBox->new, 1), + 0, gtkpack_(gtkset_border_width(Gtk2::VBox->new, 0), + 0, $label_and_widgets->($adv_options{sync}, $lsync, help_b($help_global)), + 0, $label_and_widgets->($adv_options{secured}, $lsecure, ""), + 0, $label_and_widgets->($adv_options{ro}, $lr, ""), + 0, $label_and_widgets->($adv_options{subtree_check}, $lsubtree_check, ""), + ), + ), + ), + ); + + my $w = ugtk2->new(N("Modify entry")); + $w->{window}->set_modal(1); + $w->{window}->set_position('center'); + + $expender->signal_connect(activate => sub { $w->shrink_topwindow; }); + + gtkadd($w->{window}, + gtknew('VBox', spacing => 0, children_loose => [ +# gtkadd(Gtk2::Frame->new(("")), + gtkpack_(gtkset_border_width(Gtk2::VBox->new, 1), + 0, gtknew('Title2', label => N("NFS directory")), + 0, $label_and_widgets->(N("Directory:"), $dir, $button), + 0, gtknew('Title2', label => N("Host access")), + 0, $label_and_widgets->(N("Access:"), $access, help_b($help_access)), + 0, gtknew('Title2', label => N("User ID Mapping")), + 0, $label_and_widgets->(N("User ID:"), $luserid, help_b($help_userid)), + 0, $label_and_widgets->(N("Anonymous user ID:"), $anonuid, ""), + 0, $label_and_widgets->(N("Anonymous Group ID:"), $anongid, ""), + ), +# ), +# gtkadd(Gtk2::Frame->new(""), + gtkpack_(gtkset_border_width(Gtk2::VBox->new, 1), + 0, $expender, + ), +# ), + create_okcancel({ + cancel_clicked => sub { $w->destroy }, + ok_clicked => sub { + my ($anonu, $anong); + if ($anonuid->get_text) { + my ($uid) = $anonuid->get_text =~ /\[(\S*)\]/; + $anonu = "anonuid=" . $uid; + } + if ($anongid->get_text) { + my ($gid) = $anongid->get_text =~ /\[(\S*)\]/; + $anong = "anongid=" . $gid; + } + if ($lsync->get_text =~ /yes/) { $lsync_data = "sync" } elsif ($lsync->get_text =~ /no/) { $lsync_data = "async" } else { undef $lsync_data } + if ($lr->get_text =~ /yes/) { $lr_data = "ro" } elsif ($lr->get_text =~ /no/) { $lr_data = "rw" } else { undef $lr_data } + if ($lsecure->get_text =~ /yes/) { $lsecure_data = "secure" } elsif ($lsecure->get_text =~ /no/) { $lsecure_data = "insecure" } else { undef $lsecure_data } + if ($lsubtree_check->get_text =~ /yes/) { $lsubtree_check_data = "subtree_check" } elsif ($lsubtree_check->get_text =~ /no/) { $lsubtree_check_data = "no_subtree_check" } else { undef $lsubtree_check } + # test $luserid->get_text + my $luserid_toput; + if ($luserid->get_text =~ /$userid_data->{no_root_squash}/) { + $luserid_toput = "no_root_squash"; + undef $anong; undef $anonu; + } elsif ($luserid->get_text =~ /$userid_data->{root_squash}/) { + $luserid_toput = "root_squash"; + } elsif ($luserid->get_text =~ /$userid_data->{no_all_squash}/) { + $luserid_toput = "no_all_squash"; + undef $anong; undef $anonu; + } elsif ($luserid->get_text =~ /$userid_data->{all_squash}/) { + $luserid_toput = "all_squash"; + $anong = "anongid=65534"; + $anonu = "anonuid=65534"; + } + + my $all_right = join(",", grep { defined $_ } $luserid_toput, $anonu, $anong, $lsync_data, $lsecure_data, $lsubtree_check_data, $lr_data); + my $test_dir = $dir->get_text; + if (! $test_dir) { + err_dialog(N("Error"), N("Please specify a directory to share.")) and return; + } + mkdir_p($test_dir) or err_dialog(N("Error"), N("Can't create this directory.")) and return; + #my $test_access = $access->child->get_text; + my $test_access = $access->entry->get_text; + $test_access or err_dialog(N("Error"), N("You must specify hosts access.")) and return; + if ($wanted =~ /add/) { + $iter = $model->append; + $i = "-1"; + push @listshare, { + dir => $dir->get_text, + #access => $access->child->get_text, + access => $access->entry->get_text, + right => $all_right, + options => $options->get_text, + }; + } + $listshare[$i]{right} = $all_right; + #$listshare[$i]{access} = $access->child->get_text; + $listshare[$i]{access} = $access->entry->get_text; + $listshare[$i]{dir} = $dir->get_text; + $listshare[$i]{options} = $options->get_text; + $model->set($iter, + COLUMN_DIR, $listshare[$i]{dir}, + COLUMN_ACCESS, $listshare[$i]{access}, + COLUMN_RIGHT, $all_right, + COLUMN_OPTIONS, $listshare[$i]{options}, + ); + $w->destroy; # write_conf(); - }, - }, - ), - ); - $dialog->show_all; + }, + }), + ], + ),),; + $w->{window}->show_all; } sub remove_entry { |