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

234 lines
7.2 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::V1ConfigMapVolumeSource;
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;
use Kubernetes::Object::V1KeyToPath;
2019-04-24 12:07:57 +08:00
use base ( "Class::Accessor", "Class::Data::Inheritable" );
2019-03-23 16:42:23 +08:00
#
#Adapts a ConfigMap into a volume. The contents of the target ConfigMap's Data field will be presented in a volume as files using the keys in the Data field as the file names, unless the items element is populated with specific mappings of keys to paths. ConfigMap volumes support ownership management and SELinux relabeling.
#
# 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 =>
'Adapts a ConfigMap into a volume. The contents of the target ConfigMap's Data field will be presented in a volume as files using the keys in the Data field as the file names, unless the items element is populated with specific mappings of keys to paths. ConfigMap volumes support ownership management and SELinux relabeling.',
class => 'V1ConfigMapVolumeSource',
required => [], # TODO
}
);
__PACKAGE__->method_documentation(
{
'default_mode' => {
datatype => 'int',
base_name => 'defaultMode',
description =>
'Optional: mode bits to use on created files by default. Must be a value between 0 and 0777. Defaults to 0644. Directories within the path are not affected by this setting. 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 => '',
},
'items' => {
datatype => 'ARRAY[V1KeyToPath]',
base_name => 'items',
description =>
'If unspecified, each key-value pair in the Data field of the referenced ConfigMap will be projected into the volume as a file whose name is the key and content is the value. If specified, the listed keys will be projected into the specified paths, and unlisted keys will not be present. If a key is specified which is not present in the ConfigMap, the volume setup will error unless it is marked optional. Paths must be relative and may not contain the '..' path or start with '..'.',
format => '',
read_only => '',
},
'name' => {
datatype => 'string',
base_name => 'name',
description =>
'Name of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names',
format => '',
read_only => '',
},
'optional' => {
datatype => 'boolean',
base_name => 'optional',
description =>
'Specify whether the ConfigMap or it's keys must be defined',
format => '',
read_only => '',
},
}
);
__PACKAGE__->openapi_types(
{
'default_mode' => 'int',
'items' => 'ARRAY[V1KeyToPath]',
'name' => 'string',
'optional' => 'boolean'
}
);
__PACKAGE__->attribute_map(
{
'default_mode' => 'defaultMode',
'items' => 'items',
'name' => 'name',
'optional' => 'optional'
}
);
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;