IpManagementDataTable.php 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  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\IpManagement\Pages;
  20. use ModulesGarden\ProxmoxAddon as main;
  21. use ModulesGarden\ProxmoxAddon\App\UI\IpManagement\Buttons\CreateButton;
  22. use ModulesGarden\ProxmoxAddon\App\UI\IpManagement\Buttons\DeleteButton;
  23. use ModulesGarden\ProxmoxAddon\App\UI\IpManagement\Buttons\DeleteMassButton;
  24. use ModulesGarden\ProxmoxAddon\App\UI\IpManagement\Buttons\UpdateButton;
  25. use ModulesGarden\ProxmoxAddon\Core\Models\Whmcs\Server;
  26. use ModulesGarden\ProxmoxAddon\Core\UI\Interfaces\AdminArea;
  27. use ModulesGarden\ProxmoxAddon\Core\UI\Widget\DataTable\Column;
  28. use ModulesGarden\ProxmoxAddon\Core\UI\Widget\DataTable\DataProviders\Providers\QueryDataProvider;
  29. use ModulesGarden\ProxmoxAddon\Core\UI\Widget\DataTable\DataTable;
  30. use function ModulesGarden\ProxmoxAddon\Core\Helper\sl;
  31. /**
  32. * Description of ServersDataTable
  33. *
  34. * @author Pawel Kopec <pawelk@modulesgardne.com>
  35. */
  36. class IpManagementDataTable extends DataTable implements AdminArea
  37. {
  38. public function initContent()
  39. {
  40. $this->initIds('ipManagement');
  41. $this->title = null;
  42. $this->addButton(new CreateButton);
  43. $this->addActionButton(new UpdateButton);
  44. $this->addActionButton(new DeleteButton);
  45. $this->addMassActionButton(new DeleteMassButton);
  46. }
  47. public function replaceFieldMac_address($key, $row)
  48. {
  49. if ($row->mac_address && $row->mac_address != 'auto')
  50. {
  51. return $row->mac_address;
  52. }
  53. return '-';
  54. }
  55. public function replaceFieldTrunks($key, $row)
  56. {
  57. return $row->trunks ? $row->trunks : '-';
  58. }
  59. public function replaceFieldTag($key, $row)
  60. {
  61. return $row->tag ? $row->tag : '-';
  62. }
  63. public function replaceFieldSubnet_mask($key, $row)
  64. {
  65. return $row->subnet_mask ? $row->subnet_mask : '-';
  66. }
  67. public function replaceFieldGateway($key, $row)
  68. {
  69. return $row->gateway ? $row->gateway : '-';
  70. }
  71. public function replaceFieldName($key, $row)
  72. {
  73. if ($row->sid == "0" && !$row->sid)
  74. {
  75. return '-';
  76. }
  77. return sprintf('<a href="configservers.php?action=manage&id=%s">%s</a>', $row->sid, $row->name);;
  78. }
  79. public function replaceFieldNode($key, $row)
  80. {
  81. if ($row->node == "0" && !$row->node)
  82. {
  83. return '-';
  84. }
  85. return $row->node;
  86. }
  87. public function replaceFieldVisualization($key, $row)
  88. {
  89. if ($row->visualization == "Auto")
  90. {
  91. return '-';
  92. }
  93. return $row->visualization;
  94. }
  95. public function replaceFieldPrivate($key, $row)
  96. {
  97. if ($row->private == '1')
  98. {
  99. return '<span class="lu-label lu-label--success lu-label--status">' . sl('lang')->tr('Yes') . '</span>';
  100. }
  101. return '<span class="lu-label lu-label--default lu-label--status">' . sl('lang')->tr('No') . '</span>';
  102. return $row->private == '1' ? '<span class="glyphicon glyphicon-ok-sign"></span>' : '<span class="glyphicon glyphicon-remove-sign"></span>';
  103. }
  104. protected function loadHtml()
  105. {
  106. $i = (new main\App\Models\IpAddress())->getTable();
  107. $s = (new Server)->getTable();
  108. $this->addColumn((new Column('ip', $i))->setSearchable(true, Column::TYPE_STRING)->setOrderable('ASC'))
  109. ->addColumn((new Column('mac_address', $i))->setSearchable(true, Column::TYPE_STRING)->setOrderable())
  110. ->addColumn((new Column('trunks', $i))->setSearchable(true, 'int')->setOrderable())
  111. ->addColumn((new Column('tag', $i))->setSearchable(true, 'int')->setOrderable())
  112. ->addColumn((new Column('subnet_mask', $i))->setSearchable(true, 'string')->setOrderable())
  113. ->addColumn((new Column('gateway', $i))->setSearchable(true, 'string')->setOrderable())
  114. ->addColumn((new Column('cidr', $i))->setSearchable(true, 'string')->setOrderable())
  115. ->addColumn((new Column('name', $s))->setSearchable(true, 'string')->setOrderable())
  116. ->addColumn((new Column('node', $i))->setSearchable(true, 'string')->setOrderable())
  117. ->addColumn((new Column('visualization', $i))->setSearchable(true, 'string')->setOrderable())
  118. ->addColumn((new Column('private', $i))
  119. );
  120. }
  121. protected function loadData()
  122. {
  123. $i = (new main\App\Models\IpAddress())->getTable();
  124. $s = (new Server)->getTable();
  125. $query = (new main\App\Models\IpAddress)
  126. ->query()
  127. ->getQuery()
  128. ->leftJoin($s, "{$s}.id", '=', "{$i}.sid")
  129. ->select("{$i}.*", "{$s}.name")
  130. ->where("{$i}.hosting_id", '0');
  131. $dataProv = new QueryDataProvider();
  132. $dataProv->setDefaultSorting("ip", 'ASC');
  133. $dataProv->setData($query);
  134. $this->setDataProvider($dataProv);
  135. }
  136. }