Layer3 Subinterface Models
Overview
The Layer3 Subinterface models provide structured validation for Layer 3 VLAN subinterface configuration. These subinterfaces support IP routing on VLAN-tagged traffic with static IP or DHCP addressing.
Models
Layer3SubinterfaceCreateModel: For creating new subinterfacesLayer3SubinterfaceUpdateModel: For updating existing subinterfaces (includesid)Layer3SubinterfaceResponseModel: Response model from API operations
All models use extra="forbid" to reject undefined fields.
Model Attributes
Layer3SubinterfaceBaseModel
| Attribute | Type | Required | Default | Description |
|---|---|---|---|---|
name |
str | Yes | None | Interface name (e.g., "ethernet1/1.100") |
tag |
str | Yes | None | VLAN tag (1-4096) |
comment |
str | No | None | Description (max 1023 chars) |
ip |
List[StaticIp] | No* | None | Static IP addresses |
dhcp_client |
DhcpClient | No* | None | DHCP client configuration |
mtu |
int | No | 1500 | MTU (576-9216) |
interface_management_profile |
str | No | None | Management profile (max 31 chars) |
arp |
List[ArpEntry] | No | None | Static ARP entries |
ddns_config |
DdnsConfig | No | None | Dynamic DNS configuration |
folder |
str | No** | None | Folder container |
snippet |
str | No** | None | Snippet container |
device |
str | No** | None | Device container |
* Only one IP mode (static or DHCP) can be configured ** Exactly one container required for create operations
Model Validators
IP Mode Validation
Ensures only one of ip or dhcp_client is configured:
@model_validator(mode="after")
def validate_ip_mode(self) -> "Layer3SubinterfaceBaseModel":
if self.ip and self.dhcp_client:
raise ValueError("Only one IP addressing mode allowed")
return self
Usage Examples
Static IP
from scm.models.network import Layer3SubinterfaceCreateModel
subinterface = Layer3SubinterfaceCreateModel(
name="ethernet1/1.100",
tag="100",
ip=[{"name": "192.168.100.1/24"}],
mtu=1500,
folder="Interfaces"
)
payload = subinterface.model_dump(exclude_unset=True)