Class: Google::Apis::GkebackupV1::BackupPlan

Inherits:
Object
  • Object
show all
Includes:
Core::Hashable, Core::JsonObjectSupport
Defined in:
lib/google/apis/gkebackup_v1/classes.rb,
lib/google/apis/gkebackup_v1/representations.rb,
lib/google/apis/gkebackup_v1/representations.rb

Overview

Defines the configuration and scheduling for a "line" of Backups.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(**args) ⇒ BackupPlan

Returns a new instance of BackupPlan.



489
490
491
# File 'lib/google/apis/gkebackup_v1/classes.rb', line 489

def initialize(**args)
   update!(**args)
end

Instance Attribute Details

#backup_configGoogle::Apis::GkebackupV1::BackupConfig

BackupConfig defines the configuration of Backups created via this BackupPlan. Corresponds to the JSON property backupConfig



384
385
386
# File 'lib/google/apis/gkebackup_v1/classes.rb', line 384

def backup_config
  @backup_config
end

#backup_scheduleGoogle::Apis::GkebackupV1::Schedule

Defines scheduling parameters for automatically creating Backups via this BackupPlan. Corresponds to the JSON property backupSchedule



390
391
392
# File 'lib/google/apis/gkebackup_v1/classes.rb', line 390

def backup_schedule
  @backup_schedule
end

#clusterString

