diff options
author | Antoine Ginies <aginies@mandriva.com> | 2011-01-19 10:44:49 +0000 |
---|---|---|
committer | Antoine Ginies <aginies@mandriva.com> | 2011-01-19 10:44:49 +0000 |
commit | 530a16ec071db0e24e6e949e265a96848864967c (patch) | |
tree | fe40cacd28d67b98186754c551b7fd339ebc7e17 /perl-install/diskdrake/dav.pm | |
download | drakx-backup-do-not-use-530a16ec071db0e24e6e949e265a96848864967c.tar drakx-backup-do-not-use-530a16ec071db0e24e6e949e265a96848864967c.tar.gz drakx-backup-do-not-use-530a16ec071db0e24e6e949e265a96848864967c.tar.bz2 drakx-backup-do-not-use-530a16ec071db0e24e6e949e265a96848864967c.tar.xz drakx-backup-do-not-use-530a16ec071db0e24e6e949e265a96848864967c.zip |
add mes5-2.6.33 branch
Diffstat (limited to 'perl-install/diskdrake/dav.pm')
-rw-r--r-- | perl-install/diskdrake/dav.pm | 115 |
1 files changed, 115 insertions, 0 deletions
diff --git a/perl-install/diskdrake/dav.pm b/perl-install/diskdrake/dav.pm new file mode 100644 index 000000000..a358c987a --- /dev/null +++ b/perl-install/diskdrake/dav.pm @@ -0,0 +1,115 @@ +package diskdrake::dav; # $Id: dav.pm 215411 2007-04-25 12:26:16Z pixel $ + +use diagnostics; +use strict; +use diskdrake::interactive; +use common; + +sub main { + my ($in, $all_hds) = @_; + my $davs = $all_hds->{davs}; + + $in->do_pkgs->ensure_binary_is_installed('davfs2', 'mount.davfs2') or return; + + my $quit; + do { + $in->ask_from_({ ok => '', messages => formatAlaTeX( +N("WebDAV is a protocol that allows you to mount a web server's directory +locally, and treat it like a local filesystem (provided the web server is +configured as a WebDAV server). If you would like to add WebDAV mount +points, select \"New\".")) }, + [ + (map { + my $dav = $_; + { label => $dav->{device}, val => $dav->{mntpoint}, clicked_may_quit => sub { config($in, $dav, $all_hds); 1 } } } @$davs), + { val => N("New"), clicked_may_quit => sub { create($in, $all_hds); 1 } }, + { val => N("Quit"), clicked_may_quit => sub { $quit = 1 } }, + ]); + } until $quit; + + diskdrake::interactive::Done($in, $all_hds); +} + +sub create { + my ($in, $all_hds) = @_; + + my $dav = { fs_type => 'davfs2' }; + ask_server($in, $dav, $all_hds) or return; + push @{$all_hds->{davs}}, $dav; + config($in, $dav, $all_hds); +} + +sub config { + my ($in, $dav_, $all_hds) = @_; + + my $dav = { %$dav_ }; #- working on a local copy so that "Cancel" works + + my $action; + while ($action ne 'Done') { + my %actions = my @actions = actions($dav); + $action = $in->ask_from_list_('', format_dav_info($dav), + [ map { $_->[0] } group_by2 @actions ], 'Done') or return; + $actions{$action}->($in, $dav, $all_hds); + } + %$dav_ = %$dav; #- applying +} + +sub actions { + my ($dav) = @_; + + ( + if_($dav && $dav->{isMounted}, N_("Unmount") => sub { try('Unmount', @_) }), + if_($dav && $dav->{mntpoint} && !$dav->{isMounted}, N_("Mount") => sub { try('Mount', @_) }), + N_("Server") => \&ask_server, + N_("Mount point") => \&mount_point, + N_("Options") => \&options, + N_("Done") => sub {}, + ); +} + +sub try { + my ($name, $in, $dav) = @_; + my $f = $diskdrake::interactive::{$name} or die "unknown function $name"; + eval { $f->($in, {}, $dav) }; + if (my $err = $@) { + $in->ask_warn(N("Error"), formatError($err)); + } +} + +sub ask_server { + my ($in, $dav, $_all_hds) = @_; + + my $server = $dav->{device}; + $in->ask_from_({ messages => N("Please enter the WebDAV server URL"), + focus_first => 1, + callbacks => { + complete => sub { + $server =~ m!https?://! or $in->ask_warn('', N("The URL must begin with http:// or https://")), return 1; + 0; + }, + } }, + [ { val => \$server } ]) or return; + $dav->{device} = $server; +} + +sub options { + my ($in, $dav, $all_hds) = @_; + diskdrake::interactive::Options($in, {}, $dav, $all_hds); +} +sub mount_point { + my ($in, $dav, $all_hds) = @_; + my $proposition = $dav->{device} =~ /(\w+)/ ? "/mnt/$1" : "/mnt/dav"; + diskdrake::interactive::Mount_point_raw_hd($in, $dav, $all_hds, $proposition); +} + +sub format_dav_info { + my ($dav) = @_; + + my $info = ''; + $info .= N("Server: ") . "$dav->{device}\n" if $dav->{device}; + $info .= N("Mount point: ") . "$dav->{mntpoint}\n" if $dav->{mntpoint}; + $info .= N("Options: %s", $dav->{options}) if $dav->{options}; + $info; +} + +1; |