mirror of
https://github.com/jlengrand/openapi-generator.git
synced 2026-05-10 15:54:18 +00:00
* support nested primitive types in ARRARY or HASH for basic object
* run bin/perl-petstore.sh and bin/openapi3/{LANG}-petstore.sh
121 lines
3.5 KiB
Plaintext
Vendored
121 lines
3.5 KiB
Plaintext
Vendored
{{>partial_license}}
|
|
#
|
|
# NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
|
|
# Do not edit the class manually.
|
|
# Ref: https://openapi-generator.tech
|
|
#
|
|
__PACKAGE__->mk_classdata('attribute_map' => {});
|
|
__PACKAGE__->mk_classdata('openapi_types' => {});
|
|
__PACKAGE__->mk_classdata('method_documentation' => {});
|
|
__PACKAGE__->mk_classdata('class_documentation' => {});
|
|
|
|
# new plain object
|
|
sub new {
|
|
my ($class, %args) = @_;
|
|
|
|
my $self = bless {}, $class;
|
|
|
|
$self->init(%args);
|
|
|
|
return $self;
|
|
}
|
|
|
|
# initialize the object
|
|
sub init
|
|
{
|
|
my ($self, %args) = @_;
|
|
|
|
foreach my $attribute (keys %{$self->attribute_map}) {
|
|
my $args_key = $self->attribute_map->{$attribute};
|
|
$self->$attribute( $args{ $args_key } );
|
|
}
|
|
{{#allParents}}
|
|
|
|
# initialize parent object {{{.}}}
|
|
$self->{{moduleName}}::Object::{{{.}}}::init(%args);
|
|
{{/allParents}}
|
|
}
|
|
|
|
# return perl hash
|
|
sub to_hash {
|
|
my $self = shift;
|
|
my $_hash = decode_json(JSON->new->convert_blessed->encode($self));
|
|
{{#allParents}}
|
|
|
|
# call {{{.}}} to_hash and then combine hash
|
|
$_hash = { %$_hash, %$self->{{moduleName}}::Object::{{{.}}}::to_hash };
|
|
{{/allParents}}
|
|
|
|
return $_hash;
|
|
}
|
|
|
|
# used by JSON for serialization
|
|
sub TO_JSON {
|
|
my $self = shift;
|
|
my $_data = {};
|
|
foreach my $_key (keys %{$self->attribute_map}) {
|
|
if (defined $self->{$_key}) {
|
|
$_data->{$self->attribute_map->{$_key}} = $self->{$_key};
|
|
}
|
|
}
|
|
{{#allParents}}
|
|
|
|
# combine parent ({{{.}}}) TO_JSON
|
|
$_data = { %$_data, %$self->{{moduleName}}::Object::{{{.}}}::TO_JSON };
|
|
{{/allParents}}
|
|
|
|
return $_data;
|
|
}
|
|
|
|
# from Perl hashref
|
|
sub from_hash {
|
|
my ($self, $hash) = @_;
|
|
|
|
# loop through attributes and use openapi_types to deserialize the data
|
|
while ( my ($_key, $_type) = each %{$self->openapi_types} ) {
|
|
my $_json_attribute = $self->attribute_map->{$_key};
|
|
if ($_type =~ /^array\[(.+)\]$/i) { # array
|
|
my $_subclass = $1;
|
|
my @_array = ();
|
|
foreach my $_element (@{$hash->{$_json_attribute}}) {
|
|
push @_array, $self->_deserialize($_subclass, $_element);
|
|
}
|
|
$self->{$_key} = \@_array;
|
|
} elsif ($_type =~ /^hash\[string,(.+)\]$/i) { # hash
|
|
my $_subclass = $1;
|
|
my %_hash = ();
|
|
while (my($_key, $_element) = each %{$hash->{$_json_attribute}}) {
|
|
$_hash{$_key} = $self->_deserialize($_subclass, $_element);
|
|
}
|
|
$self->{$_key} = \%_hash;
|
|
} elsif (exists $hash->{$_json_attribute}) { #hash(model), primitive, datetime
|
|
$self->{$_key} = $self->_deserialize($_type, $hash->{$_json_attribute});
|
|
} else {
|
|
$log->debugf("Warning: %s (%s) does not exist in input hash\n", $_key, $_json_attribute);
|
|
}
|
|
}
|
|
{{#allParents}}
|
|
|
|
# call parent ({{{.}}}) from_hash
|
|
$self->{{moduleName}}::Object::{{{.}}}::from_hash($hash);
|
|
{{/allParents}}
|
|
|
|
return $self;
|
|
}
|
|
|
|
# deserialize non-array data
|
|
sub _deserialize {
|
|
my ($self, $type, $data) = @_;
|
|
$log->debugf("deserializing %s with %s",Dumper($data), $type);
|
|
|
|
if ($type eq 'DateTime') {
|
|
return DateTime->from_epoch(epoch => str2time($data));
|
|
} elsif ( grep( /^$type$/, ('int', 'double', 'string', 'boolean'))) {
|
|
return $data;
|
|
} else { # hash(model)
|
|
my $_instance = eval "{{moduleName}}::Object::$type->new()";
|
|
return $_instance->from_hash($data);
|
|
}
|
|
}
|
|
|