BackupProvider.php 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. <?php
  2. /* * ********************************************************************
  3. * ProxmoxVPS Product developed. (27.03.19)
  4. * *
  5. *
  6. * CREATED BY MODULESGARDEN -> http://modulesgarden.com
  7. * CONTACT -> contact@modulesgarden.com
  8. *
  9. *
  10. * This software is furnished under a license and may be used and copied
  11. * only in accordance with the terms of such license and with the
  12. * inclusion of the above copyright notice. This software or any other
  13. * copies thereof may not be provided or otherwise made available to any
  14. * other person. No title to and ownership of the software is hereby
  15. * transferred.
  16. *
  17. *
  18. * ******************************************************************** */
  19. namespace ModulesGarden\Servers\ProxmoxCloudVps\App\UI\Backup\Providers;
  20. use MGProvision\Proxmox\v2\models\File;
  21. use ModulesGarden\ProxmoxAddon\App\Jobs\Cloud\RestoreVm;
  22. use ModulesGarden\ProxmoxAddon\App\Services\ApiService;
  23. use ModulesGarden\ProxmoxAddon\App\Services\Cloud\ProductService;
  24. use ModulesGarden\ProxmoxAddon\App\Enum\Cloud\ConfigurableOption;
  25. use ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Interfaces\ClientArea;
  26. use ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\ResponseTemplates\HtmlDataJsonResponse;
  27. use ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Forms\DataProviders\BaseDataProvider;
  28. use function ModulesGarden\ProxmoxAddon\Core\Helper\queue;
  29. use function ModulesGarden\Servers\ProxmoxCloudVps\Core\Helper\sl;
  30. class BackupProvider extends BaseDataProvider implements ClientArea
  31. {
  32. use ProductService;
  33. use ApiService;
  34. public function read()
  35. {
  36. if ($this->actionElementId)
  37. {
  38. $this->data = json_decode(base64_decode($this->actionElementId), true);
  39. }
  40. $this->availableValues['compress'] = [
  41. "0" => sl("lang")->abtr("None"),
  42. "lzo" => sl("lang")->abtr("LZO (fast)"),
  43. "gzip" => sl("lang")->abtr("GZIP (good)"),
  44. "zstd" => sl("lang")->abtr("ZSTD (fast and good)")
  45. ];
  46. $optionBackupCompress = $this->configuration()->getPermissionBackupCompress();
  47. if(empty($optionBackupCompress)){
  48. return;
  49. }
  50. foreach ($this->availableValues['compress'] as $k => $option){
  51. if($k=="0" && !in_array("none", $optionBackupCompress)){
  52. unset($this->availableValues['compress'][$k]);
  53. }
  54. if(!in_array($k, $optionBackupCompress)){
  55. unset($this->availableValues['compress'][$k]);
  56. }
  57. }
  58. }
  59. public function create()
  60. {
  61. $this->acl()->backup();
  62. $this->resourceGuard()->backupLimit();
  63. $storage = $this->configuration()->getBackupStorage();
  64. $routing = $this->configuration()->isBackupRouting() ? 1 : 0;
  65. $maxFiles = $this->configuration()->getBackupMaxFiles();
  66. if($this->isWhmcsConfigOption(ConfigurableOption::BACKUPS_FILES) && $this->getWhmcsConfigOption(ConfigurableOption::BACKUPS_FILES)!="-1"){
  67. $maxFiles = $this->getWhmcsConfigOption(ConfigurableOption::BACKUPS_FILES);
  68. }else if($this->getWhmcsConfigOption(ConfigurableOption::BACKUPS_FILES, $this->configuration()->getBackupMaxFiles())=="-1"){
  69. $maxFiles = null;
  70. }
  71. $vm = \ModulesGarden\ProxmoxAddon\Core\Helper\sl('Vm')->getVm();
  72. if($vm->isLockBackup()){
  73. return (new HtmlDataJsonResponse())
  74. ->setStatusError()
  75. ->setMessageAndTranslate('The backup creation is in progress');
  76. }
  77. $vm ->backup($storage, $routing, $maxFiles, $this->formData['compress'], $this->formData['mode']);
  78. return (new HtmlDataJsonResponse())
  79. ->setStatusSuccess()
  80. ->setMessageAndTranslate('The backup creation is in progress')
  81. ->addData('createButtonStatus', $this->configuration()->isPermissionBackup() && $this->resourceGuard()->hasBackupLimit())
  82. ->setCallBackFunction('pmToggleBackupButton')
  83. ->addRefreshTargetId('resourcesContainer')
  84. ->addRefreshTargetId('backupDataTable');
  85. }
  86. public function restore()
  87. {
  88. $id = \ModulesGarden\ProxmoxAddon\Core\Helper\sl('Vm')->getVmModel()->id;
  89. queue(RestoreVm::class, ['volid' => $this->formData['volid']], null, 'hosting', $this->getWhmcsParamByKey('serviceid'), $id);
  90. return (new HtmlDataJsonResponse())
  91. ->setStatusSuccess()
  92. ->setMessageAndTranslate('The virtual machine restore is in progress');
  93. }
  94. public function update()
  95. {
  96. }
  97. public function delete()
  98. {
  99. $this->acl()->backup();
  100. $node = \ModulesGarden\ProxmoxAddon\Core\Helper\sl('Vm')->getVmModel()->node;
  101. $storage = $this->configuration()->getBackupStorage();
  102. $volid = $this->formData['volid'];
  103. $backupFile = new File();
  104. $backupFile->setApi($this->api());
  105. $backupFile->setPath("/nodes/{$node}/storage/{$storage}/content/{$volid}");
  106. $backupFile->delete();
  107. return (new HtmlDataJsonResponse())
  108. ->setStatusSuccess()
  109. ->setMessageAndTranslate('The backup has been deleted successfully')
  110. ->addData('createButtonStatus', $this->configuration()->isPermissionBackup() && $this->resourceGuard()->hasBackupLimit())
  111. ->setCallBackFunction('pmToggleBackupButton')
  112. ->addRefreshTargetId('resourcesContainer')
  113. ->addRefreshTargetId('backupDataTable');
  114. }
  115. public function deleteMass()
  116. {
  117. $this->acl()->backup();
  118. $node = \ModulesGarden\ProxmoxAddon\Core\Helper\sl('Vm')->getVmModel()->node;
  119. $storage = $this->configuration()->getBackupStorage();
  120. $backupFile = new File();
  121. $backupFile->setApi($this->api());
  122. foreach ($this->request->get('massActions') as $id)
  123. {
  124. $data = json_decode(base64_decode($id), true);
  125. $volid = $data['volid'];
  126. $backupFile->setPath("/nodes/{$node}/storage/{$storage}/content/{$volid}");
  127. $backupFile->delete();
  128. }
  129. return (new HtmlDataJsonResponse())
  130. ->setStatusSuccess()
  131. ->setMessageAndTranslate('The backups have been deleted successfully')
  132. ->addData('createButtonStatus', $this->configuration()->isPermissionBackup() && $this->resourceGuard()->hasBackupLimit())
  133. ->setCallBackFunction('pmToggleBackupButton')
  134. ->addRefreshTargetId('resourcesContainer')
  135. ->addRefreshTargetId('backupDataTable');
  136. }
  137. }