X-Git-Url: http://gb7djk.dxcluster.net/gitweb/gitweb.cgi?a=blobdiff_plain;f=perl%2FAsyncMsg.pm;h=ff3b3bca07c01eae0c52afbc43a6cebfe08830c8;hb=4b49fe47b37249d748f0a52fe2a778d4bc27232f;hp=b1875d97bb8fa9d5698e30a1f5efcfa547cee159;hpb=f643e3f3103b73c60f9a0106754e060d3ea6d707;p=spider.git diff --git a/perl/AsyncMsg.pm b/perl/AsyncMsg.pm index b1875d97..ff3b3bca 100644 --- a/perl/AsyncMsg.pm +++ b/perl/AsyncMsg.pm @@ -118,6 +118,8 @@ sub _getpost $conn->{_assort} = $sort; $conn->{csort} = 'http'; + my $data = delete $args{data}; + my $ua = Mojo::UserAgent->new; my $s; $s .= $host; @@ -132,7 +134,6 @@ sub _getpost $ua->on(start => sub { my ($ua, $tx) = @_; - my $data = delete $args{data}; while (my ($k, $v) = each %args) { dbg("AsyncMsg: attaching header $k: $v") if isdbg('async'); $tx->req->headers->header($k => $v); @@ -202,9 +203,11 @@ sub raw my %args = @_; my $handler = delete $args{handler} || \&handle_raw; + my $conn = $pkg->new($call, $handler); $conn->{prefix} = delete $args{prefix} if exists $args{prefix}; $conn->{prefix} ||= ''; + $conn->{on_disconnect} = delete $args{on_disc} || delete $args{on_disconnect}; $r = $conn->connect($host, $port, on_connect => &_on_raw_connect); return $r ? $conn : undef; }