]> git.treefish.org Git - fex.git/blobdiff - bin/sexsend
Original release 20150826
[fex.git] / bin / sexsend
index 7340e497e98b97a984f2de429cba3699d947e7e7..ff3f1ed5d367d8cd5e12c3bb12f82dc7e203f212 100755 (executable)
@@ -12,14 +12,14 @@ use Getopt::Std;
 use Socket;
 use IO::Handle;
 use IO::Socket::INET;
 use Socket;
 use IO::Handle;
 use IO::Socket::INET;
-use Digest::MD5 qw(md5_hex);  # encypted ID / SID 
+use Digest::MD5 qw(md5_hex);  # encypted ID / SID
 
 use constant k => 2**10;
 use constant M => 2**20;
 
 eval 'use Net::INET6Glue::INET_is_INET6';
 
 
 use constant k => 2**10;
 use constant M => 2**20;
 
 eval 'use Net::INET6Glue::INET_is_INET6';
 
-our $version = 20150120;
+our $version = 20150826;
 
 my %SSL = (SSL_version => 'TLSv1');
 my $sigpipe;
 
 my %SSL = (SSL_version => 'TLSv1');
 my $sigpipe;
@@ -32,7 +32,7 @@ $0 =~ s:.*/::;
 $| = 1;
 
 # sexsend is default
 $| = 1;
 
 # sexsend is default
-$usage = 
+$usage =
   "usage: ... | $0 [options] [SEX-URL/]recipient [stream]\n".
   "options: -v           verbose mode\n".
   "         -g           show transfer rate\n".
   "usage: ... | $0 [options] [SEX-URL/]recipient [stream]\n".
   "options: -v           verbose mode\n".
   "         -g           show transfer rate\n".
