mirror of
https://github.com/percona/percona-toolkit.git
synced 2025-09-10 05:00:45 +00:00
Use 'Content-Type: multipart/form-data; boundary=Ym91bmRhcnk' to send multi-part data.
This commit is contained in:
43
bin/pt-agent
43
bin/pt-agent
@@ -969,9 +969,9 @@ sub post {
|
||||
}
|
||||
|
||||
sub put {
|
||||
my ($self, %args) = @_;
|
||||
my $self = shift;
|
||||
$self->_set(
|
||||
%args,
|
||||
@_,
|
||||
method => 'PUT',
|
||||
);
|
||||
return $self->response->header('Location');
|
||||
@@ -979,7 +979,6 @@ sub put {
|
||||
|
||||
sub delete {
|
||||
my ($self, %args) = @_;
|
||||
|
||||
have_required_args(\%args, qw(
|
||||
link
|
||||
)) or die;
|
||||
@@ -1006,7 +1005,6 @@ sub delete {
|
||||
|
||||
sub _set {
|
||||
my ($self, %args) = @_;
|
||||
|
||||
have_required_args(\%args, qw(
|
||||
method
|
||||
resources
|
||||
@@ -1016,6 +1014,8 @@ sub _set {
|
||||
my $res = $args{resources};
|
||||
my $link = $args{link};
|
||||
|
||||
my $headers = $args{headers};
|
||||
|
||||
my $content = '';
|
||||
if ( ref($res) eq 'ARRAY' ) {
|
||||
PTDEBUG && _d('List of resources');
|
||||
@@ -1047,6 +1047,7 @@ sub _set {
|
||||
method => $method,
|
||||
link => $link,
|
||||
content => $content,
|
||||
headers => $headers,
|
||||
);
|
||||
};
|
||||
if ( my $e = $EVAL_ERROR ) {
|
||||
@@ -1070,27 +1071,22 @@ sub _request {
|
||||
)) or die;
|
||||
my $method = $args{method};
|
||||
my $link = $args{link};
|
||||
|
||||
my @optional_args = (
|
||||
'content',
|
||||
'headers',
|
||||
);
|
||||
my ($content, $headers) = @args{@optional_args};
|
||||
|
||||
my $content = $args{content};
|
||||
my $headers = $args{headers};
|
||||
|
||||
my $req = HTTP::Request->new($method => $link);
|
||||
$req->content($content) if $content;
|
||||
if ( uc($method) eq 'DELETE' ) {
|
||||
$self->ua->default_header('Content-Length' => 0);
|
||||
if ( $content ) {
|
||||
$req->content($content);
|
||||
}
|
||||
if ( $headers ) {
|
||||
map { $req->header($_ => $headers->{$_}) } keys %$headers;
|
||||
}
|
||||
PTDEBUG && _d('Request', $method, $link, Dumper($req));
|
||||
|
||||
my $response = $self->ua->request($req);
|
||||
PTDEBUG && _d('Response', Dumper($response));
|
||||
|
||||
if ( uc($method) eq 'DELETE' ) {
|
||||
$self->ua->default_header('Content-Length' => undef);
|
||||
}
|
||||
|
||||
if ( !($response->code >= 200 && $response->code < 400) ) {
|
||||
die Percona::WebAPI::Exception::Request->new(
|
||||
method => $method,
|
||||
@@ -5650,7 +5646,7 @@ sub send_file {
|
||||
my $agent_json = as_json($agent, json => $json);
|
||||
chomp($agent_json);
|
||||
|
||||
my $boundary = '--Ym91bmRhcnk='; # "boundary" in base64
|
||||
my $boundary = 'Ym91bmRhcnk'; # "boundary" in base64, without a trailing =
|
||||
|
||||
my $data = slurp($file);
|
||||
$data =~ s/^\s+//;
|
||||
@@ -5658,14 +5654,23 @@ sub send_file {
|
||||
|
||||
# Put it all together:
|
||||
my $resource = <<CONTENT;
|
||||
--$boundary
|
||||
Content-Disposition: form-data; name="agent"
|
||||
|
||||
$agent_json
|
||||
$boundary
|
||||
--$boundary
|
||||
Content-Disposition: form-data; name="data"
|
||||
|
||||
$data
|
||||
--$boundary
|
||||
CONTENT
|
||||
|
||||
$client->post(
|
||||
link => $link,
|
||||
resources => $resource,
|
||||
headers => {
|
||||
'Content-Type' => "multipart/form-data; boundary=$boundary",
|
||||
}
|
||||
);
|
||||
|
||||
return;
|
||||
|
@@ -35,12 +35,14 @@ sub new {
|
||||
post => [],
|
||||
put => [],
|
||||
},
|
||||
last_request => undef,
|
||||
};
|
||||
return bless $self, $class;
|
||||
}
|
||||
|
||||
sub request {
|
||||
my ($self, $req) = @_;
|
||||
$self->{last_request} = $req;
|
||||
my $type = lc($req->method);
|
||||
push @{$self->{requests}}, uc($type) . ' ' . $req->uri;
|
||||
if ( $type eq 'post' || $type eq 'put' ) {
|
||||
|
@@ -168,12 +168,10 @@ sub post {
|
||||
return $self->response->header('Location');
|
||||
}
|
||||
|
||||
# For a successful PUT, the server returns nothing because the caller
|
||||
# already has the resources URI (if not, the caller should POST).
|
||||
sub put {
|
||||
my ($self, %args) = @_;
|
||||
my $self = shift;
|
||||
$self->_set(
|
||||
%args,
|
||||
@_,
|
||||
method => 'PUT',
|
||||
);
|
||||
return $self->response->header('Location');
|
||||
@@ -181,7 +179,6 @@ sub put {
|
||||
|
||||
sub delete {
|
||||
my ($self, %args) = @_;
|
||||
|
||||
have_required_args(\%args, qw(
|
||||
link
|
||||
)) or die;
|
||||
@@ -209,7 +206,6 @@ sub delete {
|
||||
# Low-level POST and PUT handler.
|
||||
sub _set {
|
||||
my ($self, %args) = @_;
|
||||
|
||||
have_required_args(\%args, qw(
|
||||
method
|
||||
resources
|
||||
@@ -219,6 +215,9 @@ sub _set {
|
||||
my $res = $args{resources};
|
||||
my $link = $args{link};
|
||||
|
||||
# Optional args
|
||||
my $headers = $args{headers};
|
||||
|
||||
my $content = '';
|
||||
if ( ref($res) eq 'ARRAY' ) {
|
||||
PTDEBUG && _d('List of resources');
|
||||
@@ -250,6 +249,7 @@ sub _set {
|
||||
method => $method,
|
||||
link => $link,
|
||||
content => $content,
|
||||
headers => $headers,
|
||||
);
|
||||
};
|
||||
if ( my $e = $EVAL_ERROR ) {
|
||||
@@ -276,27 +276,23 @@ sub _request {
|
||||
)) or die;
|
||||
my $method = $args{method};
|
||||
my $link = $args{link};
|
||||
|
||||
my @optional_args = (
|
||||
'content',
|
||||
'headers',
|
||||
);
|
||||
my ($content, $headers) = @args{@optional_args};
|
||||
|
||||
# Optional args
|
||||
my $content = $args{content};
|
||||
my $headers = $args{headers};
|
||||
|
||||
my $req = HTTP::Request->new($method => $link);
|
||||
$req->content($content) if $content;
|
||||
if ( uc($method) eq 'DELETE' ) {
|
||||
$self->ua->default_header('Content-Length' => 0);
|
||||
if ( $content ) {
|
||||
$req->content($content);
|
||||
}
|
||||
if ( $headers ) {
|
||||
map { $req->header($_ => $headers->{$_}) } keys %$headers;
|
||||
}
|
||||
PTDEBUG && _d('Request', $method, $link, Dumper($req));
|
||||
|
||||
my $response = $self->ua->request($req);
|
||||
PTDEBUG && _d('Response', Dumper($response));
|
||||
|
||||
if ( uc($method) eq 'DELETE' ) {
|
||||
$self->ua->default_header('Content-Length' => undef);
|
||||
}
|
||||
|
||||
if ( !($response->code >= 200 && $response->code < 400) ) {
|
||||
die Percona::WebAPI::Exception::Request->new(
|
||||
method => $method,
|
||||
|
@@ -1,8 +1,13 @@
|
||||
--Ym91bmRhcnk
|
||||
Content-Disposition: form-data; name="agent"
|
||||
|
||||
{
|
||||
"hostname" : "prod1",
|
||||
"uuid" : "123"
|
||||
}
|
||||
--Ym91bmRhcnk=
|
||||
--Ym91bmRhcnk
|
||||
Content-Disposition: form-data; name="data"
|
||||
|
||||
[
|
||||
{
|
||||
"attributes" : {
|
||||
@@ -74,3 +79,4 @@
|
||||
}
|
||||
}
|
||||
]
|
||||
--Ym91bmRhcnk
|
||||
|
@@ -138,6 +138,12 @@ ok(
|
||||
"Removed data file after sending successfully"
|
||||
);
|
||||
|
||||
is(
|
||||
$ua->{last_request}->header('content-type'),
|
||||
'multipart/form-data; boundary=Ym91bmRhcnk',
|
||||
'Content-Type=multipart/form-data; boundary=Ym91bmRhcnk'
|
||||
) or diag(Dumper($ua));
|
||||
|
||||
# #############################################################################
|
||||
# Done.
|
||||
# #############################################################################
|
||||
|
Reference in New Issue
Block a user