Required. Immutable. The source cluster from which Backups will be created via this BackupPlan. Valid formats: - projects/*/locations/*/clusters/* - projects/*/zones/*/clusters/* Corresponds to the JSON property cluster

Returns:

  • (String)


397
398
399
# File 'lib/google/apis/gkebackup_v1/classes.rb', line 397

def cluster
  @cluster
end

#create_timeString

Output only. The timestamp when this BackupPlan resource was created. Corresponds to the JSON property createTime

Returns:

  • (String)


402
403
404
# File 'lib/google/apis/gkebackup_v1/classes.rb', line 402

def create_time
  @create_time
end

#deactivatedBoolean Also known as: deactivated?

Optional. This flag indicates whether this BackupPlan has been deactivated. Setting this field to True locks the BackupPlan such that no further updates will be allowed (except deletes), including the deactivated field itself. It also prevents any new Backups from being created via this BackupPlan ( including scheduled Backups). Default: False Corresponds to the JSON property deactivated

Returns:

  • (Boolean)


411
412
413
# File 'lib/google/apis/gkebackup_v1/classes.rb', line 411

def deactivated
  @deactivated
end

#descriptionString

Optional. User specified descriptive string for this BackupPlan. Corresponds to the JSON property description

Returns:

  • (String)


417
418
419
# File 'lib/google/apis/gkebackup_v1/classes.rb', line 417

def description
  @description
end

#etagString

Output only. etag is used for optimistic concurrency control as a way to help prevent simultaneous updates of a backup plan from overwriting each other. It is strongly suggested that systems make use of the 'etag' in the read- modify-write cycle to perform BackupPlan updates in order to avoid race conditions: An etag is returned in the response to GetBackupPlan, and systems are expected to put that etag in the request to UpdateBackupPlan or DeleteBackupPlan to ensure that their change will be applied to the same version of the resource. Corresponds to the JSON property etag

Returns:

  • (String)


429
430
431
# File 'lib/google/apis/gkebackup_v1/classes.rb', line 429

def etag
  @etag
end

#labelsHash<String,String>

Optional. A set of custom labels supplied by user. Corresponds to the JSON property labels

Returns:

  • (Hash<String,String>)


434
435
436
# File 'lib/google/apis/gkebackup_v1/classes.rb', line 434

def labels
  @labels
end

#nameString

Output only. The full name of the BackupPlan resource. Format: projects/*/ locations/*/backupPlans/* Corresponds to the JSON property name

Returns:

  • (String)


440
441
442
# File 'lib/google/apis/gkebackup_v1/classes.rb', line 440

def name
  @name
end

#protected_pod_countFixnum

Output only. The number of Kubernetes Pods backed up in the last successful Backup created via this BackupPlan. Corresponds to the JSON property protectedPodCount

Returns:

  • (Fixnum)


446
447
448
# File 'lib/google/apis/gkebackup_v1/classes.rb', line 446

def protected_pod_count
  @protected_pod_count
end

#retention_policyGoogle::Apis::GkebackupV1::RetentionPolicy

RetentionPolicy defines a Backup retention policy for a BackupPlan. Corresponds to the JSON property retentionPolicy



451
452
453
# File 'lib/google/apis/gkebackup_v1/classes.rb', line 451

def retention_policy
  @retention_policy
end

#rpo_risk_levelFixnum

Output only. A number that represents the current risk level of this BackupPlan from RPO perspective with 1 being no risk and 5 being highest risk. Corresponds to the JSON property rpoRiskLevel

Returns:

  • (Fixnum)


457
458
459
# File 'lib/google/apis/gkebackup_v1/classes.rb', line 457

def rpo_risk_level
  @rpo_risk_level
end

#rpo_risk_reasonString

Output only. Human-readable description of why the BackupPlan is in the current rpo_risk_level and action items if any. Corresponds to the JSON property rpoRiskReason

Returns:

  • (String)


463
464
465
# File 'lib/google/apis/gkebackup_v1/classes.rb', line 463

def rpo_risk_reason
  @rpo_risk_reason
end

#stateString

Output only. State of the BackupPlan. This State field reflects the various stages a BackupPlan can be in during the Create operation. It will be set to " DEACTIVATED" if the BackupPlan is deactivated on an Update Corresponds to the JSON property state

Returns:

  • (String)


470
471
472
# File 'lib/google/apis/gkebackup_v1/classes.rb', line 470

def state
  @state
end

#state_reasonString

Output only. Human-readable description of why BackupPlan is in the current state Corresponds to the JSON property stateReason

Returns:

  • (String)


476
477
478
# File 'lib/google/apis/gkebackup_v1/classes.rb', line 476

def state_reason
  @state_reason
end

#uidString

Output only. Server generated global unique identifier of UUID format. Corresponds to the JSON property uid

Returns:

  • (String)


482
483
484
# File 'lib/google/apis/gkebackup_v1/classes.rb', line 482

def uid
  @uid
end

#update_timeString

Output only. The timestamp when this BackupPlan resource was last updated. Corresponds to the JSON property updateTime

Returns:

  • (String)


487
488
489
# File 'lib/google/apis/gkebackup_v1/classes.rb', line 487

def update_time
  @update_time
end

Instance Method Details

#update!(**args) ⇒ Object

Update properties of this object



494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
# File 'lib/google/apis/gkebackup_v1/classes.rb', line 494

def update!(**args)
  @backup_config = args[:backup_config] if args.key?(:backup_config)
  @backup_schedule = args[:backup_schedule] if args.key?(:backup_schedule)
  @cluster = args[:cluster] if args.key?(:cluster)
  @create_time = args[:create_time] if args.key?(:create_time)
  @deactivated = args[:deactivated] if args.key?(:deactivated)
  @description = args[:description] if args.key?(:description)
  @etag = args[:etag] if args.key?(:etag)
  @labels = args[:labels] if args.key?(:labels)
  @name = args[:name] if args.key?(:name)
  @protected_pod_count = args[:protected_pod_count] if args.key?(:protected_pod_count)
  @retention_policy = args[:retention_policy] if args.key?(:retention_policy)
  @rpo_risk_level = args[:rpo_risk_level] if args.key?(:rpo_risk_level)
  @rpo_risk_reason = args[:rpo_risk_reason] if args.key?(:rpo_risk_reason)
  @state = args[:state] if args.key?(:state)
  @state_reason = args[:state_reason] if args.key?(:state_reason)
  @uid = args[:uid] if args.key?(:uid)
  @update_time = args[:update_time] if args.key?(:update_time)
end