FirewallProvider.php 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  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\ProxmoxVps\App\UI\Firewall\Providers;
  20. use MGProvision\Proxmox\v2\models\FirewallRule;
  21. use ModulesGarden\ProxmoxAddon\App\Services\ApiService;
  22. use ModulesGarden\ProxmoxAddon\App\Services\Vps\ProductService;
  23. use ModulesGarden\Servers\ProxmoxVps\Core\UI\Interfaces\ClientArea;
  24. use ModulesGarden\Servers\ProxmoxVps\Core\UI\ResponseTemplates\HtmlDataJsonResponse;
  25. use ModulesGarden\Servers\ProxmoxVps\Core\UI\Widget\Forms\DataProviders\BaseDataProvider;
  26. class FirewallProvider extends BaseDataProvider implements ClientArea
  27. {
  28. use ProductService;
  29. use ApiService;
  30. public function read()
  31. {
  32. if ($this->actionElementId)
  33. {
  34. $this->data = json_decode(base64_decode($this->actionElementId), true);
  35. //enable
  36. $enable = $this->data['enable'];
  37. $this->data['enable'] = $enable == "1" ? "on" : "off";
  38. }
  39. }
  40. public function create()
  41. {
  42. $this->acl()->firewall();
  43. $this->resourceGuard()->firewallLimit();
  44. $firewallRule = new FirewallRule();
  45. $firewallRule->setApi($this->api());
  46. $firewallRule->setPath($this->vm()->getPath() . "/firewall/rules/");
  47. $attributes = $this->formData;
  48. $attributes['enable'] = $this->formData['enable'] == "on" ? 1 : 0;
  49. if ($attributes['proto'] == "0")
  50. {
  51. unset($attributes['proto']);
  52. }
  53. $firewallRule->setAttributes($attributes);
  54. $firewallRule->create();
  55. return (new HtmlDataJsonResponse())
  56. ->setStatusSuccess()
  57. ->setMessageAndTranslate('The firewall rule has been created successfully')
  58. ->addData('createButtonStatus', $this->resourceGuard()->hasfirewallLimit())
  59. ->setCallBackFunction('pmToggleButton');
  60. }
  61. public function update()
  62. {
  63. $this->acl()->firewall();
  64. $firewallRule = new FirewallRule();
  65. $firewallRule->setApi($this->api());
  66. $pos = $this->formData['pos'];
  67. unset($this->formData['pos']);
  68. $firewallRule->setPath($this->vm()->getPath() . "/firewall/rules/{$pos}");
  69. $attributes = $this->formData;
  70. $attributes['enable'] = $this->formData['enable'] == "on" ? 1 : 0;
  71. if ($attributes['proto'] == "0")
  72. {
  73. unset($attributes['proto']);
  74. }
  75. $firewallRule->setAttributes($attributes);
  76. $firewallRule->update();
  77. return (new HtmlDataJsonResponse())
  78. ->setStatusSuccess()
  79. ->setMessageAndTranslate('The firewall rule has been updated successfully');
  80. }
  81. public function delete()
  82. {
  83. $this->acl()->firewall();
  84. $firewallRule = new FirewallRule();
  85. $firewallRule->setApi($this->api());
  86. $pos = $this->formData['pos'];
  87. $firewallRule->setPath($this->vm()->getPath() . "/firewall/rules/{$pos}");
  88. $firewallRule->delete();
  89. return (new HtmlDataJsonResponse())
  90. ->setStatusSuccess()
  91. ->setMessageAndTranslate('The firewall rule has been deleted successfully')
  92. ->addData('createButtonStatus', $this->resourceGuard()->hasfirewallLimit())
  93. ->setCallBackFunction('pmToggleButton');
  94. }
  95. public function restore(){
  96. $rules = \json_decode(html_entity_decode($this->getFormDataValues()['rulesJson'],ENT_QUOTES),true);
  97. if(!$this->getFormDataValues()['rulesJson'] || !$rules ){
  98. return (new HtmlDataJsonResponse())
  99. ->setStatusError()
  100. ->setMessageAndTranslate('The file with firewall rules is empty or invalid');
  101. }
  102. $this->acl()->firewall();
  103. $this->resourceGuard()->firewallLimit(count($rules));
  104. foreach ($rules as $rule){
  105. $firewallRule = new FirewallRule();
  106. $firewallRule->setApi($this->api());
  107. $firewallRule->setPath($this->vm()->getPath() . "/firewall/rules/");
  108. $firewallRule->setAttributes($rule);
  109. $firewallRule->create();
  110. }
  111. return (new HtmlDataJsonResponse())
  112. ->setStatusSuccess()
  113. ->setMessageAndTranslate('The firewall rules have been restored successfully')
  114. ->addData('createButtonStatus', $this->resourceGuard()->hasfirewallLimit())
  115. ->setCallBackFunction('pmToggleButton');
  116. }
  117. }