views.py 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221
  1. from django.shortcuts import render
  2. from django.http import HttpResponse
  3. from django.template import loader
  4. from django.shortcuts import redirect
  5. from django.conf import settings
  6. from django.urls import reverse
  7. import vyos
  8. def index(request):
  9. if not request.user.is_authenticated:
  10. return redirect('%s?next=%s' % (reverse('registration-login'), request.path))
  11. #interfaces = vyos.get_interfaces()
  12. all_instances = vyos.instance_getall()
  13. hostname_default = vyos.get_hostname_prefered(request)
  14. firewall_all = vyos.get_firewall_all(hostname_default)
  15. if firewall_all == False:
  16. return redirect('firewall:firewall-create')
  17. for xitem in firewall_all['name']:
  18. if 'default-action' in firewall_all['name'][xitem]:
  19. firewall_all['name'][xitem]['default_action'] = firewall_all['name'][xitem]['default-action']
  20. del firewall_all['name'][xitem]['default-action']
  21. template = loader.get_template('firewall/list.html')
  22. context = {
  23. #'interfaces': interfaces,
  24. 'instances': all_instances,
  25. 'hostname_default': hostname_default,
  26. 'firewall_all': firewall_all
  27. }
  28. return HttpResponse(template.render(context, request))
  29. def create(request):
  30. if not request.user.is_authenticated:
  31. return redirect('%s?next=%s' % (reverse('registration-login'), request.path))
  32. #interfaces = vyos.get_interfaces()
  33. all_instances = vyos.instance_getall()
  34. hostname_default = vyos.get_hostname_prefered(request)
  35. if 'name' in request.POST:
  36. cmd = {"op": "set", "path": ["firewall", "name", request.POST['name']]}
  37. result1 = vyos.set_config(hostname_default, cmd)
  38. print(result1)
  39. if 'description' in request.POST:
  40. cmd = {"op": "set", "path": ["firewall", "name", request.POST['name'], "description", request.POST['description']]}
  41. result2 = vyos.set_config(hostname_default, cmd)
  42. print(result2)
  43. if 'action' in request.POST:
  44. cmd = {"op": "set", "path": ["firewall", "name", request.POST['name'], "default-action", request.POST['action']]}
  45. result3 = vyos.set_config(hostname_default, cmd)
  46. print(result3)
  47. return redirect('firewall:firewall-list')
  48. template = loader.get_template('firewall/create.html')
  49. context = {
  50. #'interfaces': interfaces,
  51. 'instances': all_instances,
  52. 'hostname_default': hostname_default,
  53. }
  54. return HttpResponse(template.render(context, request))
  55. def addrule(request, firewall_name):
  56. if not request.user.is_authenticated:
  57. return redirect('%s?next=%s' % (reverse('registration-login'), request.path))
  58. #interfaces = vyos.get_interfaces()
  59. all_instances = vyos.instance_getall()
  60. hostname_default = vyos.get_hostname_prefered(request)
  61. firewall = vyos.get_firewall(hostname_default, firewall_name)
  62. changed = False
  63. if 'action' in request.POST:
  64. cmd = {"op": "set", "path": ["firewall", "name", firewall_name, "rule", request.POST['rulenumber'], "action", request.POST['action']]}
  65. result1 = vyos.set_config(hostname_default, cmd)
  66. print(result1)
  67. changed = True
  68. if 'protocol' in request.POST:
  69. cmd = {"op": "set", "path": ["firewall", "name", firewall_name, "rule", request.POST['rulenumber'], "protocol", request.POST['protocol']]}
  70. result2 = vyos.set_config(hostname_default, cmd)
  71. print(result2)
  72. changed = True
  73. if 'destinationport' in request.POST:
  74. cmd = {"op": "set", "path": ["firewall", "name", firewall_name, "rule", request.POST['rulenumber'], "destination", "port", request.POST['destinationport']]}
  75. result3 = vyos.set_config(hostname_default, cmd)
  76. print(result3)
  77. changed = True
  78. if 'sourceport' in request.POST:
  79. cmd = {"op": "set", "path": ["firewall", "name", firewall_name, "rule", request.POST['rulenumber'], "source", "port", request.POST['sourceport']]}
  80. result3 = vyos.set_config(hostname_default, cmd)
  81. print(result3)
  82. changed = True
  83. if changed == True:
  84. return redirect('firewall:show', firewall_name)
  85. template = loader.get_template('firewall/show.html')
  86. context = {
  87. #'interfaces': interfaces,
  88. 'instances': all_instances,
  89. 'hostname_default': hostname_default,
  90. 'firewall': firewall,
  91. 'firewall_name': firewall_name,
  92. }
  93. return HttpResponse(template.render(context, request))
  94. def editrule(request, firewall_name, firewall_rulenumber):
  95. #interfaces = vyos.get_interfaces()
  96. all_instances = vyos.instance_getall()
  97. hostname_default = vyos.get_hostname_prefered(request)
  98. firewall = vyos.get_firewall(hostname_default, firewall_name)
  99. firewall_rule = vyos.get_firewall_rule(hostname_default, firewall_name, firewall_rulenumber)
  100. changed = False
  101. if 'action' in request.POST:
  102. cmd = {"op": "set", "path": ["firewall", "name", firewall_name, "rule", firewall_rulenumber, "action", request.POST['action']]}
  103. result1 = vyos.set_config(hostname_default, cmd)
  104. print(result1)
  105. changed = True
  106. if 'protocol' in request.POST:
  107. cmd = {"op": "set", "path": ["firewall", "name", firewall_name, "rule", firewall_rulenumber, "protocol", request.POST['protocol']]}
  108. result2 = vyos.set_config(hostname_default, cmd)
  109. print(result2)
  110. changed = True
  111. if 'destinationport' in request.POST:
  112. cmd = {"op": "set", "path": ["firewall", "name", firewall_name, "rule", firewall_rulenumber, "destination", "port", request.POST['destinationport']]}
  113. result3 = vyos.set_config(hostname_default, cmd)
  114. print(result3)
  115. changed = True
  116. if 'sourceport' in request.POST:
  117. cmd = {"op": "set", "path": ["firewall", "name", firewall_name, "rule", firewall_rulenumber, "source", "port", request.POST['sourceport']]}
  118. result3 = vyos.set_config(hostname_default, cmd)
  119. print(result3)
  120. changed = True
  121. if changed == True:
  122. return redirect('firewall:firewall-list')
  123. template = loader.get_template('firewall/editrule.html')
  124. context = {
  125. #'interfaces': interfaces,
  126. 'instances': all_instances,
  127. 'hostname_default': hostname_default,
  128. 'firewall': firewall,
  129. 'firewall_name': firewall_name,
  130. 'firewall_rule': firewall_rule,
  131. 'firewall_rulenumber' : firewall_rulenumber
  132. }
  133. return HttpResponse(template.render(context, request))
  134. def show(request, firewall_name):
  135. if not request.user.is_authenticated:
  136. return redirect('%s?next=%s' % (reverse('registration-login'), request.path))
  137. #interfaces = vyos.get_interfaces()
  138. all_instances = vyos.instance_getall()
  139. hostname_default = vyos.get_hostname_prefered(request)
  140. firewall = vyos.get_firewall(hostname_default, firewall_name)
  141. template = loader.get_template('firewall/show.html')
  142. context = {
  143. #'interfaces': interfaces,
  144. 'instances': all_instances,
  145. 'hostname_default': hostname_default,
  146. 'firewall': firewall,
  147. 'firewall_name': firewall_name,
  148. }
  149. return HttpResponse(template.render(context, request))
  150. def firewall_remove(request, firewall_name):
  151. if not request.user.is_authenticated:
  152. return redirect('%s?next=%s' % (reverse('registration-login'), request.path))
  153. #interfaces = vyos.get_interfaces()
  154. all_instances = vyos.instance_getall()
  155. hostname_default = vyos.get_hostname_prefered(request)
  156. firewall = vyos.delete_firewall(hostname_default, firewall_name)
  157. return redirect('firewall:firewall-list')