diff options
author | Marc Espie <espie@cvs.openbsd.org> | 2011-07-19 17:30:06 +0000 |
---|---|---|
committer | Marc Espie <espie@cvs.openbsd.org> | 2011-07-19 17:30:06 +0000 |
commit | 5a7f9213701f3848ea0439ba3960564ac99aa3a8 (patch) | |
tree | adff1a03c03a15bb03921c3f88cf72fe0e1fe4a8 | |
parent | 875839cf13a48a9d1981bc56e48e6d73b45826bf (diff) |
use common code for ssh/http 1.1
-rw-r--r-- | usr.sbin/pkg_add/OpenBSD/PackageRepository/SCP.pm | 119 |
1 files changed, 4 insertions, 115 deletions
diff --git a/usr.sbin/pkg_add/OpenBSD/PackageRepository/SCP.pm b/usr.sbin/pkg_add/OpenBSD/PackageRepository/SCP.pm index 9f2296dfb80..e0aa597a2dd 100644 --- a/usr.sbin/pkg_add/OpenBSD/PackageRepository/SCP.pm +++ b/usr.sbin/pkg_add/OpenBSD/PackageRepository/SCP.pm @@ -1,5 +1,5 @@ # ex:ts=8 sw=4: -# $OpenBSD: SCP.pm,v 1.26 2011/03/23 15:29:31 espie Exp $ +# $OpenBSD: SCP.pm,v 1.27 2011/07/19 17:30:05 espie Exp $ # # Copyright (c) 2003-2006 Marc Espie <espie@openbsd.org> # @@ -18,8 +18,10 @@ use strict; use warnings; +use OpenBSD::PackageRepository::Persistant; + package OpenBSD::PackageRepository::SCP; -our @ISA=qw(OpenBSD::PackageRepository::Distant); +our @ISA=qw(OpenBSD::PackageRepository::Persistant); use IPC::Open2; use IO::Handle; @@ -30,8 +32,6 @@ sub urlscheme return 'scp'; } -our %distant = (); - # Any SCP repository uses one single connection, reliant on a perl at end. # The connection starts by xfering and firing up the `distant' script. sub initiate @@ -57,117 +57,6 @@ sub initiate seek(DATA, 0, 0); } - -sub may_exist -{ - my ($self, $name) = @_; - my $l = $self->list; - return grep {$_ eq $name } @$l; -} - -sub grab_object -{ - my ($self, $object) = @_; - - my $cmdfh = $self->{cmdfh}; - my $getfh = $self->{getfh}; - - print $cmdfh "ABORT\n"; - my $_; - while (<$getfh>) { - last if m/^ABORTED/o; - } - print $cmdfh "GET ", $self->{path}.$object->{name}.".tgz", "\n"; - close($cmdfh); - $_ = <$getfh>; - chomp; - if (m/^ERROR:/o) { - $self->{state}->fatal("transfer error: #1", $_); - } - if (m/^TRANSFER:\s+(\d+)/o) { - my $buffsize = 10 * 1024; - my $buffer; - my $size = $1; - my $remaining = $size; - my $n; - - do { - $n = read($getfh, $buffer, - $remaining < $buffsize ? $remaining :$buffsize); - if (!defined $n) { - $self->{state}->fatal("Error reading: #1", $!); - } - $remaining -= $n; - if ($n > 0) { - syswrite STDOUT, $buffer; - } - } while ($n != 0 && $remaining != 0); - exit(0); - } -} - -sub maxcount -{ - return 1; -} - -sub opened -{ - my $self = $_[0]; - my $k = $self->{host}; - if (!defined $distant{$k}) { - $distant{$k} = []; - } - return $distant{$k}; -} - -sub list -{ - my ($self) = @_; - if (!defined $self->{list}) { - if (!defined $self->{controller}) { - $self->initiate; - } - my $cmdfh = $self->{cmdfh}; - my $getfh = $self->{getfh}; - my $path = $self->{path}; - my $l = []; - print $cmdfh "LIST $path\n"; - my $_; - $_ = <$getfh>; - if (!defined $_) { - $self->{state}->fatal("Could not initiate SSH session"); - } - chomp; - if (m/^ERROR:/o) { - $self->{state}->fatal("#1", $_); - } - if (!m/^SUCCESS:/o) { - $self->{state}->fatal("Synchronization error"); - } - while (<$getfh>) { - chomp; - last if $_ eq ''; - push(@$l, $_); - } - $self->{list} = $l; - } - return $self->{list}; -} - -sub cleanup -{ - my $self = shift; - if (defined $self->{controller}) { - my $cmdfh = $self->{cmdfh}; - my $getfh = $self->{getfh}; - print $cmdfh "ABORT\nBYE\nBYE\n"; - CORE::close($cmdfh); - CORE::close($getfh); - waitpid($self->{controller}, 0); - } -} - 1; __DATA__ # Distant connection script. |