Skip to content

Commit 5254660

Browse files
15156 Add display_url to REST API (#16412)
* 15156 add display_url to REST API * 15156 fix view name * 15156 fix typo * 15156 fix tests * 15156 add url display_url to base class * 15156 add url display_url to base class * 15156 add url display_url to base class * 15156 review changes * 15156 review changes * 15156 review changes * 15156 review changes * 15156 remove bogus code * 15156 remove bogus code * 15156 review changes * 15156 review changes * 15156 review changes --------- Co-authored-by: Jeremy Stretch <[email protected]>
1 parent 2b4577e commit 5254660

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

62 files changed

+436
-620
lines changed

docs/plugins/development/rest-api.md

Lines changed: 3 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -27,7 +27,7 @@ Serializers are responsible for converting Python objects to JSON data suitable
2727

2828
#### Example
2929

30-
To create a serializer for a plugin model, subclass `NetBoxModelSerializer` in `api/serializers.py`. Specify the model class and the fields to include within the serializer's `Meta` class. It is generally advisable to include a `url` attribute on each serializer. This will render the direct link to access the object being rendered.
30+
To create a serializer for a plugin model, subclass `NetBoxModelSerializer` in `api/serializers.py`. Specify the model class and the fields to include within the serializer's `Meta` class.
3131

3232
```python
3333
# api/serializers.py
@@ -36,9 +36,7 @@ from netbox.api.serializers import NetBoxModelSerializer
3636
from my_plugin.models import MyModel
3737

3838
class MyModelSerializer(NetBoxModelSerializer):
39-
url = serializers.HyperlinkedIdentityField(
40-
view_name='plugins-api:myplugin-api:mymodel-detail'
41-
)
39+
foo = SiteSerializer(nested=True, allow_null=True)
4240

4341
class Meta:
4442
model = MyModel
@@ -63,9 +61,7 @@ from netbox.api.serializers import WritableNestedSerializer
6361
from my_plugin.models import MyModel
6462

6563
class NestedMyModelSerializer(WritableNestedSerializer):
66-
url = serializers.HyperlinkedIdentityField(
67-
view_name='plugins-api:myplugin-api:mymodel-detail'
68-
)
64+
foo = SiteSerializer(nested=True, allow_null=True)
6965

7066
class Meta:
7167
model = MyModel

netbox/circuits/api/nested_serializers.py

Lines changed: 6 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -20,11 +20,10 @@
2020
#
2121

2222
class NestedProviderNetworkSerializer(WritableNestedSerializer):
23-
url = serializers.HyperlinkedIdentityField(view_name='circuits-api:providernetwork-detail')
2423

2524
class Meta:
2625
model = ProviderNetwork
27-
fields = ['id', 'url', 'display', 'name']
26+
fields = ['id', 'url', 'display_url', 'display', 'name']
2827

2928

3029
#
@@ -35,24 +34,22 @@ class Meta:
3534
exclude_fields=('circuit_count',),
3635
)
3736
class NestedProviderSerializer(WritableNestedSerializer):
38-
url = serializers.HyperlinkedIdentityField(view_name='circuits-api:provider-detail')
3937
circuit_count = RelatedObjectCountField('circuits')
4038

4139
class Meta:
4240
model = Provider
43-
fields = ['id', 'url', 'display', 'name', 'slug', 'circuit_count']
41+
fields = ['id', 'url', 'display_url', 'display', 'name', 'slug', 'circuit_count']
4442

4543

4644
#
4745
# Provider Accounts
4846
#
4947

5048
class NestedProviderAccountSerializer(WritableNestedSerializer):
51-
url = serializers.HyperlinkedIdentityField(view_name='circuits-api:provideraccount-detail')
5249

5350
class Meta:
5451
model = ProviderAccount
55-
fields = ['id', 'url', 'display', 'name', 'account']
52+
fields = ['id', 'url', 'display_url', 'display', 'name', 'account']
5653

5754

5855
#
@@ -63,26 +60,23 @@ class Meta:
6360
exclude_fields=('circuit_count',),
6461
)
6562
class NestedCircuitTypeSerializer(WritableNestedSerializer):
66-
url = serializers.HyperlinkedIdentityField(view_name='circuits-api:circuittype-detail')
6763
circuit_count = RelatedObjectCountField('circuits')
6864

6965
class Meta:
7066
model = CircuitType
71-
fields = ['id', 'url', 'display', 'name', 'slug', 'circuit_count']
67+
fields = ['id', 'url', 'display_url', 'display', 'name', 'slug', 'circuit_count']
7268

7369

7470
class NestedCircuitSerializer(WritableNestedSerializer):
75-
url = serializers.HyperlinkedIdentityField(view_name='circuits-api:circuit-detail')
7671

7772
class Meta:
7873
model = Circuit
79-
fields = ['id', 'url', 'display', 'cid']
74+
fields = ['id', 'url', 'display_url', 'display', 'cid']
8075

8176

8277
class NestedCircuitTerminationSerializer(WritableNestedSerializer):
83-
url = serializers.HyperlinkedIdentityField(view_name='circuits-api:circuittermination-detail')
8478
circuit = NestedCircuitSerializer()
8579

8680
class Meta:
8781
model = CircuitTermination
88-
fields = ['id', 'url', 'display', 'circuit', 'term_side', 'cable', '_occupied']
82+
fields = ['id', 'url', 'display_url', 'display', 'circuit', 'term_side', 'cable', '_occupied']

netbox/circuits/api/serializers_/circuits.py

Lines changed: 10 additions & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -18,35 +18,32 @@
1818

1919

2020
class CircuitTypeSerializer(NetBoxModelSerializer):
21-
url = serializers.HyperlinkedIdentityField(view_name='circuits-api:circuittype-detail')
2221

2322
# Related object counts
2423
circuit_count = RelatedObjectCountField('circuits')
2524

2625
class Meta:
2726
model = CircuitType
2827
fields = [
29-
'id', 'url', 'display', 'name', 'slug', 'color', 'description', 'tags', 'custom_fields', 'created',
30-
'last_updated', 'circuit_count',
28+
'id', 'url', 'display_url', 'display', 'name', 'slug', 'color', 'description', 'tags', 'custom_fields',
29+
'created', 'last_updated', 'circuit_count',
3130
]
3231
brief_fields = ('id', 'url', 'display', 'name', 'slug', 'description', 'circuit_count')
3332

3433

3534
class CircuitCircuitTerminationSerializer(WritableNestedSerializer):
36-
url = serializers.HyperlinkedIdentityField(view_name='circuits-api:circuittermination-detail')
3735
site = SiteSerializer(nested=True, allow_null=True)
3836
provider_network = ProviderNetworkSerializer(nested=True, allow_null=True)
3937

4038
class Meta:
4139
model = CircuitTermination
4240
fields = [
43-
'id', 'url', 'display', 'site', 'provider_network', 'port_speed', 'upstream_speed', 'xconnect_id',
44-
'description',
41+
'id', 'url', 'display_url', 'display', 'site', 'provider_network', 'port_speed', 'upstream_speed',
42+
'xconnect_id', 'description',
4543
]
4644

4745

4846
class CircuitSerializer(NetBoxModelSerializer):
49-
url = serializers.HyperlinkedIdentityField(view_name='circuits-api:circuit-detail')
5047
provider = ProviderSerializer(nested=True)
5148
provider_account = ProviderAccountSerializer(nested=True, required=False, allow_null=True, default=None)
5249
status = ChoiceField(choices=CircuitStatusChoices, required=False)
@@ -58,24 +55,23 @@ class CircuitSerializer(NetBoxModelSerializer):
5855
class Meta:
5956
model = Circuit
6057
fields = [
61-
'id', 'url', 'display', 'cid', 'provider', 'provider_account', 'type', 'status', 'tenant', 'install_date',
62-
'termination_date', 'commit_rate', 'description', 'termination_a', 'termination_z', 'comments', 'tags',
63-
'custom_fields', 'created', 'last_updated',
58+
'id', 'url', 'display_url', 'display', 'cid', 'provider', 'provider_account', 'type', 'status', 'tenant',
59+
'install_date', 'termination_date', 'commit_rate', 'description', 'termination_a', 'termination_z',
60+
'comments', 'tags', 'custom_fields', 'created', 'last_updated',
6461
]
6562
brief_fields = ('id', 'url', 'display', 'cid', 'description')
6663

6764

6865
class CircuitTerminationSerializer(NetBoxModelSerializer, CabledObjectSerializer):
69-
url = serializers.HyperlinkedIdentityField(view_name='circuits-api:circuittermination-detail')
7066
circuit = CircuitSerializer(nested=True)
7167
site = SiteSerializer(nested=True, required=False, allow_null=True)
7268
provider_network = ProviderNetworkSerializer(nested=True, required=False, allow_null=True)
7369

7470
class Meta:
7571
model = CircuitTermination
7672
fields = [
77-
'id', 'url', 'display', 'circuit', 'term_side', 'site', 'provider_network', 'port_speed', 'upstream_speed',
78-
'xconnect_id', 'pp_info', 'description', 'mark_connected', 'cable', 'cable_end', 'link_peers',
79-
'link_peers_type', 'tags', 'custom_fields', 'created', 'last_updated', '_occupied',
73+
'id', 'url', 'display_url', 'display', 'circuit', 'term_side', 'site', 'provider_network', 'port_speed',
74+
'upstream_speed', 'xconnect_id', 'pp_info', 'description', 'mark_connected', 'cable', 'cable_end',
75+
'link_peers', 'link_peers_type', 'tags', 'custom_fields', 'created', 'last_updated', '_occupied',
8076
]
8177
brief_fields = ('id', 'url', 'display', 'circuit', 'term_side', 'description', 'cable', '_occupied')

netbox/circuits/api/serializers_/providers.py

Lines changed: 5 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -15,7 +15,6 @@
1515

1616

1717
class ProviderSerializer(NetBoxModelSerializer):
18-
url = serializers.HyperlinkedIdentityField(view_name='circuits-api:provider-detail')
1918
accounts = SerializedPKRelatedField(
2019
queryset=ProviderAccount.objects.all(),
2120
serializer=NestedProviderAccountSerializer,
@@ -36,34 +35,32 @@ class ProviderSerializer(NetBoxModelSerializer):
3635
class Meta:
3736
model = Provider
3837
fields = [
39-
'id', 'url', 'display', 'name', 'slug', 'accounts', 'description', 'comments', 'asns', 'tags',
40-
'custom_fields', 'created', 'last_updated', 'circuit_count',
38+
'id', 'url', 'display_url', 'display', 'name', 'slug', 'accounts', 'description', 'comments',
39+
'asns', 'tags', 'custom_fields', 'created', 'last_updated', 'circuit_count',
4140
]
4241
brief_fields = ('id', 'url', 'display', 'name', 'slug', 'description', 'circuit_count')
4342

4443

4544
class ProviderAccountSerializer(NetBoxModelSerializer):
46-
url = serializers.HyperlinkedIdentityField(view_name='circuits-api:provideraccount-detail')
4745
provider = ProviderSerializer(nested=True)
4846
name = serializers.CharField(allow_blank=True, max_length=100, required=False, default='')
4947

5048
class Meta:
5149
model = ProviderAccount
5250
fields = [
53-
'id', 'url', 'display', 'provider', 'name', 'account', 'description', 'comments', 'tags', 'custom_fields',
54-
'created', 'last_updated',
51+
'id', 'url', 'display_url', 'display', 'provider', 'name', 'account', 'description', 'comments', 'tags',
52+
'custom_fields', 'created', 'last_updated',
5553
]
5654
brief_fields = ('id', 'url', 'display', 'name', 'account', 'description')
5755

5856

5957
class ProviderNetworkSerializer(NetBoxModelSerializer):
60-
url = serializers.HyperlinkedIdentityField(view_name='circuits-api:providernetwork-detail')
6158
provider = ProviderSerializer(nested=True)
6259

6360
class Meta:
6461
model = ProviderNetwork
6562
fields = [
66-
'id', 'url', 'display', 'provider', 'name', 'service_id', 'description', 'comments', 'tags',
63+
'id', 'url', 'display_url', 'display', 'provider', 'name', 'service_id', 'description', 'comments', 'tags',
6764
'custom_fields', 'created', 'last_updated',
6865
]
6966
brief_fields = ('id', 'url', 'display', 'name', 'description')

netbox/core/api/nested_serializers.py

Lines changed: 3 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -14,23 +14,20 @@
1414

1515

1616
class NestedDataSourceSerializer(WritableNestedSerializer):
17-
url = serializers.HyperlinkedIdentityField(view_name='core-api:datasource-detail')
1817

1918
class Meta:
2019
model = DataSource
21-
fields = ['id', 'url', 'display', 'name']
20+
fields = ['id', 'url', 'display_url', 'display', 'name']
2221

2322

2423
class NestedDataFileSerializer(WritableNestedSerializer):
25-
url = serializers.HyperlinkedIdentityField(view_name='core-api:datafile-detail')
2624

2725
class Meta:
2826
model = DataFile
29-
fields = ['id', 'url', 'display', 'path']
27+
fields = ['id', 'url', 'display_url', 'display', 'path']
3028

3129

3230
class NestedJobSerializer(serializers.ModelSerializer):
33-
url = serializers.HyperlinkedIdentityField(view_name='core-api:job-detail')
3431
status = ChoiceField(choices=JobStatusChoices)
3532
user = UserSerializer(
3633
nested=True,
@@ -39,4 +36,4 @@ class NestedJobSerializer(serializers.ModelSerializer):
3936

4037
class Meta:
4138
model = Job
42-
fields = ['url', 'created', 'completed', 'user', 'status']
39+
fields = ['url', 'display_url', 'created', 'completed', 'user', 'status']

netbox/core/api/serializers_/change_logging.py

Lines changed: 2 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -15,7 +15,6 @@
1515

1616

1717
class ObjectChangeSerializer(BaseModelSerializer):
18-
url = serializers.HyperlinkedIdentityField(view_name='core-api:objectchange-detail')
1918
user = UserSerializer(
2019
nested=True,
2120
read_only=True
@@ -44,8 +43,8 @@ class ObjectChangeSerializer(BaseModelSerializer):
4443
class Meta:
4544
model = ObjectChange
4645
fields = [
47-
'id', 'url', 'display', 'time', 'user', 'user_name', 'request_id', 'action', 'changed_object_type',
48-
'changed_object_id', 'changed_object', 'prechange_data', 'postchange_data',
46+
'id', 'url', 'display_url', 'display', 'time', 'user', 'user_name', 'request_id', 'action',
47+
'changed_object_type', 'changed_object_id', 'changed_object', 'prechange_data', 'postchange_data',
4948
]
5049

5150
@extend_schema_field(serializers.JSONField(allow_null=True))

netbox/core/api/serializers_/data.py

Lines changed: 2 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -13,9 +13,6 @@
1313

1414

1515
class DataSourceSerializer(NetBoxModelSerializer):
16-
url = serializers.HyperlinkedIdentityField(
17-
view_name='core-api:datasource-detail'
18-
)
1916
type = ChoiceField(
2017
choices=get_data_backend_choices()
2118
)
@@ -30,16 +27,13 @@ class DataSourceSerializer(NetBoxModelSerializer):
3027
class Meta:
3128
model = DataSource
3229
fields = [
33-
'id', 'url', 'display', 'name', 'type', 'source_url', 'enabled', 'status', 'description', 'comments',
30+
'id', 'url', 'display_url', 'display', 'name', 'type', 'source_url', 'enabled', 'status', 'description', 'comments',
3431
'parameters', 'ignore_rules', 'custom_fields', 'created', 'last_updated', 'file_count',
3532
]
3633
brief_fields = ('id', 'url', 'display', 'name', 'description')
3734

3835

3936
class DataFileSerializer(NetBoxModelSerializer):
40-
url = serializers.HyperlinkedIdentityField(
41-
view_name='core-api:datafile-detail'
42-
)
4337
source = DataSourceSerializer(
4438
nested=True,
4539
read_only=True
@@ -48,6 +42,6 @@ class DataFileSerializer(NetBoxModelSerializer):
4842
class Meta:
4943
model = DataFile
5044
fields = [
51-
'id', 'url', 'display', 'source', 'path', 'last_updated', 'size', 'hash',
45+
'id', 'url', 'display_url', 'display', 'source', 'path', 'last_updated', 'size', 'hash',
5246
]
5347
brief_fields = ('id', 'url', 'display', 'path')

netbox/core/api/serializers_/jobs.py

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -12,7 +12,6 @@
1212

1313

1414
class JobSerializer(BaseModelSerializer):
15-
url = serializers.HyperlinkedIdentityField(view_name='core-api:job-detail')
1615
user = UserSerializer(
1716
nested=True,
1817
read_only=True
@@ -25,7 +24,7 @@ class JobSerializer(BaseModelSerializer):
2524
class Meta:
2625
model = Job
2726
fields = [
28-
'id', 'url', 'display', 'object_type', 'object_id', 'name', 'status', 'created', 'scheduled', 'interval',
27+
'id', 'url', 'display_url', 'display', 'object_type', 'object_id', 'name', 'status', 'created', 'scheduled', 'interval',
2928
'started', 'completed', 'user', 'data', 'error', 'job_id',
3029
]
3130
brief_fields = ('url', 'created', 'completed', 'user', 'status')

0 commit comments

Comments
 (0)