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 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103
|
package JSON::Validator::OpenAPI::Dancer2;
use Hash::MultiValue;
use Mojo::Base 'JSON::Validator::OpenAPI';
sub _get_request_data {
my ($self, $dsl, $in) = @_;
if ($in eq 'query') {
return $dsl->query_parameters->as_hashref_mixed;
}
elsif ($in eq 'path') {
return $dsl->route_parameters->as_hashref_mixed;
}
elsif ($in eq 'formData') {
return $dsl->body_parameters->as_hashref_mixed;
}
elsif ($in eq 'header') {
return Hash::MultiValue->new($dsl->app->request->headers->flatten)->as_hashref_mixed;
}
elsif ($in eq 'body') {
return $dsl->app->request->data;
}
else {
$self->_invalid_in($in);
}
}
sub _get_request_uploads {
my ($self, $dsl, $name) = @_;
return ($dsl->app->request->upload($name)); # upload() is context-aware
}
sub _get_response_data {
my ($self, $dsl, $in) = @_;
if ($in eq 'header') {
my @headers = $dsl->response->headers->flatten;
return Hash::MultiValue->new(@headers)->as_hashref_mixed;
}
else {
$self->_invalid_in($in);
}
}
sub _set_request_data {
my ($self, $dsl, $in, $name => $value) = @_;
if ($in eq 'query') {
$dsl->query_parameters->set($name => $value);
$dsl->app->request->params->{$name} = $value;
}
elsif ($in eq 'path') {
$dsl->route_parameters->set($name => $value);
}
elsif ($in eq 'formData') {
$dsl->app->request->body_parameters->set($name => $value);
$dsl->app->request->params->{$name} = $value;
}
elsif ($in eq 'header') {
$dsl->app->request->headers->header($name => $value);
}
elsif ($in eq 'body') { } # no need to write body back
else {
$self->_invalid_in($in);
}
}
sub _set_response_data {
my ($self, $dsl, $in, $name => $value) = @_;
if ($in eq 'header') {
$dsl->response->headers->header($name => $value);
}
else {
$self->_invalid_in($in);
}
}
1;
=encoding utf8
=head1 NAME
JSON::Validator::OpenAPI::Dancer2 - Request/response adapter for Dancer2
=head1 SYNOPSIS
See L<JSON::Validator::OpenAPI/SYNOPSIS>.
=head1 DESCRIPTION
This module contains private methods to get/set request/response data for
L<Dancer2>.
=head1 SEE ALSO
L<Dancer2::Plugin::OpenAPI>.
L<JSON::Validator>.
=cut
|