Explorar o código

Added slug choices for interface and port types

Jeremy Stretch %!s(int64=6) %!d(string=hai) anos
pai
achega
d787c353f3
Modificáronse 3 ficheiros con 437 adicións e 30 borrados
  1. 404 21
      netbox/dcim/constants.py
  2. 24 0
      netbox/dcim/forms.py
  3. 9 9
      netbox/dcim/tests/test_views.py

+ 404 - 21
netbox/dcim/constants.py

@@ -1,4 +1,3 @@
-
 # Rack types
 # Rack types
 RACK_TYPE_2POST = 100
 RACK_TYPE_2POST = 100
 RACK_TYPE_4POST = 200
 RACK_TYPE_4POST = 200
@@ -58,7 +57,10 @@ SUBDEVICE_ROLE_CHOICES = (
     (SUBDEVICE_ROLE_CHILD, 'Child'),
     (SUBDEVICE_ROLE_CHILD, 'Child'),
 )
 )
 
 
-# Interface types
+#
+# Numeric interface types
+#
+
 # Virtual
 # Virtual
 IFACE_TYPE_VIRTUAL = 0
 IFACE_TYPE_VIRTUAL = 0
 IFACE_TYPE_LAG = 200
 IFACE_TYPE_LAG = 200
@@ -113,15 +115,15 @@ IFACE_TYPE_16GFC_SFP_PLUS = 3160
 IFACE_TYPE_32GFC_SFP28 = 3320
 IFACE_TYPE_32GFC_SFP28 = 3320
 IFACE_TYPE_128GFC_QSFP28 = 3400
 IFACE_TYPE_128GFC_QSFP28 = 3400
 # InfiniBand
 # InfiniBand
-IFACE_FF_INFINIBAND_SDR = 7010
-IFACE_FF_INFINIBAND_DDR = 7020
-IFACE_FF_INFINIBAND_QDR = 7030
-IFACE_FF_INFINIBAND_FDR10 = 7040
-IFACE_FF_INFINIBAND_FDR = 7050
-IFACE_FF_INFINIBAND_EDR = 7060
-IFACE_FF_INFINIBAND_HDR = 7070
-IFACE_FF_INFINIBAND_NDR = 7080
-IFACE_FF_INFINIBAND_XDR = 7090
+IFACE_TYPE_INFINIBAND_SDR = 7010
+IFACE_TYPE_INFINIBAND_DDR = 7020
+IFACE_TYPE_INFINIBAND_QDR = 7030
+IFACE_TYPE_INFINIBAND_FDR10 = 7040
+IFACE_TYPE_INFINIBAND_FDR = 7050
+IFACE_TYPE_INFINIBAND_EDR = 7060
+IFACE_TYPE_INFINIBAND_HDR = 7070
+IFACE_TYPE_INFINIBAND_NDR = 7080
+IFACE_TYPE_INFINIBAND_XDR = 7090
 # Serial
 # Serial
 IFACE_TYPE_T1 = 4000
 IFACE_TYPE_T1 = 4000
 IFACE_TYPE_E1 = 4010
 IFACE_TYPE_E1 = 4010
