|
@@ -6,6 +6,7 @@ from dcim.api.serializers import NestedDeviceRoleSerializer, NestedPlatformSeria
|
|
|
from dcim.constants import IFACE_FF_VIRTUAL
|
|
|
from dcim.models import Interface
|
|
|
from extras.api.customfields import CustomFieldModelSerializer
|
|
|
+from ipam.models import IPAddress
|
|
|
from tenancy.api.serializers import NestedTenantSerializer
|
|
|
from utilities.api import ChoiceFieldSerializer, ValidatedModelSerializer
|
|
|
from virtualization.constants import STATUS_CHOICES
|
|
@@ -83,18 +84,30 @@ class WritableClusterSerializer(CustomFieldModelSerializer):
|
|
|
# Virtual machines
|
|
|
#
|
|
|
|
|
|
+# Cannot import ipam.api.NestedIPAddressSerializer due to circular dependency
|
|
|
+class VirtualMachineIPAddressSerializer(serializers.ModelSerializer):
|
|
|
+ url = serializers.HyperlinkedIdentityField(view_name='ipam-api:ipaddress-detail')
|
|
|
+
|
|
|
+ class Meta:
|
|
|
+ model = IPAddress
|
|
|
+ fields = ['id', 'url', 'family', 'address']
|
|
|
+
|
|
|
+
|
|
|
class VirtualMachineSerializer(CustomFieldModelSerializer):
|
|
|
status = ChoiceFieldSerializer(choices=STATUS_CHOICES)
|
|
|
cluster = NestedClusterSerializer()
|
|
|
role = NestedDeviceRoleSerializer()
|
|
|
tenant = NestedTenantSerializer()
|
|
|
platform = NestedPlatformSerializer()
|
|
|
+ primary_ip = VirtualMachineIPAddressSerializer()
|
|
|
+ primary_ip4 = VirtualMachineIPAddressSerializer()
|
|
|
+ primary_ip6 = VirtualMachineIPAddressSerializer()
|
|
|
|
|
|
class Meta:
|
|
|
model = VirtualMachine
|
|
|
fields = [
|
|
|
- 'id', 'name', 'status', 'cluster', 'role', 'tenant', 'platform', 'primary_ip4', 'primary_ip6', 'vcpus',
|
|
|
- 'memory', 'disk', 'comments', 'custom_fields',
|
|
|
+ 'id', 'name', 'status', 'cluster', 'role', 'tenant', 'platform', 'primary_ip', 'primary_ip4', 'primary_ip6',
|
|
|
+ 'vcpus', 'memory', 'disk', 'comments', 'custom_fields',
|
|
|
]
|
|
|
|
|
|
|