Source code for models_v2.archival_target_configuration

# -*- coding: utf-8 -*-

import cohesity_management_sdk.models_v2.schedule
import cohesity_management_sdk.models_v2.retention

[docs]class ArchivalTargetConfiguration(object): """Implementation of the 'Archival Target Configuration' model. Specifies settings for copying Snapshots External Targets (such as AWS or Tape). This also specifies the retention policy that should be applied to Snapshots after they have been copied to the specified target. Attributes: schedule (Schedule): Specifies a schedule frequency and schedule unit for copying Snapshots to backup targets. retention (Retention): Specifies the retention of a backup. copy_on_run_success (bool): Specifies if Snapshots are copied from the first completely successful Protection Group Run or the first partially successful Protection Group Run occurring at the start of the replication schedule. <br> If true, Snapshots are copied from the first Protection Group Run occurring at the start of the replication schedule that was completely successful i.e. Snapshots for all the Objects in the Protection Group were successfully captured. <br> If false, Snapshots are copied from the first Protection Group Run occurring at the start of the replication schedule, even if first Protection Group Run was not completely successful i.e. Snapshots were not captured for all Objects in the Protection Group. config_id (string): Specifies the unique identifier for the target getting added. This field need to be passed only when policies are being updated. target_id (long|int): Specifies the Archival target to copy the Snapshots to. target_name (string): Specifies the Archival target name where Snapshots are copied. target_type (TargetTypeEnum): Specifies the Archival target type where Snapshots are copied. """ # Create a mapping from Model property names to API property names _names = { "schedule":'schedule', "retention":'retention', "target_id":'targetId', "copy_on_run_success":'copyOnRunSuccess', "config_id":'configId', "target_name":'targetName', "target_type":'targetType' } def __init__(self, schedule=None, retention=None, target_id=None, copy_on_run_success=None, config_id=None, target_name=None, target_type=None): """Constructor for the ArchivalTargetConfiguration class""" # Initialize members of the class self.schedule = schedule self.retention = retention self.copy_on_run_success = copy_on_run_success self.config_id = config_id self.target_id = target_id self.target_name = target_name self.target_type = target_type
[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 schedule = cohesity_management_sdk.models_v2.schedule.Schedule.from_dictionary(dictionary.get('schedule')) if dictionary.get('schedule') else None retention = cohesity_management_sdk.models_v2.retention.Retention.from_dictionary(dictionary.get('retention')) if dictionary.get('retention') else None target_id = dictionary.get('targetId') copy_on_run_success = dictionary.get('copyOnRunSuccess') config_id = dictionary.get('configId') target_name = dictionary.get('targetName') target_type = dictionary.get('targetType') # Return an object of this model return cls(schedule, retention, target_id, copy_on_run_success, config_id, target_name, target_type)