@@ -227,15 +229,15 @@ IFACE_TYPE_CHOICES = [
     [
     [
         'InfiniBand',
         'InfiniBand',
         [
         [
-            [IFACE_FF_INFINIBAND_SDR, 'SDR (2 Gbps)'],
-            [IFACE_FF_INFINIBAND_DDR, 'DDR (4 Gbps)'],
-            [IFACE_FF_INFINIBAND_QDR, 'QDR (8 Gbps)'],
-            [IFACE_FF_INFINIBAND_FDR10, 'FDR10 (10 Gbps)'],
-            [IFACE_FF_INFINIBAND_FDR, 'FDR (13.5 Gbps)'],
-            [IFACE_FF_INFINIBAND_EDR, 'EDR (25 Gbps)'],
-            [IFACE_FF_INFINIBAND_HDR, 'HDR (50 Gbps)'],
-            [IFACE_FF_INFINIBAND_NDR, 'NDR (100 Gbps)'],
-            [IFACE_FF_INFINIBAND_XDR, 'XDR (250 Gbps)'],
+            [IFACE_TYPE_INFINIBAND_SDR, 'SDR (2 Gbps)'],
+            [IFACE_TYPE_INFINIBAND_DDR, 'DDR (4 Gbps)'],
+            [IFACE_TYPE_INFINIBAND_QDR, 'QDR (8 Gbps)'],
+            [IFACE_TYPE_INFINIBAND_FDR10, 'FDR10 (10 Gbps)'],
+            [IFACE_TYPE_INFINIBAND_FDR, 'FDR (13.5 Gbps)'],
+            [IFACE_TYPE_INFINIBAND_EDR, 'EDR (25 Gbps)'],
+            [IFACE_TYPE_INFINIBAND_HDR, 'HDR (50 Gbps)'],
+            [IFACE_TYPE_INFINIBAND_NDR, 'NDR (100 Gbps)'],
+            [IFACE_TYPE_INFINIBAND_XDR, 'XDR (250 Gbps)'],
         ]
         ]
     ],
     ],
     [
     [
@@ -382,7 +384,8 @@ CONNECTION_STATUS_CHOICES = [
 
 
 # Cable endpoint types
 # Cable endpoint types
 CABLE_TERMINATION_TYPES = [
 CABLE_TERMINATION_TYPES = [
-    'consoleport', 'consoleserverport', 'interface', 'poweroutlet', 'powerport', 'frontport', 'rearport', 'circuittermination',
+    'consoleport', 'consoleserverport', 'interface', 'poweroutlet', 'powerport', 'frontport', 'rearport',
+    'circuittermination',
 ]
 ]
 
 
 # Cable types
 # Cable types
@@ -510,3 +513,383 @@ POWERFEED_LEG_CHOICES = (
     (POWERFEED_LEG_B, 'B'),
     (POWERFEED_LEG_B, 'B'),
     (POWERFEED_LEG_C, 'C'),
     (POWERFEED_LEG_C, 'C'),
 )
 )
+
+
+#
+# Interface type values
+#
+
+class InterfaceTypes:
+    """
+    Interface.type slugs
+    """
+    # Virtual
+    TYPE_VIRTUAL = 'virtual'
+    TYPE_LAG = 'lag'
+
+    # Ethernet
+    TYPE_100ME_FIXED = '100base-tx'
+    TYPE_1GE_FIXED = '1000base-t'
+    TYPE_1GE_GBIC = '1000base-x-gbic'
+    TYPE_1GE_SFP = '1000base-x-sfp'
+    TYPE_2GE_FIXED = '2.5gbase-t'
+    TYPE_5GE_FIXED = '5gbase-t'
+    TYPE_10GE_FIXED = '10gbase-t'
+    TYPE_10GE_CX4 = '10gbase-cx4'
+    TYPE_10GE_SFP_PLUS = '10gbase-x-sfpp'
+    TYPE_10GE_XFP = '10gbase-x-xfp'
+    TYPE_10GE_XENPAK = '10gbase-x-xenpak'
+    TYPE_10GE_X2 = '10gbase-x-x2'
+    TYPE_25GE_SFP28 = '25gbase-x-sfp28'
+    TYPE_40GE_QSFP_PLUS = '40gbase-x-qsfpp'
+    TYPE_50GE_QSFP28 = '50gbase-x-sfp28'
+    TYPE_100GE_CFP = '100gbase-x-cfp'
+    TYPE_100GE_CFP2 = '100gbase-x-cfp2'
+    TYPE_100GE_CFP4 = '100gbase-x-cfp4'
+    TYPE_100GE_CPAK = '100gbase-x-cpak'
+    TYPE_100GE_QSFP28 = '100gbase-x-qsfp28'
+    TYPE_200GE_CFP2 = '200gbase-x-cfp2'
+    TYPE_200GE_QSFP56 = '200gbase-x-qsfp56'
+    TYPE_400GE_QSFP_DD = '400gbase-x-qsfpdd'
+
+    # Wireless
+    TYPE_80211A = 'ieee802.11a'
+    TYPE_80211G = 'ieee802.11g'
+    TYPE_80211N = 'ieee802.11n'
+    TYPE_80211AC = 'ieee802.11ac'
+    TYPE_80211AD = 'ieee802.11ad'
+
+    # Cellular
+    TYPE_GSM = 'gsm'
+    TYPE_CDMA = 'cdma'
+    TYPE_LTE = 'lte'
+
+    # SONET
+    TYPE_SONET_OC3 = 'sonet-oc3'
+    TYPE_SONET_OC12 = 'sonet-oc12'
+    TYPE_SONET_OC48 = 'sonet-oc48'
+    TYPE_SONET_OC192 = 'sonet-oc192'
+    TYPE_SONET_OC768 = 'sonet-oc768'
+    TYPE_SONET_OC1920 = 'sonet-oc1920'
+    TYPE_SONET_OC3840 = 'sonet-oc3840'
+
+    # Fibrechannel
+    TYPE_1GFC_SFP = '1gfc-sfp'
+    TYPE_2GFC_SFP = '2gfc-sfp'
+    TYPE_4GFC_SFP = '4gfc-sfp'
+    TYPE_8GFC_SFP_PLUS = '8gfc-sfpp'
+    TYPE_16GFC_SFP_PLUS = '16gfc-sfpp'
+    TYPE_32GFC_SFP28 = '32gfc-sfp28'
+    TYPE_128GFC_QSFP28 = '128gfc-sfp28'
+
+    # InfiniBand
+    TYPE_INFINIBAND_SDR = 'inifiband-sdr'
+    TYPE_INFINIBAND_DDR = 'inifiband-ddr'
+    TYPE_INFINIBAND_QDR = 'inifiband-qdr'
+    TYPE_INFINIBAND_FDR10 = 'inifiband-fdr10'
+    TYPE_INFINIBAND_FDR = 'inifiband-fdr'
+    TYPE_INFINIBAND_EDR = 'inifiband-edr'
+    TYPE_INFINIBAND_HDR = 'inifiband-hdr'
+    TYPE_INFINIBAND_NDR = 'inifiband-ndr'
+    TYPE_INFINIBAND_XDR = 'inifiband-xdr'
+
+    # Serial
+    TYPE_T1 = 't1'
+    TYPE_E1 = 'e1'
+    TYPE_T3 = 't3'
+    TYPE_E3 = 'e3'
+
+    # Stacking
+    TYPE_STACKWISE = 'cisco-stackwise'
+    TYPE_STACKWISE_PLUS = 'cisco-stackwise-plus'
+    TYPE_FLEXSTACK = 'cisco-flexstack'
+    TYPE_FLEXSTACK_PLUS = 'cisco-flexstack-plus'
+    TYPE_JUNIPER_VCP = 'juniper-vcp'
+    TYPE_SUMMITSTACK = 'extreme-summitstack'
+    TYPE_SUMMITSTACK128 = 'extreme-summitstack-128'
+    TYPE_SUMMITSTACK256 = 'extreme-summitstack-256'
+    TYPE_SUMMITSTACK512 = 'extreme-summitstack-512'
+
+    # Other
+    TYPE_OTHER = 'other'
+
+    @classmethod
+    def as_choices(cls):
+        return (
+            (
+                'Virtual interfaces',
+                (
+                    (cls.TYPE_VIRTUAL, 'Virtual'),
+                    (cls.TYPE_LAG, 'Link Aggregation Group (LAG)'),
+                ),
+            ),
+            (
+                'Ethernet (fixed)',
+                (
+                    (cls.TYPE_100ME_FIXED, '100BASE-TX (10/100ME)'),
+                    (cls.TYPE_1GE_FIXED, '1000BASE-T (1GE)'),
+                    (cls.TYPE_2GE_FIXED, '2.5GBASE-T (2.5GE)'),
+                    (cls.TYPE_5GE_FIXED, '5GBASE-T (5GE)'),
+                    (cls.TYPE_10GE_FIXED, '10GBASE-T (10GE)'),
+                    (cls.TYPE_10GE_CX4, '10GBASE-CX4 (10GE)'),
+                )
+            ),
+            (
+                'Ethernet (modular)',
+                (
+                    (cls.TYPE_1GE_GBIC, 'GBIC (1GE)'),
+                    (cls.TYPE_1GE_SFP, 'SFP (1GE)'),
+                    (cls.TYPE_10GE_SFP_PLUS, 'SFP+ (10GE)'),
+                    (cls.TYPE_10GE_XFP, 'XFP (10GE)'),
+                    (cls.TYPE_10GE_XENPAK, 'XENPAK (10GE)'),
+                    (cls.TYPE_10GE_X2, 'X2 (10GE)'),
+                    (cls.TYPE_25GE_SFP28, 'SFP28 (25GE)'),
+                    (cls.TYPE_40GE_QSFP_PLUS, 'QSFP+ (40GE)'),
+                    (cls.TYPE_50GE_QSFP28, 'QSFP28 (50GE)'),
+                    (cls.TYPE_100GE_CFP, 'CFP (100GE)'),
+                    (cls.TYPE_100GE_CFP2, 'CFP2 (100GE)'),
+                    (cls.TYPE_200GE_CFP2, 'CFP2 (200GE)'),
+                    (cls.TYPE_100GE_CFP4, 'CFP4 (100GE)'),
+                    (cls.TYPE_100GE_CPAK, 'Cisco CPAK (100GE)'),
+                    (cls.TYPE_100GE_QSFP28, 'QSFP28 (100GE)'),
+                    (cls.TYPE_200GE_QSFP56, 'QSFP56 (200GE)'),
+                    (cls.TYPE_400GE_QSFP_DD, 'QSFP-DD (400GE)'),
+                )
+            ),
+            (
+                'Wireless',
+                (
+                    (cls.TYPE_80211A, 'IEEE 802.11a'),
+                    (cls.TYPE_80211G, 'IEEE 802.11b/g'),
+                    (cls.TYPE_80211N, 'IEEE 802.11n'),
+                    (cls.TYPE_80211AC, 'IEEE 802.11ac'),
+                    (cls.TYPE_80211AD, 'IEEE 802.11ad'),
+                )
+            ),
+            (
+                'Cellular',
+                (
+                    (cls.TYPE_GSM, 'GSM'),
+                    (cls.TYPE_CDMA, 'CDMA'),
+                    (cls.TYPE_LTE, 'LTE'),
+                )
+            ),
+            (
+                'SONET',
+                (
+                    (cls.TYPE_SONET_OC3, 'OC-3/STM-1'),
+                    (cls.TYPE_SONET_OC12, 'OC-12/STM-4'),
+                    (cls.TYPE_SONET_OC48, 'OC-48/STM-16'),
+                    (cls.TYPE_SONET_OC192, 'OC-192/STM-64'),
+                    (cls.TYPE_SONET_OC768, 'OC-768/STM-256'),
+                    (cls.TYPE_SONET_OC1920, 'OC-1920/STM-640'),
+                    (cls.TYPE_SONET_OC3840, 'OC-3840/STM-1234'),
+                )
+            ),
+            (
+                'FibreChannel',
+                (
+                    (cls.TYPE_1GFC_SFP, 'SFP (1GFC)'),
+                    (cls.TYPE_2GFC_SFP, 'SFP (2GFC)'),
+                    (cls.TYPE_4GFC_SFP, 'SFP (4GFC)'),
+                    (cls.TYPE_8GFC_SFP_PLUS, 'SFP+ (8GFC)'),
+                    (cls.TYPE_16GFC_SFP_PLUS, 'SFP+ (16GFC)'),
+                    (cls.TYPE_32GFC_SFP28, 'SFP28 (32GFC)'),
+                    (cls.TYPE_128GFC_QSFP28, 'QSFP28 (128GFC)'),
+                )
+            ),
+            (
+                'InfiniBand',
+                (
+                    (cls.TYPE_INFINIBAND_SDR, 'SDR (2 Gbps)'),
+                    (cls.TYPE_INFINIBAND_DDR, 'DDR (4 Gbps)'),
+                    (cls.TYPE_INFINIBAND_QDR, 'QDR (8 Gbps)'),
+                    (cls.TYPE_INFINIBAND_FDR10, 'FDR10 (10 Gbps)'),
+                    (cls.TYPE_INFINIBAND_FDR, 'FDR (13.5 Gbps)'),
+                    (cls.TYPE_INFINIBAND_EDR, 'EDR (25 Gbps)'),
+                    (cls.TYPE_INFINIBAND_HDR, 'HDR (50 Gbps)'),
+                    (cls.TYPE_INFINIBAND_NDR, 'NDR (100 Gbps)'),
+                    (cls.TYPE_INFINIBAND_XDR, 'XDR (250 Gbps)'),
+                )
+            ),
+            (
+                'Serial',
+                (
+                    (cls.TYPE_T1, 'T1 (1.544 Mbps)'),
+                    (cls.TYPE_E1, 'E1 (2.048 Mbps)'),
+                    (cls.TYPE_T3, 'T3 (45 Mbps)'),
+                    (cls.TYPE_E3, 'E3 (34 Mbps)'),
+                )
+            ),
+            (
+                'Stacking',
+                (
+                    (cls.TYPE_STACKWISE, 'Cisco StackWise'),
+                    (cls.TYPE_STACKWISE_PLUS, 'Cisco StackWise Plus'),
+                    (cls.TYPE_FLEXSTACK, 'Cisco FlexStack'),
+                    (cls.TYPE_FLEXSTACK_PLUS, 'Cisco FlexStack Plus'),
+                    (cls.TYPE_JUNIPER_VCP, 'Juniper VCP'),
+                    (cls.TYPE_SUMMITSTACK, 'Extreme SummitStack'),
+                    (cls.TYPE_SUMMITSTACK128, 'Extreme SummitStack-128'),
+                    (cls.TYPE_SUMMITSTACK256, 'Extreme SummitStack-256'),
+                    (cls.TYPE_SUMMITSTACK512, 'Extreme SummitStack-512'),
+                )
+            ),
+            (
+                'Other',
+                (
+                    (cls.TYPE_OTHER, 'Other'),
+                )
+            ),
+        )
+
+    @classmethod
+    def slug_to_integer(cls, slug):
+        """
+        Provide backward-compatible mapping of the type slug to integer.
+        """
+        return {
+            # Slug: integer
+            cls.TYPE_VIRTUAL: IFACE_TYPE_VIRTUAL,
+            cls.TYPE_LAG: IFACE_TYPE_LAG,
+            cls.TYPE_100ME_FIXED: IFACE_TYPE_100ME_FIXED,
+            cls.TYPE_1GE_FIXED: IFACE_TYPE_1GE_FIXED,
+            cls.TYPE_1GE_GBIC: IFACE_TYPE_1GE_GBIC,
+            cls.TYPE_1GE_SFP: IFACE_TYPE_1GE_SFP,
+            cls.TYPE_2GE_FIXED: IFACE_TYPE_2GE_FIXED,
+            cls.TYPE_5GE_FIXED: IFACE_TYPE_5GE_FIXED,
+            cls.TYPE_10GE_FIXED: IFACE_TYPE_10GE_FIXED,
+            cls.TYPE_10GE_CX4: IFACE_TYPE_10GE_CX4,
+            cls.TYPE_10GE_SFP_PLUS: IFACE_TYPE_10GE_SFP_PLUS,
+            cls.TYPE_10GE_XFP: IFACE_TYPE_10GE_XFP,
+            cls.TYPE_10GE_XENPAK: IFACE_TYPE_10GE_XENPAK,
+            cls.TYPE_10GE_X2: IFACE_TYPE_10GE_X2,
+            cls.TYPE_25GE_SFP28: IFACE_TYPE_25GE_SFP28,
+            cls.TYPE_40GE_QSFP_PLUS: IFACE_TYPE_40GE_QSFP_PLUS,
+            cls.TYPE_50GE_QSFP28: IFACE_TYPE_50GE_QSFP28,
+            cls.TYPE_100GE_CFP: IFACE_TYPE_100GE_CFP,
+            cls.TYPE_100GE_CFP2: IFACE_TYPE_100GE_CFP2,
+            cls.TYPE_100GE_CFP4: IFACE_TYPE_100GE_CFP4,
+            cls.TYPE_100GE_CPAK: IFACE_TYPE_100GE_CPAK,
+            cls.TYPE_100GE_QSFP28: IFACE_TYPE_100GE_QSFP28,
+            cls.TYPE_200GE_CFP2: IFACE_TYPE_200GE_CFP2,
+            cls.TYPE_200GE_QSFP56: IFACE_TYPE_200GE_QSFP56,
+            cls.TYPE_400GE_QSFP_DD: IFACE_TYPE_400GE_QSFP_DD,
+            cls.TYPE_80211A: IFACE_TYPE_80211A,
+            cls.TYPE_80211G: IFACE_TYPE_80211G,
+            cls.TYPE_80211N: IFACE_TYPE_80211N,
+            cls.TYPE_80211AC: IFACE_TYPE_80211AC,
+            cls.TYPE_80211AD: IFACE_TYPE_80211AD,
+            cls.TYPE_GSM: IFACE_TYPE_GSM,
+            cls.TYPE_CDMA: IFACE_TYPE_CDMA,
+            cls.TYPE_LTE: IFACE_TYPE_LTE,
+            cls.TYPE_SONET_OC3: IFACE_TYPE_SONET_OC3,
+            cls.TYPE_SONET_OC12: IFACE_TYPE_SONET_OC12,
+            cls.TYPE_SONET_OC48: IFACE_TYPE_SONET_OC48,
+            cls.TYPE_SONET_OC192: IFACE_TYPE_SONET_OC192,
+            cls.TYPE_SONET_OC768: IFACE_TYPE_SONET_OC768,
+            cls.TYPE_SONET_OC1920: IFACE_TYPE_SONET_OC1920,
+            cls.TYPE_SONET_OC3840: IFACE_TYPE_SONET_OC3840,
+            cls.TYPE_1GFC_SFP: IFACE_TYPE_1GFC_SFP,
+            cls.TYPE_2GFC_SFP: IFACE_TYPE_2GFC_SFP,
+            cls.TYPE_4GFC_SFP: IFACE_TYPE_4GFC_SFP,
+            cls.TYPE_8GFC_SFP_PLUS: IFACE_TYPE_8GFC_SFP_PLUS,
+            cls.TYPE_16GFC_SFP_PLUS: IFACE_TYPE_16GFC_SFP_PLUS,
+            cls.TYPE_32GFC_SFP28: IFACE_TYPE_32GFC_SFP28,
+            cls.TYPE_128GFC_QSFP28: IFACE_TYPE_128GFC_QSFP28,
+            cls.TYPE_INFINIBAND_SDR: IFACE_TYPE_INFINIBAND_SDR,
+            cls.TYPE_INFINIBAND_DDR: IFACE_TYPE_INFINIBAND_DDR,
+            cls.TYPE_INFINIBAND_QDR: IFACE_TYPE_INFINIBAND_QDR,
+            cls.TYPE_INFINIBAND_FDR10: IFACE_TYPE_INFINIBAND_FDR10,
+            cls.TYPE_INFINIBAND_FDR: IFACE_TYPE_INFINIBAND_FDR,
+            cls.TYPE_INFINIBAND_EDR: IFACE_TYPE_INFINIBAND_EDR,
+            cls.TYPE_INFINIBAND_HDR: IFACE_TYPE_INFINIBAND_HDR,
+            cls.TYPE_INFINIBAND_NDR: IFACE_TYPE_INFINIBAND_NDR,
+            cls.TYPE_INFINIBAND_XDR: IFACE_TYPE_INFINIBAND_XDR,
+            cls.TYPE_T1: IFACE_TYPE_T1,
+            cls.TYPE_E1: IFACE_TYPE_E1,
+            cls.TYPE_T3: IFACE_TYPE_T3,
+            cls.TYPE_E3: IFACE_TYPE_E3,
+            cls.TYPE_STACKWISE: IFACE_TYPE_STACKWISE,
+            cls.TYPE_STACKWISE_PLUS: IFACE_TYPE_STACKWISE_PLUS,
+            cls.TYPE_FLEXSTACK: IFACE_TYPE_FLEXSTACK,
+            cls.TYPE_FLEXSTACK_PLUS: IFACE_TYPE_FLEXSTACK_PLUS,
+            cls.TYPE_JUNIPER_VCP: IFACE_TYPE_JUNIPER_VCP,
+            cls.TYPE_SUMMITSTACK: IFACE_TYPE_SUMMITSTACK,
+            cls.TYPE_SUMMITSTACK128: IFACE_TYPE_SUMMITSTACK128,
+            cls.TYPE_SUMMITSTACK256: IFACE_TYPE_SUMMITSTACK256,
+            cls.TYPE_SUMMITSTACK512: IFACE_TYPE_SUMMITSTACK512,
+        }.get(slug)
+
+
+#
+# Port type values
+#
+
+class PortTypes:
+    """
+    FrontPort/RearPort.type slugs
+    """
+    TYPE_8P8C = '8p8c'
+    TYPE_110_PUNCH = '110-punch'
+    TYPE_BNC = 'bnc'
+    TYPE_ST = 'st'
+    TYPE_SC = 'sc'
+    TYPE_SC_APC = 'sc-apc'
+    TYPE_FC = 'fc'
+    TYPE_LC = 'lc'
+    TYPE_LC_APC = 'lc-apc'
+    TYPE_MTRJ = 'mtrj'
+    TYPE_MPO = 'mpo'
+    TYPE_LSH = 'lsh'
+    TYPE_LSH_APC = 'lsh-apc'
+
+    @classmethod
+    def as_choices(cls):
+        return (
+            (
+                'Copper',
+                (
+                    (cls.TYPE_8P8C, '8P8C'),
+                    (cls.TYPE_110_PUNCH, '110 Punch'),
+                    (cls.TYPE_BNC, 'BNC'),
+                ),
+            ),
+            (
+                'Fiber Optic',
+                (
+                    (cls.TYPE_FC, 'FC'),
+                    (cls.TYPE_LC, 'LC'),
+                    (cls.TYPE_LC_APC, 'LC/APC'),
+                    (cls.TYPE_LSH, 'LSH'),
+                    (cls.TYPE_LSH_APC, 'LSH/APC'),
+                    (cls.TYPE_MPO, 'MPO'),
+                    (cls.TYPE_MTRJ, 'MTRJ'),
+                    (cls.TYPE_SC, 'SC'),
+                    (cls.TYPE_SC_APC, 'SC/APC'),
+                    (cls.TYPE_ST, 'ST'),
+                )
+            )
+        )
+
+    @classmethod
+    def slug_to_integer(cls, slug):
+        """
+        Provide backward-compatible mapping of the type slug to integer.
+        """
+        return {
+            # Slug: integer
+            cls.TYPE_8P8C: PORT_TYPE_8P8C,
+            cls.TYPE_110_PUNCH: PORT_TYPE_8P8C,
+            cls.TYPE_BNC: PORT_TYPE_BNC,
+            cls.TYPE_ST: PORT_TYPE_ST,
+            cls.TYPE_SC: PORT_TYPE_SC,
+            cls.TYPE_SC_APC: PORT_TYPE_SC_APC,
+            cls.TYPE_FC: PORT_TYPE_FC,
+            cls.TYPE_LC: PORT_TYPE_LC,
+            cls.TYPE_LC_APC: PORT_TYPE_LC_APC,
+            cls.TYPE_MTRJ: PORT_TYPE_MTRJ,
+            cls.TYPE_MPO: PORT_TYPE_MPO,
+            cls.TYPE_LSH: PORT_TYPE_LSH,
+            cls.TYPE_LSH_APC: PORT_TYPE_LSH_APC,
+        }.get(slug)

+ 24 - 0
netbox/dcim/forms.py

@@ -1289,6 +1289,9 @@ class PowerOutletTemplateImportForm(ComponentTemplateImportForm):
 
 
 
 
 class InterfaceTemplateImportForm(ComponentTemplateImportForm):
 class InterfaceTemplateImportForm(ComponentTemplateImportForm):
+    type = forms.ChoiceField(
+        choices=InterfaceTypes.as_choices()
+    )
 
 
     class Meta:
     class Meta:
         model = InterfaceTemplate
         model = InterfaceTemplate
@@ -1296,8 +1299,16 @@ class InterfaceTemplateImportForm(ComponentTemplateImportForm):
             'device_type', 'name', 'type', 'mgmt_only',
             'device_type', 'name', 'type', 'mgmt_only',
         ]
         ]
 
 
+    def clean_type(self):
+        # Convert slug value to field integer value
+        slug = self.cleaned_data['type']
+        return InterfaceTypes.slug_to_integer(slug)
+
 
 
 class FrontPortTemplateImportForm(ComponentTemplateImportForm):
 class FrontPortTemplateImportForm(ComponentTemplateImportForm):
+    type = forms.ChoiceField(
+        choices=PortTypes.as_choices()
+    )
     rear_port = forms.ModelChoiceField(
     rear_port = forms.ModelChoiceField(
         queryset=RearPortTemplate.objects.all(),
         queryset=RearPortTemplate.objects.all(),
         to_field_name='name',
         to_field_name='name',
@@ -1310,8 +1321,16 @@ class FrontPortTemplateImportForm(ComponentTemplateImportForm):
             'device_type', 'name', 'type', 'rear_port', 'rear_port_position',
             'device_type', 'name', 'type', 'rear_port', 'rear_port_position',
         ]
         ]
 
 
+    def clean_type(self):
+        # Convert slug value to field integer value
+        slug = self.cleaned_data['type']
+        return PortTypes.slug_to_integer(slug)
+
 
 
 class RearPortTemplateImportForm(ComponentTemplateImportForm):
 class RearPortTemplateImportForm(ComponentTemplateImportForm):
+    type = forms.ChoiceField(
+        choices=PortTypes.as_choices()
+    )
 
 
     class Meta:
     class Meta:
         model = RearPortTemplate
         model = RearPortTemplate
@@ -1319,6 +1338,11 @@ class RearPortTemplateImportForm(ComponentTemplateImportForm):
             'device_type', 'name', 'type', 'positions',
             'device_type', 'name', 'type', 'positions',
         ]
         ]
 
 