@@ -43,7 +43,7 @@ $usage =
   "example: tail -f /var/log/syslog | $0 fex.flupp.org/admin log\n";
 
 if ($0 eq 'sexget' or $0 eq 'fuckme') {
   "example: tail -f /var/log/syslog | $0 fex.flupp.org/admin log\n";
 
 if ($0 eq 'sexget' or $0 eq 'fuckme') {
-  $usage = 
+  $usage =
     "usage: $0 [options] [[SEX-URL/]user:ID] [stream]\n".
     "options: -v           verbose mode\n".
     "         -g           show transfer rate\n".
     "usage: $0 [options] [[SEX-URL/]user:ID] [stream]\n".
     "options: -v           verbose mode\n".
     "         -g           show transfer rate\n".
@@ -56,7 +56,7 @@ if ($0 eq 'sexget' or $0 eq 'fuckme') {
 }
 
 if ($0 eq 'sexxx') {
 }
 
 if ($0 eq 'sexxx') {
-  $usage = 
+  $usage =
     "usage: $0 [-v] [-g] [-c] [-u [SEX-URL/]user] [-s stream] [files...]\n".
     "usage: $0 [-v] [-g]      [-u [SEX-URL/]user] [-s stream] | ...\n".
     "options: -v               verbose mode\n".
     "usage: $0 [-v] [-g] [-c] [-u [SEX-URL/]user] [-s stream] [files...]\n".
     "usage: $0 [-v] [-g]      [-u [SEX-URL/]user] [-s stream] | ...\n".
     "options: -v               verbose mode\n".
@@ -102,7 +102,7 @@ $opt_u = $opt_s = $opt_c = $opt_t = '';
 $_ = "$fexhome/config.pl"; require if -f;
 
 if ($0 eq 'sexxx') {
 $_ = "$fexhome/config.pl"; require if -f;
 
 if ($0 eq 'sexxx') {
-  
+
   # xx server URL, user and auth-ID
   if ($FEXXX = $ENV{FEXXX}) {
     $FEXXX = decode_b64($FEXXX) if $FEXXX !~ /\s/;
   # xx server URL, user and auth-ID
   if ($FEXXX = $ENV{FEXXX}) {
     $FEXXX = decode_b64($FEXXX) if $FEXXX !~ /\s/;
@@ -118,7 +118,7 @@ if ($0 eq 'sexxx') {
     }
     close $idf;
   }
     }
     close $idf;
   }
-  
+
   getopts('hgvcu:s:') or die $usage;
   die $usage if $opt_h;
   die $usage unless -t;
   getopts('hgvcu:s:') or die $usage;
   die $usage if $opt_h;
   die $usage unless -t;
@@ -140,7 +140,7 @@ if ($0 eq 'sexxx') {
   unless ($user) {
     die "$0: no xx user found, use \"$0 -u user\"\n";
   }
   unless ($user) {
     die "$0: no xx user found, use \"$0 -u user\"\n";
   }
-  
+
 } elsif ($0 eq 'sexget' or $0 eq 'fuckme') {
   getopts('hgvVdu:') or die $usage;
   die $usage if $opt_h;
 } elsif ($0 eq 'sexget' or $0 eq 'fuckme') {
   getopts('hgvVdu:') or die $usage;
   die $usage if $opt_h;
@@ -150,11 +150,11 @@ if ($0 eq 'sexxx') {
     print "Version: $version\n";
     exit unless @ARGV;
   }
     print "Version: $version\n";
     exit unless @ARGV;
   }
-  
+
   if (not $opt_u and @ARGV and $ARGV[0] =~ m{^anonymous|/|:}) {
     $opt_u = shift @ARGV;
   }
   if (not $opt_u and @ARGV and $ARGV[0] =~ m{^anonymous|/|:}) {
     $opt_u = shift @ARGV;
   }
-  
+
   if ($opt_u) {
     $fexcgi = $1 if $opt_u =~ s:(.+)/::;
     ($user,$id) = split(':',$opt_u);
   if ($opt_u) {
     $fexcgi = $1 if $opt_u =~ s:(.+)/::;
     ($user,$id) = split(':',$opt_u);
@@ -168,13 +168,13 @@ if ($0 eq 'sexxx') {
   unless ($fexcgi) {
     die "$0: no SEX URL found, use \"$0 -u SEX-URL/recipient\" or \"fexsend -I\"\n";
   }
   unless ($fexcgi) {
     die "$0: no SEX URL found, use \"$0 -u SEX-URL/recipient\" or \"fexsend -I\"\n";
   }
-  
+
   unless ($user) {
     die "$0: no recipient found, use \"$0 -u SEX-URL/recipient\" or \"fexsend -I\"\n";
   }
   unless ($user) {
     die "$0: no recipient found, use \"$0 -u SEX-URL/recipient\" or \"fexsend -I\"\n";
   }
-  
+
 } else { # sexsend
 } else { # sexsend
-  
+
   $opt_g = 1;
   getopts('hguvqVTt:') or die $usage;
   die $usage if $opt_h;
   $opt_g = 1;
   getopts('hguvqVTt:') or die $usage;
   die $usage if $opt_h;
@@ -183,7 +183,7 @@ if ($0 eq 'sexxx') {
     print "Version: $version\n";
     exit unless @ARGV;
   }
     print "Version: $version\n";
     exit unless @ARGV;
   }
-  
+
   if ($opt_t and $opt_t =~ /^\d+$/) {
     $timeout = "&timeout=$opt_t";
   }
   if ($opt_t and $opt_t =~ /^\d+$/) {
     $timeout = "&timeout=$opt_t";
   }
@@ -191,7 +191,7 @@ if ($0 eq 'sexxx') {
   my $save_user = $user;
   $user = shift or die $usage;
   $fexcgi = $1 if $user =~ s:(.+)/::;
   my $save_user = $user;
   $user = shift or die $usage;
   $fexcgi = $1 if $user =~ s:(.+)/::;
-  
+
   if ($user =~ /^anonymous/) {
     die "$0: need SEX-URL with anonymous SEX\n" unless $fexcgi;
     $mode = 'anonymous';
   if ($user =~ /^anonymous/) {
     die "$0: need SEX-URL with anonymous SEX\n" unless $fexcgi;
     $mode = 'anonymous';
@@ -211,7 +211,7 @@ if ($0 eq 'sexxx') {
       die "$0: no SEX URL found, use \"$0 SEX-URL/recipient\" or \"fexsend -I\"\n";
     }
   }
       die "$0: no SEX URL found, use \"$0 SEX-URL/recipient\" or \"fexsend -I\"\n";
     }
   }
-  
+
 }
 
 &get_ssl_env;
 }
 
 &get_ssl_env;
@@ -220,14 +220,14 @@ $fexcgi =~ s(^http://)()i;
 $fexcgi =~ s(/fup.*)();
 $server = $fexcgi;
 
 $fexcgi =~ s(/fup.*)();
 $server = $fexcgi;
 
-if    ($server =~ s(^https://)()i) { $port = 443 } 
-elsif ($server =~ /:(\d+)/)        { $port = $1 } 
-else                               { $port = 80 }    
+if    ($server =~ s(^https://)()i) { $port = 443 }
+elsif ($server =~ /:(\d+)/)        { $port = $1 }
+else                               { $port = 80 }
 
 $server =~ s([:/].*)();
 
 ## set up tcp/ip connection
 
 $server =~ s([:/].*)();
 
 ## set up tcp/ip connection
-# $iaddr = gethostbyname($server) 
+# $iaddr = gethostbyname($server)
 #          or die "$0: cannot find ip-address for $server $!\n";
 # socket(SH,PF_INET,SOCK_STREAM,getprotobyname('tcp')) or die "$0: socket $!\n";
 # connect(SH,sockaddr_in($port,$iaddr)) or die "$0: connect $!\n";
 #          or die "$0: cannot find ip-address for $server $!\n";
 # socket(SH,PF_INET,SOCK_STREAM,getprotobyname('tcp')) or die "$0: socket $!\n";
 # connect(SH,sockaddr_in($port,$iaddr)) or die "$0: connect $!\n";
@@ -240,21 +240,21 @@ if ($port == 443) {
   }
   eval "use IO::Socket::SSL";
   die "$0: cannot load IO::Socket::SSL\n" if $@;
   }
   eval "use IO::Socket::SSL";
   die "$0: cannot load IO::Socket::SSL\n" if $@;
-  $SH = IO::Socket::SSL->new(                                                  
-    PeerAddr => $server,                                                       
-    PeerPort => $port,                                                         
+  $SH = IO::Socket::SSL->new(
+    PeerAddr => $server,
+    PeerPort => $port,
     Proto    => 'tcp',
     %SSL
     Proto    => 'tcp',
     %SSL
-  );                                                                           
-} else {                                                                       
+  );
+} else {
   $SH = IO::Socket::INET->new(
     PeerAddr => $server,
     PeerPort => $port,
   $SH = IO::Socket::INET->new(
     PeerAddr => $server,
     PeerPort => $port,
-    Proto    => 'tcp',                                                         
-  );                                                                           
+    Proto    => 'tcp',
+  );
 }
 
 }
 
-die "cannot connect $server:$port - $!\n" unless $SH;                          
+die "cannot connect $server:$port - $!\n" unless $SH;
 warn "TCPCONNECT to $server:$port\n" if $opt_v;
 
 # autoflush $SH 1;
 warn "TCPCONNECT to $server:$port\n" if $opt_v;
 
 # autoflush $SH 1;
@@ -331,7 +331,7 @@ request("POST /sex?BS=$bs&user=$user$mode$type$timeout$stream HTTP/1.0");
 print STDERR "==> (streaming ...)\n" if $opt_v;
 
 transfer(STDIN,$SH);
 print STDERR "==> (streaming ...)\n" if $opt_v;
 
 transfer(STDIN,$SH);
-  
+
 exit;
 
 
 exit;
 
 
@@ -340,7 +340,7 @@ sub transfer {
   my $destination = shift;
   my ($t0,$t1,$tt);
   my ($B,$b,$bt);
   my $destination = shift;
   my ($t0,$t1,$tt);
   my ($B,$b,$bt);
-  
+
   $t0 = $t2 = time;
   $tt = $t0-1;
   $t1 = 0;
   $t0 = $t2 = time;
   $tt = $t0-1;
   $t1 = 0;
@@ -370,9 +370,9 @@ sub transfer {
   }
 
   die "$0: no stream data\n" unless $B;
   }
 
   die "$0: no stream data\n" unless $B;
-  
+
   $tt = (time-$t0)||1;
   $tt = (time-$t0)||1;
-  
+
   if ($opt_v or $opt_g) {
     if ($B>2097152) {
       printf STDERR "transfered: %d MB in %d s with %d kB/s\n",
   if ($opt_v or $opt_g) {
     if ($B>2097152) {
       printf STDERR "transfered: %d MB in %d s with %d kB/s\n",
@@ -385,13 +385,13 @@ sub transfer {
         $B,$tt,int($B/1024/$tt);
     }
   }
         $B,$tt,int($B/1024/$tt);
     }
   }
-  
+
 }
 
 
 sub request {
   my $req = shift;
 }
 
 
 sub request {
   my $req = shift;
-  
+
   print STDERR "==> $req\n" if $opt_v;
   syswrite $SH,"$req\r\n\r\n";
   for (;;) {
   print STDERR "==> $req\n" if $opt_v;
   syswrite $SH,"$req\r\n\r\n";
   for (;;) {
@@ -456,12 +456,12 @@ sub query_sid {
   my ($server,$port,$id) = @_;
   my $req;
   local $_;
   my ($server,$port,$id) = @_;
   my $req;
   local $_;
-  
+
   $req = "GET SID HTTP/1.1";
   print STDERR "==> $req\n" if $opt_v;
   syswrite $SH,"$req\r\n\r\n";
   $_ = &getline;
   $req = "GET SID HTTP/1.1";
   print STDERR "==> $req\n" if $opt_v;
   syswrite $SH,"$req\r\n\r\n";
   $_ = &getline;
-  unless (defined $_ and /\w/) { 
+  unless (defined $_ and /\w/) {
     print STDERR "\n" if $opt_v;
     die "$0: no response from server\n";
   }
     print STDERR "\n" if $opt_v;
     die "$0: no response from server\n";
   }
@@ -469,7 +469,7 @@ sub query_sid {
   if (/^HTTP.* 201 (.+)/) {
     print STDERR "<== $_" if $opt_v;
     $id = 'MD5H:'.md5_hex($id.$1);
   if (/^HTTP.* 201 (.+)/) {
     print STDERR "<== $_" if $opt_v;
     $id = 'MD5H:'.md5_hex($id.$1);
-    while (defined($_ = &getline)) { 
+    while (defined($_ = &getline)) {
       s/\r//;
       last if /^\n/;
       print STDERR "<== $_" if $opt_v;
       s/\r//;
       last if /^\n/;
       print STDERR "<== $_" if $opt_v;
@@ -480,7 +480,7 @@ sub query_sid {
   return $id;
 }
 
   return $id;
 }
 
-sub sigpipehandler { 
+sub sigpipehandler {
   local $_ = '';
   $SIG{ALRM} = sub { };
   alarm(1);
   local $_ = '';
   $SIG{ALRM} = sub { };
   alarm(1);
@@ -503,15 +503,15 @@ sub getline {
 
   local $SIG{ALRM} = sub { die "$0: timeout while waiting for server reply\n" };
   alarm($opt_t||300);
 
   local $SIG{ALRM} = sub { die "$0: timeout while waiting for server reply\n" };
   alarm($opt_t||300);
-  
+
   # must use sysread to avoid perl line buffering
   while (sysread $SH,$c,1) {
     $line .= $c;
     last if $c eq "\n";
   }
   # must use sysread to avoid perl line buffering
   while (sysread $SH,$c,1) {
     $line .= $c;
     last if $c eq "\n";
   }
-  
+
   alarm(0);
   alarm(0);
-  
+
   return $line;
 }
 
   return $line;
 }
 
@@ -520,7 +520,7 @@ sub decode_b64 {
   local $_ = shift;
   my $uu = '';
   my ($i,$l);
   local $_ = shift;
   my $uu = '';
   my ($i,$l);
-  
+
   tr|A-Za-z0-9+=/||cd;
   s/=+$//;
   tr|A-Za-z0-9+/| -_|;
   tr|A-Za-z0-9+=/||cd;
   s/=+$//;
   tr|A-Za-z0-9+/| -_|;
@@ -559,9 +559,9 @@ sub get_ssl_env {
   $SSL{SSL_verify_mode} = $ENV{SSLVERIFY} if defined($ENV{SSLVERIFY});
   foreach my $opt (qw(
     SSL_version
   $SSL{SSL_verify_mode} = $ENV{SSLVERIFY} if defined($ENV{SSLVERIFY});
   foreach my $opt (qw(
     SSL_version
-    SSL_cipher_list 
-    SSL_verify_mode 
-    SSL_ca_path 
+    SSL_cipher_list
+    SSL_verify_mode
+    SSL_ca_path
     SSL_ca_file)
   ) {
     my $env = uc($opt);
     SSL_ca_file)
   ) {
     my $env = uc($opt);
@@ -604,13 +604,13 @@ sub serverconnect {
   my ($server,$port) = @_;
   my $connect = "CONNECT $server:$port HTTP/1.1";
   local $_;
   my ($server,$port) = @_;
   my $connect = "CONNECT $server:$port HTTP/1.1";
   local $_;
-  
+
   if ($opt_v and $port == 443 and %SSL) {
     foreach my $v (keys %SSL) {
       printf "%s => %s\n",$v,$SSL{$v};
     }
   }
   if ($opt_v and $port == 443 and %SSL) {
     foreach my $v (keys %SSL) {
       printf "%s => %s\n",$v,$SSL{$v};
     }
   }
-  
+
   if ($proxy) {
     tcpconnect(split(':',$proxy));
     if ($port == 443) {
   if ($proxy) {
     tcpconnect(split(':',$proxy));
     if ($port == 443) {
@@ -638,12 +638,12 @@ sub serverconnect {
 # set up tcp/ip connection
 sub tcpconnect {
   my ($server,$port) = @_;
 # set up tcp/ip connection
 sub tcpconnect {
   my ($server,$port) = @_;
-  
+
   if ($SH) {
     close $SH;
     undef $SH;
   }
   if ($SH) {
     close $SH;
     undef $SH;
   }
-  
+
   if ($port == 443) {
     # eval "use IO::Socket::SSL qw(debug3)";
     eval "use IO::Socket::SSL";
   if ($port == 443) {
     # eval "use IO::Socket::SSL qw(debug3)";
     eval "use IO::Socket::SSL";
@@ -661,13 +661,13 @@ sub tcpconnect {
       Proto    => 'tcp',
     );
   }
       Proto    => 'tcp',
     );
   }
-  
+
   if ($SH) {
     autoflush $SH 1;
   } else {
     die "$0: cannot connect $server:$port - $@\n";
   }
   if ($SH) {
     autoflush $SH 1;
   } else {
     die "$0: cannot connect $server:$port - $@\n";
   }
-  
+
   print "TCPCONNECT to $server:$port\n" if $opt_v;
 }
 
   print "TCPCONNECT to $server:$port\n" if $opt_v;
 }
 
@@ -676,9 +676,9 @@ sub sendheader {
   my $sp = shift;
   my @head = @_;
   my $head;
   my $sp = shift;
   my @head = @_;
   my $head;
-  
+
   push @head,"Host: $sp";
   push @head,"Host: $sp";
-  
+
   foreach $head (@head) {
     print "--> $head\n" if $opt_v;
     print {$SH} $head,"\r\n";
   foreach $head (@head) {
     print "--> $head\n" if $opt_v;
     print {$SH} $head,"\r\n";
@@ -690,12 +690,12 @@ sub sendheader {
 
 sub nvtsend {
   local $SIG{PIPE} = sub { $sigpipe = "@_" };
 
 sub nvtsend {
   local $SIG{PIPE} = sub { $sigpipe = "@_" };
-  
+
   $sigpipe = '';
   $sigpipe = '';
-  
+
   die "$0: internal error: no active network handle\n" unless $SH;
   die "$0: remote host has closed the link\n" unless $SH->connected;
   die "$0: internal error: no active network handle\n" unless $SH;
   die "$0: remote host has closed the link\n" unless $SH->connected;
-  
+
   foreach my $line (@_) {
     print {$SH} $line,"\r\n";
     if ($sigpipe) {
   foreach my $line (@_) {
     print {$SH} $line,"\r\n";
     if ($sigpipe) {
@@ -703,7 +703,7 @@ sub nvtsend {
       return 0;
     }
   }
       return 0;
     }
   }
-  
+
   return 1;
 }
 
   return 1;
 }
 
@@ -713,7 +713,7 @@ sub encode_b64 {
   my $res = "";
   my $eol = "\n";
   my $padding;
   my $res = "";
   my $eol = "\n";
   my $padding;
-  
+
   pos($_[0]) = 0;
   $res = join '',map(pack('u',$_)=~ /^.(\S*)/, ($_[0]=~/(.{1,45})/gs));
   $res =~ tr|` -_|AA-Za-z0-9+/|;
   pos($_[0]) = 0;
   $res = join '',map(pack('u',$_)=~ /^.(\S*)/, ($_[0]=~/(.{1,45})/gs));
   $res =~ tr|` -_|AA-Za-z0-9+/|;