mirror of
https://github.com/netbox-community/netbox.git
synced 2025-08-25 00:36:11 -06:00
10595 cable a_terminations to graphql
This commit is contained in:
commit
ac1cf30321
133
netbox/dcim/graphql/gfk_mixins.py
Normal file
133
netbox/dcim/graphql/gfk_mixins.py
Normal file
@ -0,0 +1,133 @@
|
|||||||
|
import graphene
|
||||||
|
from circuits.graphql.types import CircuitTerminationType
|
||||||
|
from circuits.models import CircuitTermination
|
||||||
|
from dcim.graphql.types import (
|
||||||
|
ConsolePortTemplateType,
|
||||||
|
ConsolePortType,
|
||||||
|
ConsoleServerPortTemplateType,
|
||||||
|
ConsoleServerPortType,
|
||||||
|
FrontPortTemplateType,
|
||||||
|
FrontPortType,
|
||||||
|
InterfaceTemplateType,
|
||||||
|
InterfaceType,
|
||||||
|
PowerFeedType,
|
||||||
|
PowerOutletTemplateType,
|
||||||
|
PowerOutletType,
|
||||||
|
PowerPortTemplateType,
|
||||||
|
PowerPortType,
|
||||||
|
RearPortTemplateType,
|
||||||
|
RearPortType,
|
||||||
|
)
|
||||||
|
from dcim.models import (
|
||||||
|
ConsolePort,
|
||||||
|
ConsolePortTemplate,
|
||||||
|
ConsoleServerPort,
|
||||||
|
ConsoleServerPortTemplate,
|
||||||
|
FrontPort,
|
||||||
|
FrontPortTemplate,
|
||||||
|
Interface,
|
||||||
|
InterfaceTemplate,
|
||||||
|
PowerFeed,
|
||||||
|
PowerOutlet,
|
||||||
|
PowerOutletTemplate,
|
||||||
|
PowerPort,
|
||||||
|
PowerPortTemplate,
|
||||||
|
RearPort,
|
||||||
|
RearPortTemplate,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
class CableTerminationTerminationType(graphene.Union):
|
||||||
|
class Meta:
|
||||||
|
types = (
|
||||||
|
CircuitTerminationType,
|
||||||
|
ConsolePortType,
|
||||||
|
ConsoleServerPortType,
|
||||||
|
FrontPortType,
|
||||||
|
InterfaceType,
|
||||||
|
PowerFeedType,
|
||||||
|
PowerOutletType,
|
||||||
|
PowerPortType,
|
||||||
|
RearPortType,
|
||||||
|
)
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def resolve_type(cls, instance, info):
|
||||||
|
if type(instance) == CircuitTermination:
|
||||||
|
return CircuitTerminationType
|
||||||
|
if type(instance) == ConsolePortType:
|
||||||
|
return ConsolePortType
|
||||||
|
if type(instance) == ConsoleServerPort:
|
||||||
|
return ConsoleServerPortType
|
||||||
|
if type(instance) == FrontPort:
|
||||||
|
return FrontPortType
|
||||||
|
if type(instance) == Interface:
|
||||||
|
return InterfaceType
|
||||||
|
if type(instance) == PowerFeed:
|
||||||
|
return PowerFeedType
|
||||||
|
if type(instance) == PowerOutlet:
|
||||||
|
return PowerOutletType
|
||||||
|
if type(instance) == PowerPort:
|
||||||
|
return PowerPortType
|
||||||
|
if type(instance) == RearPort:
|
||||||
|
return RearPortType
|
||||||
|
|
||||||
|
|
||||||
|
class InventoryItemTemplateComponentType(graphene.Union):
|
||||||
|
class Meta:
|
||||||
|
types = (
|
||||||
|
ConsolePortTemplateType,
|
||||||
|
ConsoleServerPortTemplateType,
|
||||||
|
FrontPortTemplateType,
|
||||||
|
InterfaceTemplateType,
|
||||||
|
PowerOutletTemplateType,
|
||||||
|
PowerPortTemplateType,
|
||||||
|
RearPortTemplateType,
|
||||||
|
)
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def resolve_type(cls, instance, info):
|
||||||
|
if type(instance) == ConsolePortTemplate:
|
||||||
|
return ConsolePortTemplateType
|
||||||
|
if type(instance) == ConsoleServerPortTemplate:
|
||||||
|
return ConsoleServerPortTemplateType
|
||||||
|
if type(instance) == FrontPortTemplate:
|
||||||
|
return FrontPortTemplateType
|
||||||
|
if type(instance) == InterfaceTemplate:
|
||||||
|
return InterfaceTemplateType
|
||||||
|
if type(instance) == PowerOutletTemplate:
|
||||||
|
return PowerOutletTemplateType
|
||||||
|
if type(instance) == PowerPortTemplate:
|
||||||
|
return PowerPortTemplateType
|
||||||
|
if type(instance) == RearPortTemplate:
|
||||||
|
return RearPortTemplateType
|
||||||
|
|
||||||
|
|
||||||
|
class InventoryItemComponentType(graphene.Union):
|
||||||
|
class Meta:
|
||||||
|
types = (
|
||||||
|
ConsolePortType,
|
||||||
|
ConsoleServerPortType,
|
||||||
|
FrontPortType,
|
||||||
|
InterfaceType,
|
||||||
|
PowerOutletType,
|
||||||
|
PowerPortType,
|
||||||
|
RearPortType,
|
||||||
|
)
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def resolve_type(cls, instance, info):
|
||||||
|
if type(instance) == ConsolePort:
|
||||||
|
return ConsolePortType
|
||||||
|
if type(instance) == ConsoleServerPort:
|
||||||
|
return ConsoleServerPortType
|
||||||
|
if type(instance) == FrontPort:
|
||||||
|
return FrontPortType
|
||||||
|
if type(instance) == Interface:
|
||||||
|
return InterfaceType
|
||||||
|
if type(instance) == PowerOutlet:
|
||||||
|
return PowerOutletType
|
||||||
|
if type(instance) == PowerPort:
|
||||||
|
return PowerPortType
|
||||||
|
if type(instance) == RearPort:
|
||||||
|
return RearPortType
|
@ -86,17 +86,9 @@ class ComponentTemplateObjectType(
|
|||||||
# Model types
|
# Model types
|
||||||
#
|
#
|
||||||
|
|
||||||
class CableTerminationType(NetBoxObjectType):
|
|
||||||
|
|
||||||
class Meta:
|
|
||||||
model = models.CableTermination
|
|
||||||
fields = '__all__'
|
|
||||||
filterset_class = filtersets.CableTerminationFilterSet
|
|
||||||
|
|
||||||
|
|
||||||
class CableType(NetBoxObjectType):
|
class CableType(NetBoxObjectType):
|
||||||
a_terminations = graphene.List(CableTerminationType)
|
a_terminations = graphene.List('dcim.graphql.gfk_mixins.CableTerminationTerminationType')
|
||||||
b_terminations = graphene.List(CableTerminationType)
|
b_terminations = graphene.List('dcim.graphql.gfk_mixins.CableTerminationTerminationType')
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
model = models.Cable
|
model = models.Cable
|
||||||
@ -116,6 +108,15 @@ class CableType(NetBoxObjectType):
|
|||||||
return self.b_terminations
|
return self.b_terminations
|
||||||
|
|
||||||
|
|
||||||
|
class CableTerminationType(NetBoxObjectType):
|
||||||
|
termination = graphene.Field('dcim.graphql.gfk_mixins.CableTerminationTerminationType')
|
||||||
|
|
||||||
|
class Meta:
|
||||||
|
model = models.CableTermination
|
||||||
|
exclude = ('termination_type', 'termination_id')
|
||||||
|
filterset_class = filtersets.CableTerminationFilterSet
|
||||||
|
|
||||||
|
|
||||||
class ConsolePortType(ComponentObjectType, CabledObjectMixin):
|
class ConsolePortType(ComponentObjectType, CabledObjectMixin):
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
@ -191,10 +192,11 @@ class DeviceBayTemplateType(ComponentTemplateObjectType):
|
|||||||
|
|
||||||
|
|
||||||
class InventoryItemTemplateType(ComponentTemplateObjectType):
|
class InventoryItemTemplateType(ComponentTemplateObjectType):
|
||||||
|
component = graphene.Field('dcim.graphql.gfk_mixins.InventoryItemTemplateComponentType')
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
model = models.InventoryItemTemplate
|
model = models.InventoryItemTemplate
|
||||||
fields = '__all__'
|
exclude = ('component_type', 'component_id')
|
||||||
filterset_class = filtersets.InventoryItemTemplateFilterSet
|
filterset_class = filtersets.InventoryItemTemplateFilterSet
|
||||||
|
|
||||||
|
|
||||||
@ -277,10 +279,11 @@ class InterfaceTemplateType(ComponentTemplateObjectType):
|
|||||||
|
|
||||||
|
|
||||||
class InventoryItemType(ComponentObjectType):
|
class InventoryItemType(ComponentObjectType):
|
||||||
|
component = graphene.Field('dcim.graphql.gfk_mixins.InventoryItemComponentType')
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
model = models.InventoryItem
|
model = models.InventoryItem
|
||||||
fields = '__all__'
|
exclude = ('component_type', 'component_id')
|
||||||
filterset_class = filtersets.InventoryItemFilterSet
|
filterset_class = filtersets.InventoryItemFilterSet
|
||||||
|
|
||||||
|
|
||||||
|
95
netbox/ipam/graphql/gfk_mixins.py
Normal file
95
netbox/ipam/graphql/gfk_mixins.py
Normal file
@ -0,0 +1,95 @@
|
|||||||
|
import graphene
|
||||||
|
from dcim.graphql.types import (
|
||||||
|
InterfaceType,
|
||||||
|
LocationType,
|
||||||
|
RackType,
|
||||||
|
RegionType,
|
||||||
|
SiteGroupType,
|
||||||
|
SiteType,
|
||||||
|
)
|
||||||
|
from dcim.models import Interface, Location, Rack, Region, Site, SiteGroup
|
||||||
|
from ipam.graphql.types import FHRPGroupType, VLANType
|
||||||
|
from ipam.models import VLAN, FHRPGroup
|
||||||
|
from virtualization.graphql.types import ClusterGroupType, ClusterType, VMInterfaceType
|
||||||
|
from virtualization.models import Cluster, ClusterGroup, VMInterface
|
||||||
|
|
||||||
|
|
||||||
|
class IPAddressAssignmentType(graphene.Union):
|
||||||
|
class Meta:
|
||||||
|
types = (
|
||||||
|
InterfaceType,
|
||||||
|
FHRPGroupType,
|
||||||
|
VMInterfaceType,
|
||||||
|
)
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def resolve_type(cls, instance, info):
|
||||||
|
if type(instance) == Interface:
|
||||||
|
return InterfaceType
|
||||||
|
if type(instance) == FHRPGroup:
|
||||||
|
return FHRPGroupType
|
||||||
|
if type(instance) == VMInterface:
|
||||||
|
return VMInterfaceType
|
||||||
|
|
||||||
|
|
||||||
|
class L2VPNAssignmentType(graphene.Union):
|
||||||
|
class Meta:
|
||||||
|
types = (
|
||||||
|
InterfaceType,
|
||||||
|
VLANType,
|
||||||
|
VMInterfaceType,
|
||||||
|
)
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def resolve_type(cls, instance, info):
|
||||||
|
if type(instance) == Interface:
|
||||||
|
return InterfaceType
|
||||||
|
if type(instance) == VLAN:
|
||||||
|
return VLANType
|
||||||
|
if type(instance) == VMInterface:
|
||||||
|
return VMInterfaceType
|
||||||
|
|
||||||
|
|
||||||
|
class FHRPGroupInterfaceType(graphene.Union):
|
||||||
|
class Meta:
|
||||||
|
types = (
|
||||||
|
InterfaceType,
|
||||||
|
VMInterfaceType,
|
||||||
|
)
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def resolve_type(cls, instance, info):
|
||||||
|
if type(instance) == Interface:
|
||||||
|
return InterfaceType
|
||||||
|
if type(instance) == VMInterface:
|
||||||
|
return VMInterfaceType
|
||||||
|
|
||||||
|
|
||||||
|
class VLANGroupScopeType(graphene.Union):
|
||||||
|
class Meta:
|
||||||
|
types = (
|
||||||
|
ClusterType,
|
||||||
|
ClusterGroupType,
|
||||||
|
LocationType,
|
||||||
|
RackType,
|
||||||
|
RegionType,
|
||||||
|
SiteType,
|
||||||
|
SiteGroupType,
|
||||||
|
)
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def resolve_type(cls, instance, info):
|
||||||
|
if type(instance) == Cluster:
|
||||||
|
return ClusterType
|
||||||
|
if type(instance) == ClusterGroup:
|
||||||
|
return ClusterGroupType
|
||||||
|
if type(instance) == Location:
|
||||||
|
return LocationType
|
||||||
|
if type(instance) == Rack:
|
||||||
|
return RackType
|
||||||
|
if type(instance) == Region:
|
||||||
|
return RegionType
|
||||||
|
if type(instance) == Site:
|
||||||
|
return SiteType
|
||||||
|
if type(instance) == SiteGroup:
|
||||||
|
return SiteGroupType
|
@ -1,5 +1,6 @@
|
|||||||
import graphene
|
import graphene
|
||||||
|
|
||||||
|
from graphene_django import DjangoObjectType
|
||||||
from ipam import filtersets, models
|
from ipam import filtersets, models
|
||||||
from netbox.graphql.scalars import BigInt
|
from netbox.graphql.scalars import BigInt
|
||||||
from netbox.graphql.types import BaseObjectType, OrganizationalObjectType, NetBoxObjectType
|
from netbox.graphql.types import BaseObjectType, OrganizationalObjectType, NetBoxObjectType
|
||||||
@ -54,18 +55,20 @@ class FHRPGroupType(NetBoxObjectType):
|
|||||||
|
|
||||||
|
|
||||||
class FHRPGroupAssignmentType(BaseObjectType):
|
class FHRPGroupAssignmentType(BaseObjectType):
|
||||||
|
interface = graphene.Field('ipam.graphql.gfk_mixins.FHRPGroupInterfaceType')
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
model = models.FHRPGroupAssignment
|
model = models.FHRPGroupAssignment
|
||||||
fields = '__all__'
|
exclude = ('interface_type', 'interface_id')
|
||||||
filterset_class = filtersets.FHRPGroupAssignmentFilterSet
|
filterset_class = filtersets.FHRPGroupAssignmentFilterSet
|
||||||
|
|
||||||
|
|
||||||
class IPAddressType(NetBoxObjectType):
|
class IPAddressType(NetBoxObjectType):
|
||||||
|
assigned_object = graphene.Field('ipam.graphql.gfk_mixins.IPAddressAssignmentType')
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
model = models.IPAddress
|
model = models.IPAddress
|
||||||
fields = '__all__'
|
exclude = ('assigned_object_type', 'assigned_object_id')
|
||||||
filterset_class = filtersets.IPAddressFilterSet
|
filterset_class = filtersets.IPAddressFilterSet
|
||||||
|
|
||||||
def resolve_role(self, info):
|
def resolve_role(self, info):
|
||||||
@ -140,10 +143,11 @@ class VLANType(NetBoxObjectType):
|
|||||||
|
|
||||||
|
|
||||||
class VLANGroupType(OrganizationalObjectType):
|
class VLANGroupType(OrganizationalObjectType):
|
||||||
|
scope = graphene.Field('ipam.graphql.gfk_mixins.VLANGroupScopeType')
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
model = models.VLANGroup
|
model = models.VLANGroup
|
||||||
fields = '__all__'
|
exclude = ('scope_type', 'scope_id')
|
||||||
filterset_class = filtersets.VLANGroupFilterSet
|
filterset_class = filtersets.VLANGroupFilterSet
|
||||||
|
|
||||||
|
|
||||||
@ -163,7 +167,9 @@ class L2VPNType(NetBoxObjectType):
|
|||||||
|
|
||||||
|
|
||||||
class L2VPNTerminationType(NetBoxObjectType):
|
class L2VPNTerminationType(NetBoxObjectType):
|
||||||
|
assigned_object = graphene.Field('ipam.graphql.gfk_mixins.L2VPNAssignmentType')
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
model = models.L2VPNTermination
|
model = models.L2VPNTermination
|
||||||
fields = '__all__'
|
exclude = ('assigned_object_type', 'assigned_object_id')
|
||||||
filtersets_class = filtersets.L2VPNTerminationFilterSet
|
filtersets_class = filtersets.L2VPNTerminationFilterSet
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
import inspect
|
||||||
import json
|
import json
|
||||||
|
|
||||||
from django.conf import settings
|
from django.conf import settings
|
||||||
@ -5,7 +6,7 @@ from django.contrib.auth.models import User
|
|||||||
from django.contrib.contenttypes.models import ContentType
|
from django.contrib.contenttypes.models import ContentType
|
||||||
from django.urls import reverse
|
from django.urls import reverse
|
||||||
from django.test import override_settings
|
from django.test import override_settings
|
||||||
from graphene.types import Dynamic as GQLDynamic, List as GQLList
|
from graphene.types import Dynamic as GQLDynamic, List as GQLList, Union as GQLUnion
|
||||||
from rest_framework import status
|
from rest_framework import status
|
||||||
from rest_framework.test import APIClient
|
from rest_framework.test import APIClient
|
||||||
|
|
||||||
@ -449,6 +450,9 @@ class APIViewTestCases:
|
|||||||
if type(field) is GQLDynamic:
|
if type(field) is GQLDynamic:
|
||||||
# Dynamic fields must specify a subselection
|
# Dynamic fields must specify a subselection
|
||||||
fields_string += f'{field_name} {{ id }}\n'
|
fields_string += f'{field_name} {{ id }}\n'
|
||||||
|
elif inspect.isclass(field.type) and issubclass(field.type, GQLUnion):
|
||||||
|
# Union types dont' have an id or consistent values
|
||||||
|
continue
|
||||||
elif type(field.type) is GQLList and field_name != 'choices':
|
elif type(field.type) is GQLList and field_name != 'choices':
|
||||||
# TODO: Come up with something more elegant
|
# TODO: Come up with something more elegant
|
||||||
# Temporary hack to support automated testing of reverse generic relations
|
# Temporary hack to support automated testing of reverse generic relations
|
||||||
|
Loading…
Reference in New Issue
Block a user