# solaris-lib.pl # supported_filesystems() # Returns a list of filesystem types on which dumping is supported sub supported_filesystems { local @rv; push(@rv, "ufs") if (&has_command("ufsdump")); return @rv; } # multiple_directory_support(fs) # Returns 1 if some filesystem dump supports multiple directories sub multiple_directory_support { return $_[0] eq "ufs"; } # dump_form(&dump) sub dump_form { # Display common options print " ",&hlink($text{'dump_dest'}, "dest"), " \n"; printf " %s\n", $_[0]->{'host'} ? '' : 'checked', $text{'dump_file'}; printf " %s
\n", $_[0]->{'host'} ? '' : $_[0]->{'file'}, &file_chooser_button("file"); printf "\n", $_[0]->{'host'} ? 'checked' : ''; print &text('dump_host', "", "", ""), " \n"; } sub dump_options_form { print " ",&hlink($text{'dump_update'},"update"), "\n"; printf " %s\n", $_[0]->{'update'} ? 'checked' : '', $text{'yes'}; printf " %s\n", $_[0]->{'update'} ? '' : 'checked', $text{'no'}; print "",&hlink($text{'dump_verify'},"verify"),"\n"; printf " %s\n", $_[0]->{'verify'} ? 'checked' : '', $text{'yes'}; printf " %s \n", $_[0]->{'verify'} ? '' : 'checked', $text{'no'}; print " ",&hlink($text{'dump_level'},"level"),"\n"; print "\n"; print "",&hlink($text{'dump_offline'},"offline"),"\n"; printf " %s\n", $_[0]->{'offline'} ? 'checked' : '', $text{'yes'}; printf " %s \n", $_[0]->{'offline'} ? '' : 'checked', $text{'no'}; } # parse_dump(&dump) sub parse_dump { # Parse common options if ($in{'mode'} == 0) { $in{'file'} =~ /\S/ || &error($text{'dump_efile'}); $_[0]->{'file'} = $in{'file'}; delete($_[0]->{'host'}); delete($_[0]->{'huser'}); delete($_[0]->{'hfile'}); } else { gethostbyname($in{'host'}) || &check_ipaddress($in{'host'}) || &error($text{'dump_ehost'}); $_[0]->{'host'} = $in{'host'}; $in{'huser'} =~ /^\S+$/ || &error($text{'dump_ehuser'}); $_[0]->{'huser'} = $in{'huser'}; $in{'hfile'} || &error($text{'dump_ehfile'}); $_[0]->{'hfile'} = $in{'hfile'}; delete($_[0]->{'file'}); } $_[0]->{'update'} = $in{'update'}; $_[0]->{'verify'} = $in{'verify'}; $_[0]->{'level'} = $in{'level'}; $_[0]->{'offline'} = $in{'offline'}; } # execute_dump(&dump, filehandle, escape) # Executes a dump and displays the output sub execute_dump { local $fh = $_[1]; local $cmd = "ufsdump $_[0]->{'level'}"; $cmd .= "u" if ($_[0]->{'update'}); $cmd .= "v" if ($_[0]->{'verify'}); $cmd .= "o" if ($_[0]->{'offline'}); if ($_[0]->{'huser'}) { $cmd .= "f '$_[0]->{'huser'}\@$_[0]->{'host'}:". &date_subs($_[0]->{'hfile'})."'"; } elsif ($_[0]->{'host'}) { $cmd .= "f '$_[0]->{'host'}:".&date_subs($_[0]->{'hfile'})."'"; } else { $cmd .= "f '".&date_subs($_[0]->{'file'})."'"; } $cmd .= " $_[0]->{'extra'}" if ($_[0]->{'extra'}); $cmd .= " ".join(" ", map { "'$_'" } split(/\s+/, $_[0]->{'dir'})); &system_logged("sync"); sleep(1); &additional_log('exec', undef, $cmd); &open_execute_command(CMD, "$cmd 2>&1 ) { if ($_[2]) { print $fh &html_escape($_); } else { print $fh $_; } } close(CMD); return $? ? 0 : 1; } # dump_dest(&dump) sub dump_dest { if ($_[0]->{'file'}) { return "".&html_escape($_[0]->{'file'}).""; } elsif ($_[0]->{'huser'}) { return "".&html_escape("$_[0]->{'huser'}\@$_[0]->{'host'}:$_[0]->{'hfile'}").""; } else { return "".&html_escape("$_[0]->{'host'}:$_[0]->{'hfile'}").""; } } # missing_restore_command(filesystem) sub missing_restore_command { return &has_command("ufsrestore") ? undef : "ufsrestore"; } # restore_form(filesystem) sub restore_form { # common options print " ",&hlink($text{'restore_src'}, "rsrc"), "\n"; printf " %s\n", $_[1]->{'host'} ? "" : "checked", $text{'dump_file'}; printf " %s
\n", $_[1]->{'host'} ? "" : $_[0]->{'file'}, &file_chooser_button("file"); printf "\n", $_[1]->{'host'} ? "checked" : ""; print &text('dump_host', "", "", ""), " \n"; print " ",&hlink($text{'restore_files'},"rfiles"), "\n"; print " ", "$text{'restore_all'}\n"; print " $text{'restore_sel'}\n"; print " \n"; print " ",&hlink($text{'restore_dir'},"rdir"),"\n"; print " ",&file_chooser_button("dir", 1), " \n"; print " ",&hlink($text{'restore_test'},"rtest"),"\n"; print " $text{'yes'}\n"; print " $text{'no'} \n"; } # parse_restore(filesystem) # Parses inputs from restore_form() and returns a command to be passed to # restore_backup() sub parse_restore { local $cmd; $cmd = "ufsrestore"; $cmd .= ($in{'test'} ? " t" : " x"); if ($in{'mode'} == 0) { $in{'file'} || &error($text{'restore_efile'}); $cmd .= "f '$in{'file'}'"; } else { gethostbyname($in{'host'}) || &check_ipaddress($in{'host'}) || &error($text{'restore_ehost'}); $in{'huser'} =~ /^\S*$/ || &error($text{'restore_ehuser'}); $in{'hfile'} || &error($text{'restore_ehfile'}); if ($in{'huser'}) { $cmd .= "f '$in{'huser'}\@$in{'host'}:$in{'hfile'}'"; } else { $cmd .= "f '$in{'host'}:$in{'hfile'}'"; } } $cmd .= " $in{'extra'}" if ($in{'extra'}); if (!$in{'files_def'}) { $in{'files'} || &error($text{'restore_efiles'}); $cmd .= " $in{'files'}"; } -d $in{'dir'} || &error($text{'restore_edir'}); return $cmd; } # restore_backup(filesystem, command) # Restores a backup based on inputs from restore_form(), and displays the results sub restore_backup { &additional_log('exec', undef, $_[1]); &foreign_require("proc", "proc-lib.pl"); local ($fh, $fpid) = &foreign_call("proc", "pty_process_exec", "cd '$in{'dir'}' ; $_[1]"); local $donevolume; while(1) { local $rv = &wait_for($fh, "(next volume #)", "(set owner.mode for.*\\[yn\\])", "(Directories already exist, set modes anyway. \\[yn\\])", "((.*)\\[yn\\])", "(.*\\n)"); last if ($rv < 0); print &html_escape($matches[1]); if ($rv == 0) { if ($donevolume++) { return $text{'restore_evolume'}; } else { syswrite($fh, "1\n", 2); } } elsif ($rv == 1 || $rv == 2) { syswrite($fh, "n\n", 2); } elsif ($rv == 3) { return &text('restore_equestion', "$matches[2]"); } } close($fh); waitpid($fpid, 0); return $? || undef; } 1;