+    def clean_type(self):
+        # Convert slug value to field integer value
+        slug = self.cleaned_data['type']
+        return PortTypes.slug_to_integer(slug)
+
 
 
 class DeviceBayTemplateImportForm(ComponentTemplateImportForm):
 class DeviceBayTemplateImportForm(ComponentTemplateImportForm):
 
 

+ 9 - 9
netbox/dcim/tests/test_views.py

@@ -253,28 +253,28 @@ power-outlets:
     feed_leg: 1
     feed_leg: 1
 interfaces:
 interfaces:
   - name: Interface 1
   - name: Interface 1
-    type: 1000
+    type: 1000base-t
     mgmt_only: true
     mgmt_only: true
   - name: Interface 2
   - name: Interface 2
-    type: 1000
+    type: 1000base-t
   - name: Interface 3
   - name: Interface 3
-    type: 1000
+    type: 1000base-t
 rear-ports:
 rear-ports:
   - name: Rear Port 1
   - name: Rear Port 1
-    type: 1000
+    type: 8p8c
   - name: Rear Port 2
   - name: Rear Port 2
-    type: 1000
+    type: 8p8c
   - name: Rear Port 3
   - name: Rear Port 3
-    type: 1000
+    type: 8p8c
 front-ports:
 front-ports:
   - name: Front Port 1
   - name: Front Port 1
-    type: 1000
+    type: 8p8c
     rear_port: Rear Port 1
     rear_port: Rear Port 1
   - name: Front Port 2
   - name: Front Port 2
-    type: 1000
+    type: 8p8c
     rear_port: Rear Port 2
     rear_port: Rear Port 2
   - name: Front Port 3
   - name: Front Port 3
-    type: 1000
+    type: 8p8c
     rear_port: Rear Port 3
     rear_port: Rear Port 3
 device-bays:
 device-bays:
   - name: Device Bay 1
   - name: Device Bay 1