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

292 lines
8.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::V1ScaleIOVolumeSource;
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::V1LocalObjectReference;
2019-04-24 12:07:57 +08:00
use base ( "Class::Accessor", "Class::Data::Inheritable" );
2019-03-23 16:42:23 +08:00
#
#ScaleIOVolumeSource represents a persistent ScaleIO 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://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 =>
'ScaleIOVolumeSource represents a persistent ScaleIO volume',
class => 'V1ScaleIOVolumeSource',
required => [], # TODO
}
);
__PACKAGE__->method_documentation(
{
'fs_type' => {
datatype => 'string',
base_name => 'fsType',
description =>
'Filesystem type to mount. Must be a filesystem type supported by the host operating system. Ex. \"ext4\", \"xfs\", \"ntfs\". Default is \"xfs\".',
format => '',
read_only => '',
},
'gateway' => {
datatype => 'string',
base_name => 'gateway',
description => 'The host address of the ScaleIO API Gateway.',
format => '',
read_only => '',
},
'protection_domain' => {
datatype => 'string',
base_name => 'protectionDomain',
description =>
'The name of the ScaleIO Protection Domain for the configured storage.',
format => '',
read_only => '',
},
'read_only' => {
datatype => 'boolean',
base_name => 'readOnly',
description =>
'Defaults to false (read/write). ReadOnly here will force the ReadOnly setting in VolumeMounts.',
format => '',
read_only => '',
},
'secret_ref' => {
datatype => 'V1LocalObjectReference',
base_name => 'secretRef',
description => '',
format => '',
read_only => '',
},
'ssl_enabled' => {
datatype => 'boolean',
base_name => 'sslEnabled',
description =>
'Flag to enable/disable SSL communication with Gateway, default false',
format => '',
read_only => '',
},
'storage_mode' => {
datatype => 'string',
base_name => 'storageMode',
description =>
'Indicates whether the storage for a volume should be ThickProvisioned or ThinProvisioned. Default is ThinProvisioned.',
format => '',
read_only => '',
},
'storage_pool' => {
datatype => 'string',
base_name => 'storagePool',
description =>
'The ScaleIO Storage Pool associated with the protection domain.',
format => '',
read_only => '',
},
'system' => {
datatype => 'string',
base_name => 'system',
description =>
'The name of the storage system as configured in ScaleIO.',
format => '',
read_only => '',
},
'volume_name' => {
datatype => 'string',
base_name => 'volumeName',
description =>
'The name of a volume already created in the ScaleIO system that is associated with this volume source.',
format => '',
read_only => '',
},
}
);
__PACKAGE__->openapi_types(
{
'fs_type' => 'string',
'gateway' => 'string',
'protection_domain' => 'string',
'read_only' => 'boolean',
'secret_ref' => 'V1LocalObjectReference',
'ssl_enabled' => 'boolean',
'storage_mode' => 'string',
'storage_pool' => 'string',
'system' => 'string',
'volume_name' => 'string'
}
);
__PACKAGE__->attribute_map(
{
'fs_type' => 'fsType',
'gateway' => 'gateway',
'protection_domain' => 'protectionDomain',
'read_only' => 'readOnly',
'secret_ref' => 'secretRef',
'ssl_enabled' => 'sslEnabled',
'storage_mode' => 'storageMode',
'storage_pool' => 'storagePool',
'system' => 'system',
'volume_name' => 'volumeName'
}
);
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;