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: //gi thub . com /openapitools/o penapi - 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: //o penapi - 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::V1KeyToPath ;
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
#
#Maps a string key to a path within a volume.
#
# 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: //gi thub . com /openapitools/o penapi - 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: //o penapi - 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 = > 'Maps a string key to a path within a volume.' ,
class = > 'V1KeyToPath' ,
required = > [] , # TODO
}
) ;
__PACKAGE__ - > method_documentation (
{
'key' = > {
datatype = > 'string' ,
base_name = > 'key' ,
description = > 'The key to project.' ,
format = > '' ,
read_only = > '' ,
} ,
'mode' = > {
datatype = > 'int' ,
base_name = > 'mode' ,
description = >
'Optional: mode bits to use on this file, must be a value between 0 and 0777. If not specified, the volume defaultMode will be used. This might be in conflict with other options that affect the file mode, like fsGroup, and the result can be other mode bits set.' ,
format = > '' ,
read_only = > '' ,
} ,
'path' = > {
datatype = > 'string' ,
base_name = > 'path' ,
description = >
'The relative path of the file to map the key to. May not be an absolute path. May not contain the path element '..'. May not start with the string '..'.' ,
format = > '' ,
read_only = > '' ,
} ,
}
) ;
2019-03-23 16:42:23 +08:00
2019-04-24 12:07:57 +08:00
__PACKAGE__ - > openapi_types (
{
'key' = > 'string' ,
'mode' = > 'int' ,
'path' = > 'string'
}
) ;
2019-03-23 16:42:23 +08:00
2019-04-24 12:07:57 +08:00
__PACKAGE__ - > attribute_map (
{
'key' = > 'key' ,
'mode' = > 'mode' ,
'path' = > 'path'
}
) ;
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 ;