Files
perl/lib/Kubernetes/Object/V1ServicePort.pm

241 lines
7.3 KiB
Perl
Raw Permalink Normal View History

2019-04-24 12:07:57 +08:00
2019-03-23 16:42:23 +08:00
=begin comment
Kubernetes
No description provided (generated by Openapi Generator https://github.com/openapitools/openapi-generator)
2019-05-16 20:24:00 +08:00
The version of the OpenAPI document: v1.13.7
2019-03-23 16:42:23 +08:00
Generated by: https://openapi-generator.tech
=end comment
=cut
#
# 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 Kubernetes::Object::V1ServicePort;
require 5.6.0;
use strict;
use warnings;
use utf8;
use JSON qw(decode_json);
use Data::Dumper;
use Module::Runtime qw(use_module);
use Log::Any qw($log);
use Date::Parse;
use DateTime;
2019-04-24 12:07:57 +08:00
use base ( "Class::Accessor", "Class::Data::Inheritable" );
2019-03-23 16:42:23 +08:00
#
#ServicePort contains information on service's port.
#
# NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). Do not edit the class manually.
# REF: https://openapi-generator.tech
#
=begin comment
Kubernetes
No description provided (generated by Openapi Generator https://github.com/openapitools/openapi-generator)
2019-05-16 20:24:00 +08:00
The version of the OpenAPI document: v1.13.7
2019-03-23 16:42:23 +08:00
Generated by: https://openapi-generator.tech
=end comment
=cut
#
# NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
# Do not edit the class manually.
# Ref: https://openapi-generator.tech
#
2019-04-24 12:07:57 +08:00
__PACKAGE__->mk_classdata( 'attribute_map' => {} );
__PACKAGE__->mk_classdata( 'openapi_types' => {} );
__PACKAGE__->mk_classdata( 'method_documentation' => {} );
__PACKAGE__->mk_classdata( 'class_documentation' => {} );
2019-03-23 16:42:23 +08:00
2019-05-16 20:24:00 +08:00
# new plain object
2019-04-24 12:07:57 +08:00
sub new {
my ( $class, %args ) = @_;
my $self = bless {}, $class;
2019-05-16 20:24:00 +08:00
$self->init(%args);
2019-04-24 12:07:57 +08:00
return $self;
}
2019-03-23 16:42:23 +08:00
2019-05-16 20:24:00 +08:00
# 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} );
}
}
2019-03-23 16:42:23 +08:00
# return perl hash
sub to_hash {
2019-05-16 20:24:00 +08:00
my $self = shift;
my $_hash = decode_json( JSON->new->convert_blessed->encode($self) );
return $_hash;
2019-03-23 16:42:23 +08:00
}
# used by JSON for serialization
2019-04-24 12:07:57 +08:00
sub TO_JSON {
my $self = shift;
2019-03-23 16:42:23 +08:00
my $_data = {};
2019-04-24 12:07:57 +08:00
foreach my $_key ( keys %{ $self->attribute_map } ) {
if ( defined $self->{$_key} ) {
$_data->{ $self->attribute_map->{$_key} } = $self->{$_key};
2019-03-23 16:42:23 +08:00
}
}
2019-05-16 20:24:00 +08:00
2019-03-23 16:42:23 +08:00
return $_data;
}
# from Perl hashref
sub from_hash {
2019-04-24 12:07:57 +08:00
my ( $self, $hash ) = @_;
2019-03-23 16:42:23 +08:00
# loop through attributes and use openapi_types to deserialize the data
2019-04-24 12:07:57 +08:00
while ( my ( $_key, $_type ) = each %{ $self->openapi_types } ) {
my $_json_attribute = $self->attribute_map->{$_key};
2019-05-16 20:24:00 +08:00
if ( $_type =~ /^array\[(.+)\]$/i ) { # array
my $_subclass = $1;
2019-04-24 12:07:57 +08:00
my @_array = ();
foreach my $_element ( @{ $hash->{$_json_attribute} } ) {
push @_array, $self->_deserialize( $_subclass, $_element );
2019-03-23 16:42:23 +08:00
}
$self->{$_key} = \@_array;
2019-04-24 12:07:57 +08:00
}
2019-05-16 20:24:00 +08:00
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;
}
2019-04-24 12:07:57 +08:00
elsif ( exists $hash->{$_json_attribute} )
2019-05-16 20:24:00 +08:00
{ #hash(model), primitive, datetime
2019-04-24 12:07:57 +08:00
$self->{$_key} =
$self->_deserialize( $_type, $hash->{$_json_attribute} );
}
else {
$log->debugf( "Warning: %s (%s) does not exist in input hash\n",
$_key, $_json_attribute );
2019-03-23 16:42:23 +08:00
}
}
2019-04-24 12:07:57 +08:00
2019-03-23 16:42:23 +08:00
return $self;
}
# deserialize non-array data
sub _deserialize {
2019-04-24 12:07:57 +08:00
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' ) ) ) {
2019-03-23 16:42:23 +08:00
return $data;
2019-04-24 12:07:57 +08:00
}
else { # hash(model)
2019-03-23 16:42:23 +08:00
my $_instance = eval "Kubernetes::Object::$type->new()";
return $_instance->from_hash($data);
}
}
2019-04-24 12:07:57 +08:00
__PACKAGE__->class_documentation(
{
description =>
'ServicePort contains information on service's port.',
class => 'V1ServicePort',
required => [], # TODO
}
);
__PACKAGE__->method_documentation(
{
'name' => {
datatype => 'string',
base_name => 'name',
description =>
'The name of this port within the service. This must be a DNS_LABEL. All ports within a ServiceSpec must have unique names. This maps to the 'Name' field in EndpointPort objects. Optional if only one ServicePort is defined on this service.',
format => '',
read_only => '',
},
'node_port' => {
datatype => 'int',
base_name => 'nodePort',
description =>
'The port on each node on which this service is exposed when type=NodePort or LoadBalancer. Usually assigned by the system. If specified, it will be allocated to the service if unused or else creation of the service will fail. Default is to auto-allocate a port if the ServiceType of this Service requires one. More info: https://kubernetes.io/docs/concepts/services-networking/service/#type-nodeport',
format => '',
read_only => '',
},
'port' => {
datatype => 'int',
base_name => 'port',
description => 'The port that will be exposed by this service.',
format => '',
read_only => '',
},
'protocol' => {
datatype => 'string',
base_name => 'protocol',
description =>
'The IP protocol for this port. Supports \"TCP\", \"UDP\", and \"SCTP\". Default is TCP.',
format => '',
read_only => '',
},
'target_port' => {
datatype => 'object',
base_name => 'targetPort',
description =>
'Number or name of the port to access on the pods targeted by the service. Number must be in the range 1 to 65535. Name must be an IANA_SVC_NAME. If this is a string, it will be looked up as a named port in the target Pod's container ports. If this is not specified, the value of the 'port' field is used (an identity map). This field is ignored for services with clusterIP=None, and should be omitted or set equal to the 'port' field. More info: https://kubernetes.io/docs/concepts/services-networking/service/#defining-a-service',
format => '',
read_only => '',
},
}
);
__PACKAGE__->openapi_types(
{
'name' => 'string',
'node_port' => 'int',
'port' => 'int',
'protocol' => 'string',
'target_port' => 'object'
}
);
__PACKAGE__->attribute_map(
{
'name' => 'name',
'node_port' => 'nodePort',
'port' => 'port',
'protocol' => 'protocol',
'target_port' => 'targetPort'
}
);
2019-03-23 16:42:23 +08:00
2019-04-24 12:07:57 +08:00
__PACKAGE__->mk_accessors( keys %{ __PACKAGE__->attribute_map } );
2019-03-23 16:42:23 +08:00
1;