Class: Pvectl::Services::Backup
- Inherits:
-
Object
- Object
- Pvectl::Services::Backup
- Defined in:
- lib/pvectl/services/backup.rb
Overview
Orchestrates backup operations.
Handles creating, listing, deleting, and restoring backups for VMs and containers with multi-ID support and error handling.
Constant Summary collapse
- DEFAULT_TIMEOUT =
5 minutes for backups
300
Instance Method Summary collapse
-
#create(vmids, storage:, mode: "snapshot", compress: "zstd", notes: nil, protected: false) ⇒ Array<Models::OperationResult>
Creates backups for multiple VMs.
-
#delete(volid) ⇒ Models::OperationResult
Deletes a backup.
-
#initialize(backup_repo:, resource_resolver:, task_repo:, options: {}) ⇒ Backup
constructor
Creates a new Backup service.
-
#list(vmid: nil, storage: nil) ⇒ Array<Models::Backup>
Lists backups with optional filtering.
-
#restore(volid, vmid:, storage: nil, force: false, start: false, unique: false) ⇒ Models::OperationResult
Restores a backup to a VM/container.
Constructor Details
#initialize(backup_repo:, resource_resolver:, task_repo:, options: {}) ⇒ Backup
Creates a new Backup service.
27 28 29 30 31 32 |
# File 'lib/pvectl/services/backup.rb', line 27 def initialize(backup_repo:, resource_resolver:, task_repo:, options: {}) @backup_repo = backup_repo @resolver = resource_resolver @task_repo = task_repo @options = end |
Instance Method Details
#create(vmids, storage:, mode: "snapshot", compress: "zstd", notes: nil, protected: false) ⇒ Array<Models::OperationResult>
Creates backups for multiple VMs.
52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 |
# File 'lib/pvectl/services/backup.rb', line 52 def create(vmids, storage:, mode: "snapshot", compress: "zstd", notes: nil, protected: false) resources = @resolver.resolve_multiple(vmids) return [] if resources.empty? execute_multi(resources, :create) do |resource| @backup_repo.create( resource[:vmid], resource[:node], storage: storage, mode: mode, compress: compress, notes: notes, protected: protected ) end end |
#delete(volid) ⇒ Models::OperationResult
Deletes a backup.
73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 |
# File 'lib/pvectl/services/backup.rb', line 73 def delete(volid) node = find_node_for_volid(volid) upid = @backup_repo.delete(volid, node) if @options[:async] Models::OperationResult.new( resource: { volid: volid, node: node }, operation: :delete, task_upid: upid, success: :pending ) else task = @task_repo.wait(upid, timeout: timeout) Models::OperationResult.new( resource: { volid: volid, node: node }, operation: :delete, task: task, success: task.successful? ) end rescue StandardError => e Models::OperationResult.new( resource: { volid: volid }, operation: :delete, success: false, error: e. ) end |
#list(vmid: nil, storage: nil) ⇒ Array<Models::Backup>
Lists backups with optional filtering.
39 40 41 |
# File 'lib/pvectl/services/backup.rb', line 39 def list(vmid: nil, storage: nil) @backup_repo.list(vmid: vmid, storage: storage) end |
#restore(volid, vmid:, storage: nil, force: false, start: false, unique: false) ⇒ Models::OperationResult
Restores a backup to a VM/container.
112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 |
# File 'lib/pvectl/services/backup.rb', line 112 def restore(volid, vmid:, storage: nil, force: false, start: false, unique: false) node = find_node_for_volid(volid) upid = @backup_repo.restore( volid, node, vmid: vmid, storage: storage, force: force, start: start, unique: unique ) if @options[:async] Models::OperationResult.new( resource: { volid: volid, vmid: vmid, node: node }, operation: :restore, task_upid: upid, success: :pending ) else task = @task_repo.wait(upid, timeout: timeout) Models::OperationResult.new( resource: { volid: volid, vmid: vmid, node: node }, operation: :restore, task: task, success: task.successful? ) end rescue StandardError => e Models::OperationResult.new( resource: { volid: volid, vmid: vmid }, operation: :restore, success: false, error: e. ) end |