RecoveryVmsDataTable.php 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. <?php
  2. /* * ********************************************************************
  3. * ProxmoxAddon product developed. (Aug 22, 2018)
  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\ProxmoxAddon\App\UI\RecoveryVms\Pages;
  20. use ModulesGarden\ProxmoxAddon as main;
  21. use ModulesGarden\ProxmoxAddon\App\UI\RecoveryVms\Buttons\DetailButton;
  22. use ModulesGarden\ProxmoxAddon\Core\Models\Whmcs\Hosting;
  23. use ModulesGarden\ProxmoxAddon\Core\Models\Whmcs\Server;
  24. use ModulesGarden\ProxmoxAddon\Core\UI\Interfaces\AdminArea;
  25. use ModulesGarden\ProxmoxAddon\Core\UI\Widget\DataTable\Column;
  26. use ModulesGarden\ProxmoxAddon\Core\UI\Widget\DataTable\DataProviders\Providers\QueryDataProvider;
  27. use ModulesGarden\ProxmoxAddon\Core\UI\Widget\DataTable\DataTable;
  28. /**
  29. * Description of ServersDataTable
  30. *
  31. * @author Pawel Kopec <pawelk@modulesgardne.com>
  32. */
  33. class RecoveryVmsDataTable extends DataTable implements AdminArea
  34. {
  35. public function initContent()
  36. {
  37. $this->initIds('recoveryVms');
  38. $this->title = null;
  39. $this->addActionButton(new DetailButton);
  40. $rd = new main\Core\UI\Widget\Buttons\ButtonRedirect();
  41. $rd->setRawUrl('addonmodules.php?module=proxmoxAddon&mg-page=home&mg-action=recoveryToFile');
  42. $rd->setIcon('lu-btn__icon lu-zmdi lu-zmdi-download');
  43. $rd->setTitle("export");
  44. $rd->replaceClasses(['lu-btn lu-btn--primary']);
  45. $rd->setShowTitle();
  46. $rd->deleteHtmlAttribute('data-toggle');
  47. $this->addButton($rd);
  48. }
  49. public function replaceFieldFirstname($key, $row)
  50. {
  51. return sprintf('<a href="clientssummary.php?userid=%s">%s %s</a>', $row->client_id, $row->firstname, $row->lastname);
  52. }
  53. public function replaceFieldDomain($key, $row)
  54. {
  55. if ($row->domain)
  56. {
  57. return sprintf('<a href="clientsservices.php?userid=%s&id=%s"> %s</a>', $row->client_id, $row->service_id, $row->domain);
  58. }
  59. return sprintf('<a href="clientsservices.php?userid=%s&id=%s"> %s</a>', $row->client_id, $row->service_id, $row->service_id);
  60. }
  61. public function replaceFieldServer($key, $row)
  62. {
  63. return sprintf('<a href="configservers.php?action=manage&id=%s">%s</a>', $row->server, $row->serverName);
  64. }
  65. public function replaceFieldVirtualization($key, $row)
  66. {
  67. return main\Core\ServiceLocator::call('lang')->absoluteT($row->virtualization);
  68. }
  69. public function replaceFieldlast_update($key, $row)
  70. {
  71. return fromMySQLDate($row->last_update, true);
  72. }
  73. protected function loadHtml()
  74. {
  75. $r = (new main\App\Models\RecoveryVm)->getTable();
  76. $c = (new main\Core\Models\Whmcs\Client)->getTable();
  77. $h = (new Hosting)->getTable();
  78. $s = (new Server)->getTable();
  79. $this->addColumn((new Column('id', $r))->setOrderable("DESC"))
  80. ->addColumn((new Column('firstname', $c))->setSearchable(true, Column::TYPE_STRING)->setOrderable())
  81. ->addColumn((new Column('domain', $h))->setSearchable(true, Column::TYPE_STRING)->setOrderable())
  82. ->addColumn((new Column('server')))
  83. ->addColumn((new Column('node', $r))->setSearchable(true, Column::TYPE_STRING)->setOrderable())
  84. ->addColumn((new Column('vmid', $r))->setSearchable(true, Column::TYPE_STRING)->setOrderable())
  85. ->addColumn((new Column('virtualization', $r))->setSearchable(true, Column::TYPE_STRING)->setOrderable())
  86. ->addColumn((new Column('last_update', $r))->setSearchable(true, Column::TYPE_DATE)->setOrderable());
  87. }
  88. protected function loadData()
  89. {
  90. $r = (new main\App\Models\RecoveryVm)->getTable();
  91. $c = (new main\Core\Models\Whmcs\Client)->getTable();
  92. $h = (new Hosting)->getTable();
  93. $s = (new Server)->getTable();
  94. $p = (new main\Core\Models\Whmcs\Product)->getTable();
  95. $query = (new main\App\Models\RecoveryVm)
  96. ->query()
  97. ->getQuery()
  98. ->leftJoin($c, "{$r}.client_id", '=', "{$c}.id")
  99. ->leftJoin($s, "{$r}.server_id", '=', "{$s}.id")
  100. ->leftJoin($h, "{$r}.service_id", '=', "{$h}.id")
  101. ->leftJoin($p, "{$h}.packageid", '=', "{$p}.id")
  102. ->select("{$r}.*", "{$h}.domain", "{$h}.domainstatus", "{$h}.server", "{$c}.firstname", "{$c}.lastname", "{$s}.name AS serverName", "{$p}.name AS productName")
  103. ->whereIn("{$s}.type", ["proxmoxVPS", "ProxmoxCloudVps"]);
  104. $dataProv = new QueryDataProvider();
  105. $dataProv->setDefaultSorting("id", 'DESC');
  106. $dataProv->setData($query);
  107. $this->setDataProvider($dataProv);
  108. }
  109. }