8
0
Fork 0
mirror of https://gitlab2.federez.net/re2o/re2o synced 2024-11-27 07:02:26 +00:00

Pour le dns

This commit is contained in:
Dalahro 2016-07-19 21:43:24 +02:00
parent 80fcc69ea9
commit 8e5464a192
3 changed files with 22 additions and 10 deletions

View file

@ -4,6 +4,7 @@ from machines.models import Interface
class InterfaceSerializer( serializers.ModelSerializer): class InterfaceSerializer( serializers.ModelSerializer):
class Meta: class Meta:
model = Interface model = Interface
fields = ('id','ipv4', 'mac_address') fields = ('ipv4', 'mac_address', 'dns')

View file

@ -16,6 +16,7 @@ urlpatterns = [
url(r'^edit_extension/(?P<extensionid>[0-9]+)$', views.edit_extension, name='edit-extension'), url(r'^edit_extension/(?P<extensionid>[0-9]+)$', views.edit_extension, name='edit-extension'),
url(r'^del_extension/$', views.del_extension, name='del-extension'), url(r'^del_extension/$', views.del_extension, name='del-extension'),
url(r'^index_extension/$', views.index_extension, name='index-extension'), url(r'^index_extension/$', views.index_extension, name='index-extension'),
url(r'^rest/mac-ip/$', views.interface_list, name='interface-list'),
url(r'^$', views.index, name='index'), url(r'^$', views.index, name='index'),
url(r'^rest/mac-ip/$', views.mac_ip, name='mac-ip'),
url(r'^rest/dns-ip/$', views.dns_ip, name='dns-ip'),
] ]

View file

@ -290,21 +290,31 @@ def index_extension(request):
class JSONResponse(HttpResponse): class JSONResponse(HttpResponse):
def __init__(self, data, **kwargs): def __init__(self, data, **kwargs):
datas=[]
for d in data: for d in data:
interface = Interface.objects.get(pk=d["id"]) if d["ipv4"]:
d.pop("id")
if d["ipv4"] and interface.is_active():
d["ipv4"]= IpList.objects.get(pk=d["ipv4"]).__str__() d["ipv4"]= IpList.objects.get(pk=d["ipv4"]).__str__()
datas.append(d) content = JSONRenderer().render(data)
content = JSONRenderer().render(datas)
kwargs['content_type'] = 'application/json' kwargs['content_type'] = 'application/json'
super(JSONResponse, self).__init__(content, **kwargs) super(JSONResponse, self).__init__(content, **kwargs)
def interface_list(request): def interface_list(request):
interfaces = Interface.objects.all() interfaces = Interface.objects.all()
seria = InterfaceSerializer(interfaces, many=True) interface = []
return JSONResponse(seria.data) for i in interfaces :
if i.ipv4 and i.is_active():
interface.append(i)
seria = InterfaceSerializer(interface, many=True)
return seria.data
def mac_ip(request):
seria = interface_list(request)
for s in seria:
s.pop('dns')
return JSONResponse(seria)
def dns_ip(request):
seria = interface_list(request)
for s in seria:
s.pop('mac_address')
return JSONResponse(seria)