# -*- coding: utf-8 -*-
# Copyright 2021 Cohesity Inc.
[docs]class ConnectorParameters(object):
"""Implementation of the 'ConnectorParameters' model.
Specifies the parameters required to establish a connection with
a particular environment.
Attributes:
endpoint (string): Specify an IP address or URL of the environment.
(such as the IP address of the vCenter Server for a VMware
environment).
environment (EnvironmentConnectorParametersEnum): Specifies the
environment like VMware, SQL, where the Protection Source exists.
Supported environment types such as 'kView', 'kSQL', 'kVMware',
etc. NOTE: 'kPuppeteer' refers to Cohesity's Remote Adapter.
'kVMware' indicates the VMware Protection Source environment.
'kHyperV' indicates the HyperV Protection Source environment.
'kSQL' indicates the SQL Protection Source environment. 'kView'
indicates the View Protection Source environment. 'kPuppeteer'
indicates the Cohesity's Remote Adapter. 'kPhysical' indicates the
physical Protection Source environment. 'kPure' indicates the Pure
Storage Protection Source environment. 'Nimble' indicates the
Nimble Storage Protection Source environment. 'kAzure' indicates
the Microsoft's Azure Protection Source environment. 'kNetapp'
indicates the Netapp Protection Source environment. 'kAgent'
indicates the Agent Protection Source environment. 'kGenericNas'
indicates the Generic Network Attached Storage Protection Source
environment. 'kAcropolis' indicates the Acropolis Protection
Source environment. 'kPhsicalFiles' indicates the Physical Files
Protection Source environment. 'kIsilon' indicates the Dell EMC's
Isilon Protection Source environment. 'kGPFS' indicates IBM's GPFS
Protection Source environment. 'kKVM' indicates the KVM Protection
Source environment. 'kAWS' indicates the AWS Protection Source
environment. 'kExchange' indicates the Exchange Protection Source
environment. 'kHyperVVSS' indicates the HyperV VSS Protection
Source environment. 'kOracle' indicates the Oracle Protection
Source environment. 'kGCP' indicates the Google Cloud Platform
Protection Source environment. 'kFlashBlade' indicates the Flash
Blade Protection Source environment. 'kAWSNative' indicates the
AWS Native Protection Source environment. 'kO365' indicates the
Office 365 Protection Source environment. 'kO365Outlook' indicates
Office 365 outlook Protection Source environment. 'kHyperFlex'
indicates the Hyper Flex Protection Source environment.
'kGCPNative' indicates the GCP Native Protection Source
environment. 'kAzureNative' indicates the Azure Native
Protection Source environment. 'kKubernetes' indicates a
Kubernetes Protection Source environment. 'kElastifile'
indicates Elastifile Protection Source environment. 'kAD'
indicates Active Directory Protection Source environment.
'kRDSSnapshotManager' indicates AWS RDS Protection Source
environment. 'kCassandra' indicates Cassandra Protection Source
environment. 'kMongoDB' indicates MongoDB Protection Source
environment. 'kCouchbase' indicates Couchbase Protection Source
environment. 'kHdfs' indicates Hdfs Protection Source environment.
'kHive' indicates Hive Protection Source environment. 'kHBase'
indicates HBase Protection Source environment.
id (long|int): Specifies a Unique id that is generated when the Source
is registered. This is a convenience field that is used to
maintain an index to different connection params.
version (long|int): Version is updated each time the connector
parameters are updated. This is used to discard older connector
parameters.
"""
# Create a mapping from Model property names to API property names
_names = {
"endpoint":'endpoint',
"environment":'environment',
"id":'id',
"version":'version'
}
def __init__(self,
endpoint=None,
environment=None,
id=None,
version=None):
"""Constructor for the ConnectorParameters class"""
# Initialize members of the class
self.endpoint = endpoint
self.environment = environment
self.id = id
self.version = version
[docs] @classmethod
def from_dictionary(cls,
dictionary):
"""Creates an instance of this model from a dictionary
Args:
dictionary (dictionary): A dictionary representation of the object as
obtained from the deserialization of the server's response. The keys
MUST match property names in the API description.
Returns:
object: An instance of this structure class.
"""
if dictionary is None:
return None
# Extract variables from the dictionary
endpoint = dictionary.get('endpoint')
environment = dictionary.get('environment')
id = dictionary.get('id')
version = dictionary.get('version')
# Return an object of this model
return cls(endpoint,
environment,
id,
version)