Netbox Create Device Interfaces Task¤
task api name:
create_device_interfaces
Task to create network interfaces on one or more devices in NetBox. This task creates interfaces in bulk and only if the interfaces do not already exist in NetBox, making it idempotent and safe to run multiple times.
The task supports alphanumeric range expansion, allowing you to create multiple interfaces with a single pattern. This is particularly useful for creating large numbers of similar interfaces efficiently.
Tip
The create_device_interfaces task automatically skips interfaces that already exist, preventing duplicate creation attempts and allowing for safe re-runs of automation tasks.
Interface Name Range Expansion¤
The task supports powerful range expansion patterns for creating multiple interfaces:
Numeric Ranges¤
Use [start-end] syntax to expand numeric ranges:
interface_name: "Ethernet[1-5]"
# Expands to: Ethernet1, Ethernet2, Ethernet3, Ethernet4, Ethernet5
interface_name: "Loopback[10-12]"
# Expands to: Loopback10, Loopback11, Loopback12
Comma-Separated Lists¤
Use [option1,option2,...] syntax to expand lists:
interface_name: "[ge,xe,fe]-0/0/0"
# Expands to: ge-0/0/0, xe-0/0/0, fe-0/0/0
interface_name: "Port-[A,B,C]"
# Expands to: Port-A, Port-B, Port-C
Multiple Range Patterns¤
Combine multiple range patterns in a single interface name:
interface_name: "[ge,xe]-0/0/[0-3]"
# Expands to: ge-0/0/0, ge-0/0/1, ge-0/0/2, ge-0/0/3,
# xe-0/0/0, xe-0/0/1, xe-0/0/2, xe-0/0/3
Multiple Interface Names¤
Pass a list of interface names (with or without ranges):
interface_name:
- "Loopback[1-3]"
- "Management1"
- "[ge,xe]-0/1/0"
# Expands to: Loopback1, Loopback2, Loopback3, Management1, ge-0/1/0, xe-0/1/0
Branching Support¤
Create Device Interfaces task is branch aware and can create interfaces within a branch. Netbox Branching Plugin needs to be installed on the Netbox instance.
When using branches, interfaces are created in the specified branch and can be reviewed before merging into the main database.
NORFAB Netbox Create Device Interfaces Command Shell Reference¤
NorFab shell supports these command options for Netbox create_device_interfaces task:
nf#man tree netbox.create.device-interfaces
root
└── netbox: Netbox service
└── create: Create objects in Netbox
└── device-interfaces: Create devices interfaces
├── instance: Netbox instance name to target
├── dry-run: Do not commit to database
├── branch: Branching plugin branch name to use
├── *devices: List of device names or device objects to create interfaces for
├── *interface_name: Name(s) of the interface(s) to create
├── interface-type: Name(s) of the interface(s) to create, default 'other'
├── description: Interface description
├── speed: Interface speed in Kbps
├── mtu: Maximum transmission unit size in bytes
├── timeout: Job timeout
├── workers: Filter worker to target, default 'any'
├── verbose-result: Control output details, default 'False'
└── progress: Display progress events, default 'True'
nf#
Usage Examples¤
Basic Interface Creation¤
Create a single interface on one device:
from norfab.core.nfapi import NorFab
nf = NorFab()
result = nf.run_job(
service="netbox",
task="create_device_interfaces",
workers="any",
kwargs={
"devices": ["switch-01", "switch-02"],
"interface_name": "Loopbback[0-5]",
"interface_type": "virtual",
"description": "Test interfaces"
}
)
Interface Types¤
Common interface types supported by NetBox:
virtual- Virtual interfaces (loopbacks, tunnel interfaces)lag- Link Aggregation Group (Port-Channel, bond)1000base-t- 1G copper Ethernet10gbase-x-sfpp- 10G SFP+ Ethernet25gbase-x-sfp28- 25G SFP28 Ethernet40gbase-x-qsfpp- 40G QSFP+ Ethernet100gbase-x-qsfp28- 100G QSFP28 Ethernetother- Generic interface type (default)
Refer to your NetBox instance for the complete list of available interface types.
Error Handling¤
Task handles several error conditions gracefully:
- Non-existent Device: If a device doesn't exist in NetBox, an error is logged but processing continues for other devices
- Duplicate Interfaces: Existing interfaces are automatically skipped and listed in the
skippedarray - Invalid Interface Type: NetBox will reject invalid interface types with an error message
- Branch Not Found: If a specified branch doesn't exist and the branching plugin is not available, the task will fail
Best Practices¤
- Use Dry Run First: Always test with
dry_run: Truebefore creating interfaces in production - Meaningful Names: Use descriptive interface names that match your device's actual interface naming
- Consistent Types: Use appropriate interface types that match the physical/virtual nature of the interfaces
- Batch Operations: Create multiple interfaces in a single call for efficiency
- Branch Usage: Use branches for testing bulk operations before committing to the main database
- Idempotency: The task is idempotent - running it multiple times with the same parameters is safe
Python API Reference¤
Create interfaces for one or more devices in NetBox. This task creates interfaces in bulk and only if interfaces does not exist in Netbox.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
job
|
Job
|
The job object containing execution context and metadata. |
required |
devices
|
list
|
List of device names or device objects to create interfaces for. |
required |
interface_name
|
Union[list, str]
|
Name(s) of the interface(s) to create. Can be a single interface name as a string or multiple names as a list. Alphanumeric ranges are supported for bulk creation:
|
None
|
interface_type
|
str
|
Type of interface (e.g., "other", "virtual", "lag", "1000base-t"). Defaults to "other". |
'other'
|
instance
|
Union[None, str]
|
NetBox instance identifier to use. If None, uses the default instance. Defaults to None. |
None
|
dry_run
|
bool
|
If True, simulates the operation without making actual changes. Defaults to False. |
False
|
branch
|
str
|
NetBox branch to use for the operation. Defaults to None. |
None
|
kwargs
|
dict
|
Any additional interface attributes |
{}
|
interfaces_data
|
list
|
List of per-interface payload dictionaries.
Each dictionary supports all NetBox interface create fields and must
include |
None
|
Returns:
| Name | Type | Description |
|---|---|---|
Result |
Result
|
Result object containing the task name, execution results, and affected resources. The result dictionary contains status and details of interface creation operations. |
Source code in norfab\workers\netbox_worker\interfaces_tasks.py
728 729 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 747 748 749 750 751 752 753 754 755 756 757 758 759 760 761 762 763 764 765 766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781 782 783 784 785 786 787 788 789 790 791 792 793 794 795 796 797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813 814 815 816 817 818 819 820 821 822 823 824 825 826 827 828 829 830 831 832 833 834 835 836 837 838 839 840 841 842 843 844 845 846 847 848 849 850 851 852 853 854 855 856 857 858 859 860 861 862 863 864 865 866 867 | |