Aggregate Interface Models
Overview
The Aggregate Interface models provide structured validation for aggregate (bonded) ethernet interface configuration. These models support Layer 2 and Layer 3 modes with LACP (Link Aggregation Control Protocol) configuration.
Models
AggregateInterfaceCreateModel: For creating new aggregate interfacesAggregateInterfaceUpdateModel: For updating existing interfaces (includesid)AggregateInterfaceResponseModel: Response model from API operationsAggregateLayer2: Layer 2 mode configurationAggregateLayer3: Layer 3 mode configuration
All models use extra="forbid" to reject undefined fields.
Model Attributes
AggregateInterfaceBaseModel
| Attribute | Type | Required | Default | Description |
|---|---|---|---|---|
name |
str | Yes | None | Interface name (e.g., "ae1") |
comment |
str | No | None | Description (max 1023 chars) |
layer2 |
AggregateLayer2 | No* | None | Layer 2 mode configuration |
layer3 |
AggregateLayer3 | No* | None | Layer 3 mode configuration |
folder |
str | No** | None | Folder container |
snippet |
str | No** | None | Snippet container |
device |
str | No** | None | Device container |
* Only one mode can be configured (oneOf validation) ** Exactly one container required for create operations
AggregateLayer2
| Attribute | Type | Required | Default | Description |
|---|---|---|---|---|
vlan_tag |
str | No | None | VLAN tag (1-4096) |
lacp |
LacpConfig | No | None | LACP configuration |
AggregateLayer3
| Attribute | Type | Required | Default | Description |
|---|---|---|---|---|
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 |
arp |
List[ArpEntry] | No | None | Static ARP entries |
ddns_config |
DdnsConfig | No | None | Dynamic DNS config |
lacp |
LacpConfig | No | None | LACP configuration |
* Only one IP mode can be configured (oneOf validation)
LacpConfig
| Attribute | Type | Default | Description |
|---|---|---|---|
enable |
bool | False | Enable LACP |
fast_failover |
bool | False | Enable fast failover |
mode |
str | "passive" | LACP mode (passive/active) |
transmission_rate |
str | "slow" | Rate (fast/slow) |
system_priority |
int | 32768 | System priority (1-65535) |
max_ports |
int | 8 | Max ports (1-8) |
Model Validators
Interface Mode Validation
Ensures only one of layer2 or layer3 is configured:
@model_validator(mode="after")
def validate_interface_mode(self) -> "AggregateInterfaceBaseModel":
modes = [self.layer2, self.layer3]
configured = [m for m in modes if m is not None]
if len(configured) > 1:
raise ValueError("Only one interface mode allowed: layer2 or layer3")
return self
Usage Examples
Layer 3 with LACP
from scm.models.network import AggregateInterfaceCreateModel
interface = AggregateInterfaceCreateModel(
name="ae1",
layer3={
"ip": [{"name": "10.0.0.1/24"}],
"mtu": 9000,
"lacp": {
"enable": True,
"mode": "active",
"fast_failover": True
}
},
folder="Interfaces"
)
payload = interface.model_dump(exclude_unset=True)