ServersDataTable.php 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  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\Servers\Pages;
  20. use ModulesGarden\ProxmoxAddon\App\Models\RangeVm;
  21. use ModulesGarden\ProxmoxAddon\App\UI\Servers\Buttons\UpdateButton;
  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\Buttons\ButtonRedirect;
  26. use ModulesGarden\ProxmoxAddon\Core\UI\Widget\DataTable\Column;
  27. use ModulesGarden\ProxmoxAddon\Core\UI\Widget\DataTable\DataProviders\Providers\QueryDataProvider;
  28. use ModulesGarden\ProxmoxAddon\Core\UI\Widget\DataTable\DataTable;
  29. use function ModulesGarden\ProxmoxAddon\Core\Helper\sl;
  30. /**
  31. * Description of ServersDataTable
  32. *
  33. * @author Pawel Kopec <pawelk@modulesgardne.com>
  34. */
  35. class ServersDataTable extends DataTable implements AdminArea
  36. {
  37. public function initContent()
  38. {
  39. $this->initIds('serverList');
  40. $this->title = null;
  41. //Manage
  42. $rd = new ButtonRedirect;
  43. $rd->setRawUrl('configservers.php?action=manage')
  44. ->setRedirectParams(['id' => ':id']);
  45. $rd->replaceClasses(['lu-btn lu-btn--sm lu-btn--link lu-btn--icon lu-btn--plain lu-btn--default lu-tooltip drop-target drop-element-attached-bottom drop-element-attached-center drop-target-attached-top drop-target-attached-center']);
  46. $rd->setIcon('lu-btn-icon lu-zmdi lu-zmdi-edit');
  47. $this->addActionButton($rd);
  48. //Server details
  49. $rd = new ButtonRedirect('serverDetail');
  50. $rd->setRawUrl('addonmodules.php?module=proxmoxAddon&mg-page=home&mg-action=serverDetail')
  51. ->setRedirectParams(['id' => ':id']);
  52. $rd->replaceClasses(['lu-btn lu-btn--sm lu-btn--link lu-btn--icon lu-btn--plain lu-btn--default lu-tooltip drop-target drop-element-attached-bottom drop-element-attached-center drop-target-attached-top drop-target-attached-center']);
  53. $rd->setIcon('lu-btn__icon lu-zmdi lu-zmdi-info-outline');
  54. $this->addActionButton($rd);
  55. }
  56. public function replaceFieldResources($key, $row)
  57. {
  58. $resources = new ResourcesRow("resourcesRow" . $row->id);
  59. $resources->setIndex($row->id);
  60. return $resources->getHtml();
  61. }
  62. public function replaceFieldSuspended($key, $row)
  63. {
  64. $ajax = new SuspendedRow("suspendedRow" . $row->id);
  65. $ajax->setIndex($row->id);
  66. return $ajax->getHtml();
  67. }
  68. public function replaceFieldActiveAccounts($key, $row)
  69. {
  70. $active = Hosting::where('server', $row->id)->where("domainstatus", "Active")->count();
  71. return sprintf("%s / %s", $active, $row->maxaccounts);
  72. }
  73. public function replaceFieldDisabled($key, $row)
  74. {
  75. if ($row->disabled == 1)
  76. {
  77. return '<span class="lu-label lu-label--default lu-label--status">' . sl('lang')->tr('Disabled') . '</span>';
  78. }
  79. return '<span class="lu-label lu-label--success lu-label--status">' . sl('lang')->tr('Enabled') . '</span>';
  80. }
  81. public function replaceFieldRange($key, $row)
  82. {
  83. if ($row->vmid_from && $row->vmid_to)
  84. {
  85. return sprintf("%s - %s", $row->vmid_from, $row->vmid_to);
  86. }
  87. return '-';
  88. }
  89. protected function loadHtml()
  90. {
  91. $s = (new Server)->getTable();
  92. $r = (new RangeVm)->getTable();
  93. $this->addColumn((new Column('name', $s))->setSearchable(true, Column::TYPE_STRING)->setOrderable('ASC'))
  94. ->addColumn((new Column('ipaddress', $s))->setSearchable(true, Column::TYPE_STRING)->setOrderable())
  95. ->addColumn((new Column('activeAccounts')))
  96. ->addColumn((new Column('resources')))
  97. ->addColumn((new Column('suspended')))
  98. ->addColumn((new Column('disabled', $s)))
  99. ->addColumn((new Column('range', $r))
  100. );
  101. }
  102. protected function loadData()
  103. {
  104. $s = (new Server)->getTable();
  105. $r = (new RangeVm)->getTable();
  106. $query = (new Server)
  107. ->query()
  108. ->getQuery()
  109. ->leftJoin($r, "{$s}.id", '=', "{$r}.server_id")
  110. ->select("{$s}.id", "{$s}.name", "{$s}.ipaddress", "{$s}.hostname", "{$s}.active", "{$s}.maxaccounts", "{$s}.disabled", "{$r}.vmid_from", "{$r}.vmid_to")
  111. ->whereIn("{$s}.type", ["proxmoxVPS", "ProxmoxCloudVps"]);
  112. $dataProv = new QueryDataProvider();
  113. $dataProv->setDefaultSorting("name", 'ASC');
  114. $dataProv->setData($query);
  115. $this->setDataProvider($dataProv);
  116. }
  117. }