summaryrefslogtreecommitdiff
path: root/sysutils/zetaback/files/opt-localhost.in
blob: 6035e9cf1eb76c8d39ac4873808914125d2a5927 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
--- zetaback.in.orig	2020-05-02 21:18:03 UTC
+++ zetaback.in
@@ -769,7 +769,11 @@ sub zfs_remove_snap($$$) {
   }
   return unless($snap);
   print "Dropping $snap on $fs\n" if($DEBUG);
-  `ssh $ssh_config $host $agent -z $fs -d $snap`;
+  if ($host eq "localhost") {
+      `$agent -z $fs -d $snap`;
+  } else {
+      `ssh $ssh_config $host $agent -z $fs -d $snap`;
+  }
 }
 
 # Lots of args.. internally called.
@@ -832,7 +836,12 @@ sub zfs_do_backup($$$$$$;$) {
       die "Child exit value: $ev" if ($ev);
     }
     else {
-      my @cmd = ('ssh', split(/ /, $ssh_config), $host, $agent, '-z', $fs);
+      my @cmd;
+      if ($host eq "localhost") {
+         @cmd = ($agent, '-z', $fs);
+      } else  {
+         @cmd = ('ssh', split(/ /, $ssh_config), $host, $agent, '-z', $fs);
+      }
       if ($type eq "i" || ($type eq "s" && $base)) {
         push @cmd, ("-i", $base);
       }
@@ -1346,7 +1359,11 @@ sub zfs_restore_part($$$$;$) {
       open(DUMP, "__ZFS__ send $dataset |");
     }
     eval {
-      open(RECEIVER, "| ssh $ssh_config $host $command");
+      if ($host eq "localhost") {
+	  open(RECEIVER, "| $command");
+      } else {
+	  open(RECEIVER, "| ssh $ssh_config $host $command");
+      }
       my $buffer;
       while(my $len = sysread(DUMP, $buffer, $BLOCKSIZE)) {
         if(syswrite(RECEIVER, $buffer, $len) != $len) {
@@ -1573,7 +1590,12 @@ sub plan_and_run($$) {
     # Get list of zfs filesystems from the agent
     open(SILENT, ">&", \*STDERR);
     close(STDERR);
-    my $rv = open(ZFSLIST, "ssh $ssh_config $host $agent -l |");
+    my $rv;
+    if ($host eq "localhost") {
+      $rv = open(ZFSLIST, "$agent -l |");
+    } else {
+      $rv = open(ZFSLIST, "ssh $ssh_config $host $agent -l |");
+    }
     open(STDERR, ">&", \*SILENT);
     close(SILENT);
     next unless $rv;