-
Notifications
You must be signed in to change notification settings - Fork 4
Expand file tree
/
Copy pathip_range.py
More file actions
107 lines (93 loc) · 3.06 KB
/
ip_range.py
File metadata and controls
107 lines (93 loc) · 3.06 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
"""
IPRange entity examples for the Diode Python SDK.
This module demonstrates three patterns for ingesting IPRange entities:
- ip_range_minimal: Required fields only
- ip_range_extended: Common optional fields
- ip_range_explicit: Fully nested objects with all fields
"""
from netboxlabs.diode.sdk import DiodeClient
from netboxlabs.diode.sdk.ingester import (
Entity,
IPRange,
Owner,
OwnerGroup,
Role,
Tag,
Tenant,
VRF,
)
TARGET = "grpc://localhost:8080/diode"
APP_NAME = "ip_range-example"
APP_VERSION = "1.0.0"
CLIENT_ID = "diode"
CLIENT_SECRET = "changeme"
def main():
"""Main execution - demonstrates ingesting a IPRange entity."""
with DiodeClient(
target=TARGET,
app_name=APP_NAME,
app_version=APP_VERSION,
client_id=CLIENT_ID,
client_secret=CLIENT_SECRET,
) as client:
# Choose one of the three patterns:
ip_range = ip_range_minimal()
# ip_range = ip_range_extended()
# ip_range = ip_range_explicit()
response = client.ingest(entities=[Entity(ip_range=ip_range)])
if response.errors:
print(f"Errors: {response.errors}")
else:
print("IPRange ingested successfully")
def ip_range_minimal() -> IPRange:
"""Create a IPRange with only required fields using flat strings."""
return IPRange(
start_address="Example Start Address",
end_address="Example End Address",
metadata={"source": "example"},
)
def ip_range_extended() -> IPRange:
"""Create a IPRange with common optional fields."""
return IPRange(
start_address="Example Start Address",
end_address="Example End Address",
metadata={"source": "example", "custom_key": "custom_value"},
status="active",
description="Example description",
tenant="Example Tenant",
role="Example Role",
comments="Example comments",
mark_utilized=True,
mark_populated=True,
)
def ip_range_explicit() -> IPRange:
"""Create a IPRange with fully nested objects and all common fields."""
return IPRange(
start_address="Example Start Address",
end_address="Example End Address",
metadata={
"source": "example",
"custom_key": "custom_value",
"collected_at": "2024-01-15T10:30:00Z",
},
status="active",
description="Example description",
comments="Example comments",
mark_utilized=True,
mark_populated=True,
vrf=VRF(name="Example Name", metadata={"source": "example"}),
tenant=Tenant(
name="Example Name", slug="example-slug", metadata={"source": "example"}
),
role=Role(
name="Example Name", slug="example-slug", metadata={"source": "example"}
),
owner=Owner(
name="Example Name",
group=OwnerGroup(name="Example Name", metadata={"source": "example"}),
metadata={"source": "example"},
),
tags=[Tag(name="production")],
)
if __name__ == "__main__":
main()