nested_serializers.py 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389
  1. import warnings
  2. from drf_spectacular.utils import extend_schema_serializer
  3. from rest_framework import serializers
  4. from dcim import models
  5. from netbox.api.fields import RelatedObjectCountField
  6. from netbox.api.serializers import WritableNestedSerializer
  7. from .serializers_.nested import (
  8. NestedDeviceBaySerializer, NestedDeviceSerializer, NestedInterfaceSerializer, NestedInterfaceTemplateSerializer,
  9. NestedLocationSerializer, NestedModuleBaySerializer, NestedRegionSerializer, NestedSiteGroupSerializer,
  10. )
  11. __all__ = [
  12. 'NestedCableSerializer',
  13. 'NestedConsolePortSerializer',
  14. 'NestedConsolePortTemplateSerializer',
  15. 'NestedConsoleServerPortSerializer',
  16. 'NestedConsoleServerPortTemplateSerializer',
  17. 'NestedDeviceBaySerializer',
  18. 'NestedDeviceBayTemplateSerializer',
  19. 'NestedDeviceRoleSerializer',
  20. 'NestedDeviceSerializer',
  21. 'NestedDeviceTypeSerializer',
  22. 'NestedFrontPortSerializer',
  23. 'NestedFrontPortTemplateSerializer',
  24. 'NestedInterfaceSerializer',
  25. 'NestedInterfaceTemplateSerializer',
  26. 'NestedInventoryItemSerializer',
  27. 'NestedInventoryItemRoleSerializer',
  28. 'NestedInventoryItemTemplateSerializer',
  29. 'NestedManufacturerSerializer',
  30. 'NestedModuleBaySerializer',
  31. 'NestedModuleBayTemplateSerializer',
  32. 'NestedModuleSerializer',
  33. 'NestedModuleTypeSerializer',
  34. 'NestedPlatformSerializer',
  35. 'NestedPowerFeedSerializer',
  36. 'NestedPowerOutletSerializer',
  37. 'NestedPowerOutletTemplateSerializer',
  38. 'NestedPowerPanelSerializer',
  39. 'NestedPowerPortSerializer',
  40. 'NestedPowerPortTemplateSerializer',
  41. 'NestedLocationSerializer',
  42. 'NestedRackReservationSerializer',
  43. 'NestedRackRoleSerializer',
  44. 'NestedRackSerializer',
  45. 'NestedRearPortSerializer',
  46. 'NestedRearPortTemplateSerializer',
  47. 'NestedRegionSerializer',
  48. 'NestedSiteSerializer',
  49. 'NestedSiteGroupSerializer',
  50. 'NestedVirtualChassisSerializer',
  51. 'NestedVirtualDeviceContextSerializer',
  52. ]
  53. # TODO: Remove in v4.2
  54. warnings.warn(
  55. "Dedicated nested serializers will be removed in NetBox v4.2. Use Serializer(nested=True) instead.",
  56. DeprecationWarning
  57. )
  58. #
  59. # Regions/sites
  60. #
  61. class NestedSiteSerializer(WritableNestedSerializer):
  62. class Meta:
  63. model = models.Site
  64. fields = ['id', 'url', 'display_url', 'display', 'name', 'slug']
  65. #
  66. # Racks
  67. #
  68. @extend_schema_serializer(
  69. exclude_fields=('rack_count',),
  70. )
  71. class NestedRackRoleSerializer(WritableNestedSerializer):
  72. rack_count = RelatedObjectCountField('racks')
  73. class Meta:
  74. model = models.RackRole
  75. fields = ['id', 'url', 'display_url', 'display', 'name', 'slug', 'rack_count']
  76. @extend_schema_serializer(
  77. exclude_fields=('device_count',),
  78. )
  79. class NestedRackSerializer(WritableNestedSerializer):
  80. device_count = RelatedObjectCountField('devices')
  81. class Meta:
  82. model = models.Rack
  83. fields = ['id', 'url', 'display_url', 'display', 'name', 'device_count']
  84. class NestedRackReservationSerializer(WritableNestedSerializer):
  85. user = serializers.SerializerMethodField(read_only=True)
  86. class Meta:
  87. model = models.RackReservation
  88. fields = ['id', 'url', 'display_url', 'display', 'user', 'units']
  89. def get_user(self, obj):
  90. return obj.user.username
  91. #
  92. # Device/module types
  93. #
  94. @extend_schema_serializer(
  95. exclude_fields=('devicetype_count',),
  96. )
  97. class NestedManufacturerSerializer(WritableNestedSerializer):
  98. devicetype_count = RelatedObjectCountField('device_types')
  99. class Meta:
  100. model = models.Manufacturer
  101. fields = ['id', 'url', 'display_url', 'display', 'name', 'slug', 'devicetype_count']
  102. @extend_schema_serializer(
  103. exclude_fields=('device_count',),
  104. )
  105. class NestedDeviceTypeSerializer(WritableNestedSerializer):
  106. manufacturer = NestedManufacturerSerializer(read_only=True)
  107. device_count = RelatedObjectCountField('instances')
  108. class Meta:
  109. model = models.DeviceType
  110. fields = ['id', 'url', 'display_url', 'display', 'manufacturer', 'model', 'slug', 'device_count']
  111. class NestedModuleTypeSerializer(WritableNestedSerializer):
  112. manufacturer = NestedManufacturerSerializer(read_only=True)
  113. class Meta:
  114. model = models.ModuleType
  115. fields = ['id', 'url', 'display_url', 'display', 'manufacturer', 'model']
  116. #
  117. # Component templates
  118. #
  119. class NestedConsolePortTemplateSerializer(WritableNestedSerializer):
  120. class Meta:
  121. model = models.ConsolePortTemplate
  122. fields = ['id', 'url', 'display_url', 'display', 'name']
  123. class NestedConsoleServerPortTemplateSerializer(WritableNestedSerializer):
  124. class Meta:
  125. model = models.ConsoleServerPortTemplate
  126. fields = ['id', 'url', 'display_url', 'display', 'name']
  127. class NestedPowerPortTemplateSerializer(WritableNestedSerializer):
  128. class Meta:
  129. model = models.PowerPortTemplate
  130. fields = ['id', 'url', 'display_url', 'display', 'name']
  131. class NestedPowerOutletTemplateSerializer(WritableNestedSerializer):
  132. class Meta:
  133. model = models.PowerOutletTemplate
  134. fields = ['id', 'url', 'display_url', 'display', 'name']
  135. class NestedRearPortTemplateSerializer(WritableNestedSerializer):
  136. class Meta:
  137. model = models.RearPortTemplate
  138. fields = ['id', 'url', 'display_url', 'display', 'name']
  139. class NestedFrontPortTemplateSerializer(WritableNestedSerializer):
  140. class Meta:
  141. model = models.FrontPortTemplate
  142. fields = ['id', 'url', 'display_url', 'display', 'name']
  143. class NestedModuleBayTemplateSerializer(WritableNestedSerializer):
  144. class Meta:
  145. model = models.ModuleBayTemplate
  146. fields = ['id', 'url', 'display_url', 'display', 'name']
  147. class NestedDeviceBayTemplateSerializer(WritableNestedSerializer):
  148. class Meta:
  149. model = models.DeviceBayTemplate
  150. fields = ['id', 'url', 'display_url', 'display', 'name']
  151. class NestedInventoryItemTemplateSerializer(WritableNestedSerializer):
  152. _depth = serializers.IntegerField(source='level', read_only=True)
  153. class Meta:
  154. model = models.InventoryItemTemplate
  155. fields = ['id', 'url', 'display_url', 'display', 'name', '_depth']
  156. #
  157. # Devices
  158. #
  159. @extend_schema_serializer(
  160. exclude_fields=('device_count', 'virtualmachine_count'),
  161. )
  162. class NestedDeviceRoleSerializer(WritableNestedSerializer):
  163. device_count = RelatedObjectCountField('devices')
  164. virtualmachine_count = RelatedObjectCountField('virtual_machines')
  165. class Meta:
  166. model = models.DeviceRole
  167. fields = ['id', 'url', 'display_url', 'display', 'name', 'slug', 'device_count', 'virtualmachine_count']
  168. @extend_schema_serializer(
  169. exclude_fields=('device_count', 'virtualmachine_count'),
  170. )
  171. class NestedPlatformSerializer(WritableNestedSerializer):
  172. device_count = RelatedObjectCountField('devices')
  173. virtualmachine_count = RelatedObjectCountField('virtual_machines')
  174. class Meta:
  175. model = models.Platform
  176. fields = ['id', 'url', 'display_url', 'display', 'name', 'slug', 'device_count', 'virtualmachine_count']
  177. class ModuleNestedModuleBaySerializer(WritableNestedSerializer):
  178. class Meta:
  179. model = models.ModuleBay
  180. fields = ['id', 'url', 'display_url', 'display', 'name']
  181. class NestedModuleSerializer(WritableNestedSerializer):
  182. device = NestedDeviceSerializer(read_only=True)
  183. module_bay = ModuleNestedModuleBaySerializer(read_only=True)
  184. module_type = NestedModuleTypeSerializer(read_only=True)
  185. class Meta:
  186. model = models.Module
  187. fields = ['id', 'url', 'display_url', 'display', 'device', 'module_bay', 'module_type']
  188. class NestedConsoleServerPortSerializer(WritableNestedSerializer):
  189. device = NestedDeviceSerializer(read_only=True)
  190. _occupied = serializers.BooleanField(required=False, read_only=True)
  191. class Meta:
  192. model = models.ConsoleServerPort
  193. fields = ['id', 'url', 'display_url', 'display', 'device', 'name', 'cable', '_occupied']
  194. class NestedConsolePortSerializer(WritableNestedSerializer):
  195. device = NestedDeviceSerializer(read_only=True)
  196. _occupied = serializers.BooleanField(required=False, read_only=True)
  197. class Meta:
  198. model = models.ConsolePort
  199. fields = ['id', 'url', 'display_url', 'display', 'device', 'name', 'cable', '_occupied']
  200. class NestedPowerOutletSerializer(WritableNestedSerializer):
  201. device = NestedDeviceSerializer(read_only=True)
  202. _occupied = serializers.BooleanField(required=False, read_only=True)
  203. class Meta:
  204. model = models.PowerOutlet
  205. fields = ['id', 'url', 'display_url', 'display', 'device', 'name', 'cable', '_occupied']
  206. class NestedPowerPortSerializer(WritableNestedSerializer):
  207. device = NestedDeviceSerializer(read_only=True)
  208. _occupied = serializers.BooleanField(required=False, read_only=True)
  209. class Meta:
  210. model = models.PowerPort
  211. fields = ['id', 'url', 'display_url', 'display', 'device', 'name', 'cable', '_occupied']
  212. class NestedRearPortSerializer(WritableNestedSerializer):
  213. device = NestedDeviceSerializer(read_only=True)
  214. _occupied = serializers.BooleanField(required=False, read_only=True)
  215. class Meta:
  216. model = models.RearPort
  217. fields = ['id', 'url', 'display_url', 'display', 'device', 'name', 'cable', '_occupied']
  218. class NestedFrontPortSerializer(WritableNestedSerializer):
  219. device = NestedDeviceSerializer(read_only=True)
  220. _occupied = serializers.BooleanField(required=False, read_only=True)
  221. class Meta:
  222. model = models.FrontPort
  223. fields = ['id', 'url', 'display_url', 'display', 'device', 'name', 'cable', '_occupied']
  224. class NestedInventoryItemSerializer(WritableNestedSerializer):
  225. device = NestedDeviceSerializer(read_only=True)
  226. _depth = serializers.IntegerField(source='level', read_only=True)
  227. class Meta:
  228. model = models.InventoryItem
  229. fields = ['id', 'url', 'display_url', 'display', 'device', 'name', '_depth']
  230. @extend_schema_serializer(
  231. exclude_fields=('inventoryitem_count',),
  232. )
  233. class NestedInventoryItemRoleSerializer(WritableNestedSerializer):
  234. inventoryitem_count = RelatedObjectCountField('inventory_items')
  235. class Meta:
  236. model = models.InventoryItemRole
  237. fields = ['id', 'url', 'display_url', 'display', 'name', 'slug', 'inventoryitem_count']
  238. #
  239. # Cables
  240. #
  241. class NestedCableSerializer(WritableNestedSerializer):
  242. class Meta:
  243. model = models.Cable
  244. fields = ['id', 'url', 'display_url', 'display', 'label']
  245. #
  246. # Virtual chassis
  247. #
  248. @extend_schema_serializer(
  249. exclude_fields=('member_count',),
  250. )
  251. class NestedVirtualChassisSerializer(WritableNestedSerializer):
  252. master = NestedDeviceSerializer()
  253. member_count = serializers.IntegerField(read_only=True)
  254. class Meta:
  255. model = models.VirtualChassis
  256. fields = ['id', 'url', 'display_url', 'display', 'name', 'master', 'member_count']
  257. #
  258. # Power panels/feeds
  259. #
  260. @extend_schema_serializer(
  261. exclude_fields=('powerfeed_count',),
  262. )
  263. class NestedPowerPanelSerializer(WritableNestedSerializer):
  264. powerfeed_count = RelatedObjectCountField('powerfeeds')
  265. class Meta:
  266. model = models.PowerPanel
  267. fields = ['id', 'url', 'display_url', 'display', 'name', 'powerfeed_count']
  268. class NestedPowerFeedSerializer(WritableNestedSerializer):
  269. _occupied = serializers.BooleanField(required=False, read_only=True)
  270. class Meta:
  271. model = models.PowerFeed
  272. fields = ['id', 'url', 'display_url', 'display', 'name', 'cable', '_occupied']
  273. class NestedVirtualDeviceContextSerializer(WritableNestedSerializer):
  274. device = NestedDeviceSerializer()
  275. class Meta:
  276. model = models.VirtualDeviceContext
  277. fields = ['id', 'url', 'display_url', 'display', 'name', 'identifier', 'device']