-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdns_router.py
More file actions
244 lines (205 loc) · 6.59 KB
/
dns_router.py
File metadata and controls
244 lines (205 loc) · 6.59 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
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
"""DNS service router.
Copyright (c) 2024 MultiFactor
License: https://github.com/MultiDirectoryLab/MultiDirectory/blob/main/LICENSE
"""
from dishka import FromDishka
from dns.exception import DNSException
from fastapi import Depends, status
from fastapi_error_map import rule
from fastapi_error_map.routing import ErrorAwareRouter
import ldap_protocol.dns.exceptions as dns_exc
from api.auth.utils import verify_auth
from api.error_routing import (
ERROR_MAP_TYPE,
DishkaErrorAwareRoute,
DomainErrorTranslator,
)
from api.main.adapters.dns import DNSFastAPIAdapter
from api.main.schema import (
DNSServiceForwardZoneCheckRequest,
DNSServiceRecordCreateRequest,
DNSServiceRecordDeleteRequest,
DNSServiceRecordUpdateRequest,
DNSServiceReloadZoneRequest,
DNSServiceSetupRequest,
DNSServiceZoneCreateRequest,
DNSServiceZoneDeleteRequest,
DNSServiceZoneUpdateRequest,
)
from api.utils import require_master_db
from enums import DomainCodes
from ldap_protocol.dns import (
DNSForwardServerStatus,
DNSForwardZone,
DNSRecords,
DNSServerParam,
DNSZone,
)
translator = DomainErrorTranslator(DomainCodes.DNS)
error_map: ERROR_MAP_TYPE = {
dns_exc.DNSSetupError: rule(
status=status.HTTP_422_UNPROCESSABLE_ENTITY,
translator=translator,
),
dns_exc.DNSRecordCreateError: rule(
status=status.HTTP_400_BAD_REQUEST,
translator=translator,
),
dns_exc.DNSRecordUpdateError: rule(
status=status.HTTP_400_BAD_REQUEST,
translator=translator,
),
dns_exc.DNSRecordDeleteError: rule(
status=status.HTTP_400_BAD_REQUEST,
translator=translator,
),
dns_exc.DNSZoneCreateError: rule(
status=status.HTTP_400_BAD_REQUEST,
translator=translator,
),
dns_exc.DNSZoneUpdateError: rule(
status=status.HTTP_400_BAD_REQUEST,
translator=translator,
),
dns_exc.DNSZoneDeleteError: rule(
status=status.HTTP_400_BAD_REQUEST,
translator=translator,
),
dns_exc.DNSUpdateServerOptionsError: rule(
status=status.HTTP_400_BAD_REQUEST,
translator=translator,
),
DNSException: rule(
status=status.HTTP_500_INTERNAL_SERVER_ERROR,
translator=translator,
),
dns_exc.DNSConnectionError: rule(
status=status.HTTP_400_BAD_REQUEST,
translator=translator,
),
dns_exc.DNSNotImplementedError: rule(
status=status.HTTP_400_BAD_REQUEST,
translator=translator,
),
}
dns_router = ErrorAwareRouter(
prefix="/dns",
tags=["DNS_SERVICE"],
dependencies=[Depends(verify_auth)],
route_class=DishkaErrorAwareRoute,
)
@dns_router.post("/record", error_map=error_map)
async def create_record(
data: DNSServiceRecordCreateRequest,
adapter: FromDishka[DNSFastAPIAdapter],
) -> None:
"""Create DNS record with given params."""
await adapter.create_record(data)
@dns_router.delete("/record", error_map=error_map)
async def delete_single_record(
data: DNSServiceRecordDeleteRequest,
adapter: FromDishka[DNSFastAPIAdapter],
) -> None:
"""Delete DNS record with given params."""
await adapter.delete_record(data)
@dns_router.patch("/record", error_map=error_map)
async def update_record(
data: DNSServiceRecordUpdateRequest,
adapter: FromDishka[DNSFastAPIAdapter],
) -> None:
"""Update DNS record with given params."""
await adapter.update_record(data)
@dns_router.get("/record", error_map=error_map)
async def get_all_records(
adapter: FromDishka[DNSFastAPIAdapter],
) -> list[DNSRecords]:
"""Get all DNS records of current zone."""
return await adapter.get_all_records()
@dns_router.get("/status", error_map=error_map)
async def get_dns_status(
adapter: FromDishka[DNSFastAPIAdapter],
) -> dict[str, str | None]:
"""Get DNS service status."""
return await adapter.get_dns_status()
@dns_router.post(
"/setup",
error_map=error_map,
dependencies=[Depends(require_master_db)],
)
async def setup_dns(
data: DNSServiceSetupRequest,
adapter: FromDishka[DNSFastAPIAdapter],
) -> None:
"""Set up DNS service."""
await adapter.setup_dns(data)
@dns_router.get("/zone", error_map=error_map)
async def get_dns_zone(
adapter: FromDishka[DNSFastAPIAdapter],
) -> list[DNSZone]:
"""Get all DNS records of all zones."""
return await adapter.get_dns_zone()
@dns_router.get("/zone/forward", error_map=error_map)
async def get_forward_dns_zones(
adapter: FromDishka[DNSFastAPIAdapter],
) -> list[DNSForwardZone]:
"""Get list of DNS forward zones with forwarders."""
return await adapter.get_forward_dns_zones()
@dns_router.post(
"/zone",
error_map=error_map,
warn_on_unmapped=False,
default_client_error_translator=translator,
)
async def create_zone(
data: DNSServiceZoneCreateRequest,
adapter: FromDishka[DNSFastAPIAdapter],
) -> None:
"""Create new DNS zone."""
await adapter.create_zone(data)
@dns_router.patch("/zone", error_map=error_map)
async def update_zone(
data: DNSServiceZoneUpdateRequest,
adapter: FromDishka[DNSFastAPIAdapter],
) -> None:
"""Update DNS zone with given params."""
await adapter.update_zone(data)
@dns_router.delete("/zone", error_map=error_map)
async def delete_zone(
data: DNSServiceZoneDeleteRequest,
adapter: FromDishka[DNSFastAPIAdapter],
) -> None:
"""Delete DNS zone."""
await adapter.delete_zone(data)
@dns_router.post("/forward_check", error_map=error_map)
async def check_dns_forward_zone(
data: DNSServiceForwardZoneCheckRequest,
adapter: FromDishka[DNSFastAPIAdapter],
) -> list[DNSForwardServerStatus]:
"""Check given DNS forward zone for availability."""
return await adapter.check_dns_forward_zone(data)
@dns_router.get("/zone/reload/", error_map=error_map)
async def reload_zone(
data: DNSServiceReloadZoneRequest,
adapter: FromDishka[DNSFastAPIAdapter],
) -> None:
"""Reload given DNS zone."""
await adapter.reload_zone(data)
@dns_router.patch("/server/options")
async def update_server_options(
data: list[DNSServerParam],
adapter: FromDishka[DNSFastAPIAdapter],
) -> None:
"""Update DNS server options."""
await adapter.update_server_options(data)
@dns_router.get("/server/options")
async def get_server_options(
adapter: FromDishka[DNSFastAPIAdapter],
) -> list[DNSServerParam]:
"""Get list of modifiable DNS server params."""
return await adapter.get_server_options()
@dns_router.get("/server/restart")
async def restart_server(
adapter: FromDishka[DNSFastAPIAdapter],
) -> None:
"""Restart entire DNS server."""
await adapter.restart_server()