zenml-nightly 0.82.1.dev20250521__py3-none-any.whl → 0.82.1.dev20250524__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (57) hide show
  1. zenml/VERSION +1 -1
  2. zenml/client.py +6 -2
  3. zenml/config/build_configuration.py +7 -0
  4. zenml/config/docker_settings.py +25 -0
  5. zenml/config/server_config.py +7 -0
  6. zenml/constants.py +1 -0
  7. zenml/enums.py +1 -0
  8. zenml/environment.py +12 -0
  9. zenml/integrations/gcp/__init__.py +1 -1
  10. zenml/integrations/gcp/service_connectors/gcp_service_connector.py +12 -11
  11. zenml/integrations/hyperai/orchestrators/hyperai_orchestrator.py +1 -1
  12. zenml/integrations/kubernetes/orchestrators/kube_utils.py +16 -12
  13. zenml/materializers/built_in_materializer.py +9 -3
  14. zenml/zen_server/cloud_utils.py +45 -21
  15. zenml/zen_server/routers/actions_endpoints.py +6 -6
  16. zenml/zen_server/routers/artifact_endpoint.py +6 -6
  17. zenml/zen_server/routers/artifact_version_endpoints.py +11 -11
  18. zenml/zen_server/routers/auth_endpoints.py +4 -3
  19. zenml/zen_server/routers/code_repositories_endpoints.py +6 -6
  20. zenml/zen_server/routers/devices_endpoints.py +6 -6
  21. zenml/zen_server/routers/event_source_endpoints.py +6 -6
  22. zenml/zen_server/routers/flavors_endpoints.py +7 -7
  23. zenml/zen_server/routers/logs_endpoints.py +2 -2
  24. zenml/zen_server/routers/model_versions_endpoints.py +13 -13
  25. zenml/zen_server/routers/models_endpoints.py +6 -6
  26. zenml/zen_server/routers/pipeline_builds_endpoints.py +5 -5
  27. zenml/zen_server/routers/pipeline_deployments_endpoints.py +6 -6
  28. zenml/zen_server/routers/pipelines_endpoints.py +7 -7
  29. zenml/zen_server/routers/plugin_endpoints.py +3 -3
  30. zenml/zen_server/routers/projects_endpoints.py +7 -7
  31. zenml/zen_server/routers/run_metadata_endpoints.py +2 -2
  32. zenml/zen_server/routers/run_templates_endpoints.py +7 -7
  33. zenml/zen_server/routers/runs_endpoints.py +11 -11
  34. zenml/zen_server/routers/schedule_endpoints.py +6 -6
  35. zenml/zen_server/routers/secrets_endpoints.py +8 -8
  36. zenml/zen_server/routers/server_endpoints.py +13 -9
  37. zenml/zen_server/routers/service_accounts_endpoints.py +12 -12
  38. zenml/zen_server/routers/service_connectors_endpoints.py +13 -13
  39. zenml/zen_server/routers/service_endpoints.py +6 -6
  40. zenml/zen_server/routers/stack_components_endpoints.py +18 -9
  41. zenml/zen_server/routers/stack_deployment_endpoints.py +4 -4
  42. zenml/zen_server/routers/stacks_endpoints.py +6 -6
  43. zenml/zen_server/routers/steps_endpoints.py +8 -8
  44. zenml/zen_server/routers/tag_resource_endpoints.py +5 -5
  45. zenml/zen_server/routers/tags_endpoints.py +6 -6
  46. zenml/zen_server/routers/triggers_endpoints.py +9 -9
  47. zenml/zen_server/routers/users_endpoints.py +12 -12
  48. zenml/zen_server/routers/webhook_endpoints.py +2 -2
  49. zenml/zen_server/utils.py +72 -33
  50. zenml/zen_server/zen_server_api.py +211 -55
  51. zenml/zen_stores/rest_zen_store.py +40 -11
  52. zenml/zen_stores/sql_zen_store.py +79 -2
  53. {zenml_nightly-0.82.1.dev20250521.dist-info → zenml_nightly-0.82.1.dev20250524.dist-info}/METADATA +1 -1
  54. {zenml_nightly-0.82.1.dev20250521.dist-info → zenml_nightly-0.82.1.dev20250524.dist-info}/RECORD +57 -57
  55. {zenml_nightly-0.82.1.dev20250521.dist-info → zenml_nightly-0.82.1.dev20250524.dist-info}/LICENSE +0 -0
  56. {zenml_nightly-0.82.1.dev20250521.dist-info → zenml_nightly-0.82.1.dev20250524.dist-info}/WHEEL +0 -0
  57. {zenml_nightly-0.82.1.dev20250521.dist-info → zenml_nightly-0.82.1.dev20250524.dist-info}/entry_points.txt +0 -0
@@ -55,7 +55,7 @@ from zenml.zen_server.rbac.models import Action, ResourceType
55
55
  from zenml.zen_server.rbac.utils import verify_permission
56
56
  from zenml.zen_server.routers.projects_endpoints import workspace_router
57
57
  from zenml.zen_server.utils import (
58
- handle_exceptions,
58
+ async_fastapi_endpoint_wrapper,
59
59
  make_dependable,
60
60
  server_config,
61
61
  zen_store,
@@ -80,7 +80,7 @@ router = APIRouter(
80
80
  deprecated=True,
81
81
  tags=["run_templates"],
82
82
  )
83
- @handle_exceptions
83
+ @async_fastapi_endpoint_wrapper
84
84
  def create_run_template(
85
85
  run_template: RunTemplateRequest,
86
86
  project_name_or_id: Optional[Union[str, UUID]] = None,
@@ -117,7 +117,7 @@ def create_run_template(
117
117
  deprecated=True,
118
118
  tags=["run_templates"],
119
119
  )
120
- @handle_exceptions
120
+ @async_fastapi_endpoint_wrapper
121
121
  def list_run_templates(
122
122
  filter_model: RunTemplateFilter = Depends(
123
123
  make_dependable(RunTemplateFilter)
@@ -153,7 +153,7 @@ def list_run_templates(
153
153
  "/{template_id}",
154
154
  responses={401: error_response, 404: error_response, 422: error_response},
155
155
  )
156
- @handle_exceptions
156
+ @async_fastapi_endpoint_wrapper
157
157
  def get_run_template(
158
158
  template_id: UUID,
159
159
  hydrate: bool = True,
@@ -180,7 +180,7 @@ def get_run_template(
180
180
  "/{template_id}",
181
181
  responses={401: error_response, 404: error_response, 422: error_response},
182
182
  )
183
- @handle_exceptions
183
+ @async_fastapi_endpoint_wrapper
184
184
  def update_run_template(
185
185
  template_id: UUID,
186
186
  update: RunTemplateUpdate,
@@ -207,7 +207,7 @@ def update_run_template(
207
207
  "/{template_id}",
208
208
  responses={401: error_response, 404: error_response, 422: error_response},
209
209
  )
210
- @handle_exceptions
210
+ @async_fastapi_endpoint_wrapper
211
211
  def delete_run_template(
212
212
  template_id: UUID,
213
213
  _: AuthContext = Security(authorize),
@@ -235,7 +235,7 @@ if server_config().workload_manager_enabled:
235
235
  429: error_response,
236
236
  },
237
237
  )
238
- @handle_exceptions
238
+ @async_fastapi_endpoint_wrapper
239
239
  def create_template_run(
240
240
  template_id: UUID,
241
241
  config: Optional[PipelineRunConfiguration] = None,
@@ -54,7 +54,7 @@ from zenml.zen_server.rbac.utils import (
54
54
  )
55
55
  from zenml.zen_server.routers.projects_endpoints import workspace_router
56
56
  from zenml.zen_server.utils import (
57
- handle_exceptions,
57
+ async_fastapi_endpoint_wrapper,
58
58
  make_dependable,
59
59
  server_config,
60
60
  workload_manager,
@@ -83,7 +83,7 @@ logger = get_logger(__name__)
83
83
  deprecated=True,
84
84
  tags=["runs"],
85
85
  )
86
- @handle_exceptions
86
+ @async_fastapi_endpoint_wrapper
87
87
  def get_or_create_pipeline_run(
88
88
  pipeline_run: PipelineRunRequest,
89
89
  project_name_or_id: Optional[Union[str, UUID]] = None,
@@ -121,7 +121,7 @@ def get_or_create_pipeline_run(
121
121
  deprecated=True,
122
122
  tags=["runs"],
123
123
  )
124
- @handle_exceptions
124
+ @async_fastapi_endpoint_wrapper
125
125
  def list_runs(
126
126
  runs_filter_model: PipelineRunFilter = Depends(
127
127
  make_dependable(PipelineRunFilter)
@@ -156,7 +156,7 @@ def list_runs(
156
156
  "/{run_id}",
157
157
  responses={401: error_response, 404: error_response, 422: error_response},
158
158
  )
159
- @handle_exceptions
159
+ @async_fastapi_endpoint_wrapper
160
160
  def get_run(
161
161
  run_id: UUID,
162
162
  hydrate: bool = True,
@@ -222,7 +222,7 @@ def get_run(
222
222
  "/{run_id}",
223
223
  responses={401: error_response, 404: error_response, 422: error_response},
224
224
  )
225
- @handle_exceptions
225
+ @async_fastapi_endpoint_wrapper
226
226
  def update_run(
227
227
  run_id: UUID,
228
228
  run_model: PipelineRunUpdate,
@@ -249,7 +249,7 @@ def update_run(
249
249
  "/{run_id}",
250
250
  responses={401: error_response, 404: error_response, 422: error_response},
251
251
  )
252
- @handle_exceptions
252
+ @async_fastapi_endpoint_wrapper
253
253
  def delete_run(
254
254
  run_id: UUID,
255
255
  _: AuthContext = Security(authorize),
@@ -270,7 +270,7 @@ def delete_run(
270
270
  "/{run_id}" + STEPS,
271
271
  responses={401: error_response, 404: error_response, 422: error_response},
272
272
  )
273
- @handle_exceptions
273
+ @async_fastapi_endpoint_wrapper
274
274
  def get_run_steps(
275
275
  run_id: UUID,
276
276
  step_run_filter_model: StepRunFilter = Depends(
@@ -299,7 +299,7 @@ def get_run_steps(
299
299
  "/{run_id}" + PIPELINE_CONFIGURATION,
300
300
  responses={401: error_response, 404: error_response, 422: error_response},
301
301
  )
302
- @handle_exceptions
302
+ @async_fastapi_endpoint_wrapper
303
303
  def get_pipeline_configuration(
304
304
  run_id: UUID,
305
305
  _: AuthContext = Security(authorize),
@@ -322,7 +322,7 @@ def get_pipeline_configuration(
322
322
  "/{run_id}" + STATUS,
323
323
  responses={401: error_response, 404: error_response, 422: error_response},
324
324
  )
325
- @handle_exceptions
325
+ @async_fastapi_endpoint_wrapper
326
326
  def get_run_status(
327
327
  run_id: UUID,
328
328
  _: AuthContext = Security(authorize),
@@ -345,7 +345,7 @@ def get_run_status(
345
345
  "/{run_id}" + REFRESH,
346
346
  responses={401: error_response, 404: error_response, 422: error_response},
347
347
  )
348
- @handle_exceptions
348
+ @async_fastapi_endpoint_wrapper
349
349
  def refresh_run_status(
350
350
  run_id: UUID,
351
351
  _: AuthContext = Security(authorize),
@@ -394,7 +394,7 @@ def refresh_run_status(
394
394
  422: error_response,
395
395
  },
396
396
  )
397
- @handle_exceptions
397
+ @async_fastapi_endpoint_wrapper
398
398
  def run_logs(
399
399
  run_id: UUID,
400
400
  offset: int = 0,
@@ -33,7 +33,7 @@ from zenml.zen_server.rbac.endpoint_utils import (
33
33
  )
34
34
  from zenml.zen_server.routers.projects_endpoints import workspace_router
35
35
  from zenml.zen_server.utils import (
36
- handle_exceptions,
36
+ async_fastapi_endpoint_wrapper,
37
37
  make_dependable,
38
38
  zen_store,
39
39
  )
@@ -57,7 +57,7 @@ router = APIRouter(
57
57
  deprecated=True,
58
58
  tags=["schedules"],
59
59
  )
60
- @handle_exceptions
60
+ @async_fastapi_endpoint_wrapper
61
61
  def create_schedule(
62
62
  schedule: ScheduleRequest,
63
63
  project_name_or_id: Optional[Union[str, UUID]] = None,
@@ -97,7 +97,7 @@ def create_schedule(
97
97
  deprecated=True,
98
98
  tags=["schedules"],
99
99
  )
100
- @handle_exceptions
100
+ @async_fastapi_endpoint_wrapper
101
101
  def list_schedules(
102
102
  schedule_filter_model: ScheduleFilter = Depends(
103
103
  make_dependable(ScheduleFilter)
@@ -131,7 +131,7 @@ def list_schedules(
131
131
  "/{schedule_id}",
132
132
  responses={401: error_response, 404: error_response, 422: error_response},
133
133
  )
134
- @handle_exceptions
134
+ @async_fastapi_endpoint_wrapper
135
135
  def get_schedule(
136
136
  schedule_id: UUID,
137
137
  hydrate: bool = True,
@@ -157,7 +157,7 @@ def get_schedule(
157
157
  "/{schedule_id}",
158
158
  responses={401: error_response, 404: error_response, 422: error_response},
159
159
  )
160
- @handle_exceptions
160
+ @async_fastapi_endpoint_wrapper
161
161
  def update_schedule(
162
162
  schedule_id: UUID,
163
163
  schedule_update: ScheduleUpdate,
@@ -182,7 +182,7 @@ def update_schedule(
182
182
  "/{schedule_id}",
183
183
  responses={401: error_response, 404: error_response, 422: error_response},
184
184
  )
185
- @handle_exceptions
185
+ @async_fastapi_endpoint_wrapper
186
186
  def delete_schedule(
187
187
  schedule_id: UUID,
188
188
  _: AuthContext = Security(authorize),
@@ -51,7 +51,7 @@ from zenml.zen_server.rbac.utils import (
51
51
  )
52
52
  from zenml.zen_server.routers.projects_endpoints import workspace_router
53
53
  from zenml.zen_server.utils import (
54
- handle_exceptions,
54
+ async_fastapi_endpoint_wrapper,
55
55
  make_dependable,
56
56
  zen_store,
57
57
  )
@@ -81,7 +81,7 @@ op_router = APIRouter(
81
81
  deprecated=True,
82
82
  tags=["secrets"],
83
83
  )
84
- @handle_exceptions
84
+ @async_fastapi_endpoint_wrapper
85
85
  def create_secret(
86
86
  secret: SecretRequest,
87
87
  workspace_name_or_id: Optional[Union[str, UUID]] = None,
@@ -106,7 +106,7 @@ def create_secret(
106
106
  "",
107
107
  responses={401: error_response, 404: error_response, 422: error_response},
108
108
  )
109
- @handle_exceptions
109
+ @async_fastapi_endpoint_wrapper
110
110
  def list_secrets(
111
111
  secret_filter_model: SecretFilter = Depends(make_dependable(SecretFilter)),
112
112
  hydrate: bool = False,
@@ -153,7 +153,7 @@ def list_secrets(
153
153
  "/{secret_id}",
154
154
  responses={401: error_response, 404: error_response, 422: error_response},
155
155
  )
156
- @handle_exceptions
156
+ @async_fastapi_endpoint_wrapper
157
157
  def get_secret(
158
158
  secret_id: UUID,
159
159
  hydrate: bool = True,
@@ -185,7 +185,7 @@ def get_secret(
185
185
  "/{secret_id}",
186
186
  responses={401: error_response, 404: error_response, 422: error_response},
187
187
  )
188
- @handle_exceptions
188
+ @async_fastapi_endpoint_wrapper
189
189
  def update_secret(
190
190
  secret_id: UUID,
191
191
  secret_update: SecretUpdate,
@@ -225,7 +225,7 @@ def update_secret(
225
225
  "/{secret_id}",
226
226
  responses={401: error_response, 404: error_response, 422: error_response},
227
227
  )
228
- @handle_exceptions
228
+ @async_fastapi_endpoint_wrapper
229
229
  def delete_secret(
230
230
  secret_id: UUID,
231
231
  _: AuthContext = Security(authorize),
@@ -246,7 +246,7 @@ def delete_secret(
246
246
  SECRETS_BACKUP,
247
247
  responses={401: error_response, 404: error_response, 422: error_response},
248
248
  )
249
- @handle_exceptions
249
+ @async_fastapi_endpoint_wrapper
250
250
  def backup_secrets(
251
251
  ignore_errors: bool = True,
252
252
  delete_secrets: bool = False,
@@ -276,7 +276,7 @@ def backup_secrets(
276
276
  SECRETS_RESTORE,
277
277
  responses={401: error_response, 404: error_response, 422: error_response},
278
278
  )
279
- @handle_exceptions
279
+ @async_fastapi_endpoint_wrapper
280
280
  def restore_secrets(
281
281
  ignore_errors: bool = False,
282
282
  delete_secrets: bool = False,
@@ -46,7 +46,11 @@ from zenml.zen_server.auth import AuthContext, authorize
46
46
  from zenml.zen_server.exceptions import error_response
47
47
  from zenml.zen_server.rbac.models import ResourceType
48
48
  from zenml.zen_server.rbac.utils import get_allowed_resource_ids
49
- from zenml.zen_server.utils import handle_exceptions, server_config, zen_store
49
+ from zenml.zen_server.utils import (
50
+ async_fastapi_endpoint_wrapper,
51
+ server_config,
52
+ zen_store,
53
+ )
50
54
 
51
55
  router = APIRouter(
52
56
  prefix=API + VERSION_1,
@@ -56,7 +60,7 @@ router = APIRouter(
56
60
 
57
61
 
58
62
  @router.get("/version")
59
- def version() -> str:
63
+ async def version() -> str:
60
64
  """Get version of the server.
61
65
 
62
66
  Returns:
@@ -69,7 +73,7 @@ def version() -> str:
69
73
  INFO,
70
74
  responses={401: error_response, 404: error_response, 422: error_response},
71
75
  )
72
- @handle_exceptions
76
+ @async_fastapi_endpoint_wrapper
73
77
  def server_info() -> ServerModel:
74
78
  """Get information about the server.
75
79
 
@@ -83,7 +87,7 @@ def server_info() -> ServerModel:
83
87
  LOAD_INFO,
84
88
  response_model=ServerLoadInfo,
85
89
  )
86
- @handle_exceptions
90
+ @async_fastapi_endpoint_wrapper
87
91
  def server_load_info(_: AuthContext = Security(authorize)) -> ServerLoadInfo:
88
92
  """Get information about the server load.
89
93
 
@@ -132,7 +136,7 @@ def server_load_info(_: AuthContext = Security(authorize)) -> ServerLoadInfo:
132
136
  422: error_response,
133
137
  },
134
138
  )
135
- @handle_exceptions
139
+ @async_fastapi_endpoint_wrapper
136
140
  def get_onboarding_state(
137
141
  _: AuthContext = Security(authorize),
138
142
  ) -> List[str]:
@@ -159,7 +163,7 @@ if server_config().external_server_id is None:
159
163
  422: error_response,
160
164
  },
161
165
  )
162
- @handle_exceptions
166
+ @async_fastapi_endpoint_wrapper
163
167
  def get_settings(
164
168
  _: AuthContext = Security(authorize),
165
169
  hydrate: bool = True,
@@ -182,7 +186,7 @@ if server_config().external_server_id is None:
182
186
  422: error_response,
183
187
  },
184
188
  )
185
- @handle_exceptions
189
+ @async_fastapi_endpoint_wrapper
186
190
  def update_server_settings(
187
191
  settings_update: ServerSettingsUpdate,
188
192
  auth_context: AuthContext = Security(authorize),
@@ -227,7 +231,7 @@ if server_config().auth_scheme != AuthScheme.EXTERNAL:
227
231
  422: error_response,
228
232
  },
229
233
  )
230
- @handle_exceptions
234
+ @async_fastapi_endpoint_wrapper
231
235
  def activate_server(
232
236
  activate_request: ServerActivationRequest,
233
237
  ) -> Optional[UserResponse]:
@@ -246,7 +250,7 @@ if server_config().auth_scheme != AuthScheme.EXTERNAL:
246
250
  STATISTICS,
247
251
  responses={401: error_response, 404: error_response, 422: error_response},
248
252
  )
249
- @handle_exceptions
253
+ @async_fastapi_endpoint_wrapper
250
254
  def get_server_statistics(
251
255
  auth_context: AuthContext = Security(authorize),
252
256
  ) -> ServerStatistics:
@@ -49,7 +49,7 @@ from zenml.zen_server.rbac.endpoint_utils import (
49
49
  from zenml.zen_server.rbac.models import Action, ResourceType
50
50
  from zenml.zen_server.rbac.utils import verify_permission_for_model
51
51
  from zenml.zen_server.utils import (
52
- handle_exceptions,
52
+ async_fastapi_endpoint_wrapper,
53
53
  make_dependable,
54
54
  zen_store,
55
55
  )
@@ -73,7 +73,7 @@ router = APIRouter(
73
73
  422: error_response,
74
74
  },
75
75
  )
76
- @handle_exceptions
76
+ @async_fastapi_endpoint_wrapper
77
77
  def create_service_account(
78
78
  service_account: ServiceAccountRequest,
79
79
  _: AuthContext = Security(authorize),
@@ -96,7 +96,7 @@ def create_service_account(
96
96
  "/{service_account_name_or_id}",
97
97
  responses={401: error_response, 404: error_response, 422: error_response},
98
98
  )
99
- @handle_exceptions
99
+ @async_fastapi_endpoint_wrapper
100
100
  def get_service_account(
101
101
  service_account_name_or_id: Union[str, UUID],
102
102
  _: AuthContext = Security(authorize),
@@ -123,7 +123,7 @@ def get_service_account(
123
123
  "",
124
124
  responses={401: error_response, 404: error_response, 422: error_response},
125
125
  )
126
- @handle_exceptions
126
+ @async_fastapi_endpoint_wrapper
127
127
  def list_service_accounts(
128
128
  filter_model: ServiceAccountFilter = Depends(
129
129
  make_dependable(ServiceAccountFilter)
@@ -158,7 +158,7 @@ def list_service_accounts(
158
158
  422: error_response,
159
159
  },
160
160
  )
161
- @handle_exceptions
161
+ @async_fastapi_endpoint_wrapper
162
162
  def update_service_account(
163
163
  service_account_name_or_id: Union[str, UUID],
164
164
  service_account_update: ServiceAccountUpdate,
@@ -185,7 +185,7 @@ def update_service_account(
185
185
  "/{service_account_name_or_id}",
186
186
  responses={401: error_response, 404: error_response, 422: error_response},
187
187
  )
188
- @handle_exceptions
188
+ @async_fastapi_endpoint_wrapper
189
189
  def delete_service_account(
190
190
  service_account_name_or_id: Union[str, UUID],
191
191
  _: AuthContext = Security(authorize),
@@ -211,7 +211,7 @@ def delete_service_account(
211
211
  "/{service_account_id}" + API_KEYS,
212
212
  responses={401: error_response, 409: error_response, 422: error_response},
213
213
  )
214
- @handle_exceptions
214
+ @async_fastapi_endpoint_wrapper
215
215
  def create_api_key(
216
216
  service_account_id: UUID,
217
217
  api_key: APIKeyRequest,
@@ -249,7 +249,7 @@ def create_api_key(
249
249
  "/{service_account_id}" + API_KEYS + "/{api_key_name_or_id}",
250
250
  responses={401: error_response, 404: error_response, 422: error_response},
251
251
  )
252
- @handle_exceptions
252
+ @async_fastapi_endpoint_wrapper
253
253
  def get_api_key(
254
254
  service_account_id: UUID,
255
255
  api_key_name_or_id: Union[str, UUID],
@@ -282,7 +282,7 @@ def get_api_key(
282
282
  "/{service_account_id}" + API_KEYS,
283
283
  responses={401: error_response, 404: error_response, 422: error_response},
284
284
  )
285
- @handle_exceptions
285
+ @async_fastapi_endpoint_wrapper
286
286
  def list_api_keys(
287
287
  service_account_id: UUID,
288
288
  filter_model: APIKeyFilter = Depends(make_dependable(APIKeyFilter)),
@@ -316,7 +316,7 @@ def list_api_keys(
316
316
  "/{service_account_id}" + API_KEYS + "/{api_key_name_or_id}",
317
317
  responses={401: error_response, 409: error_response, 422: error_response},
318
318
  )
319
- @handle_exceptions
319
+ @async_fastapi_endpoint_wrapper
320
320
  def update_api_key(
321
321
  service_account_id: UUID,
322
322
  api_key_name_or_id: Union[str, UUID],
@@ -350,7 +350,7 @@ def update_api_key(
350
350
  + API_KEY_ROTATE,
351
351
  responses={401: error_response, 409: error_response, 422: error_response},
352
352
  )
353
- @handle_exceptions
353
+ @async_fastapi_endpoint_wrapper
354
354
  def rotate_api_key(
355
355
  service_account_id: UUID,
356
356
  api_key_name_or_id: Union[str, UUID],
@@ -381,7 +381,7 @@ def rotate_api_key(
381
381
  "/{service_account_id}" + API_KEYS + "/{api_key_name_or_id}",
382
382
  responses={401: error_response, 404: error_response, 422: error_response},
383
383
  )
384
- @handle_exceptions
384
+ @async_fastapi_endpoint_wrapper
385
385
  def delete_api_key(
386
386
  service_account_id: UUID,
387
387
  api_key_name_or_id: Union[str, UUID],
@@ -61,7 +61,7 @@ from zenml.zen_server.rbac.utils import (
61
61
  )
62
62
  from zenml.zen_server.routers.projects_endpoints import workspace_router
63
63
  from zenml.zen_server.utils import (
64
- handle_exceptions,
64
+ async_fastapi_endpoint_wrapper,
65
65
  make_dependable,
66
66
  zen_store,
67
67
  )
@@ -91,7 +91,7 @@ types_router = APIRouter(
91
91
  deprecated=True,
92
92
  tags=["service_connectors"],
93
93
  )
94
- @handle_exceptions
94
+ @async_fastapi_endpoint_wrapper
95
95
  def create_service_connector(
96
96
  connector: ServiceConnectorRequest,
97
97
  project_name_or_id: Optional[Union[str, UUID]] = None,
@@ -124,7 +124,7 @@ def create_service_connector(
124
124
  deprecated=True,
125
125
  tags=["service_connectors"],
126
126
  )
127
- @handle_exceptions
127
+ @async_fastapi_endpoint_wrapper
128
128
  def list_service_connectors(
129
129
  connector_filter_model: ServiceConnectorFilter = Depends(
130
130
  make_dependable(ServiceConnectorFilter)
@@ -198,7 +198,7 @@ def list_service_connectors(
198
198
  deprecated=True,
199
199
  tags=["service_connectors"],
200
200
  )
201
- @handle_exceptions
201
+ @async_fastapi_endpoint_wrapper
202
202
  def list_service_connector_resources(
203
203
  filter_model: ServiceConnectorFilter = Depends(
204
204
  make_dependable(ServiceConnectorFilter)
@@ -234,7 +234,7 @@ def list_service_connector_resources(
234
234
  "/{connector_id}",
235
235
  responses={401: error_response, 404: error_response, 422: error_response},
236
236
  )
237
- @handle_exceptions
237
+ @async_fastapi_endpoint_wrapper
238
238
  def get_service_connector(
239
239
  connector_id: UUID,
240
240
  expand_secrets: bool = True,
@@ -276,7 +276,7 @@ def get_service_connector(
276
276
  "/{connector_id}",
277
277
  responses={401: error_response, 404: error_response, 422: error_response},
278
278
  )
279
- @handle_exceptions
279
+ @async_fastapi_endpoint_wrapper
280
280
  def update_service_connector(
281
281
  connector_id: UUID,
282
282
  connector_update: ServiceConnectorUpdate,
@@ -303,7 +303,7 @@ def update_service_connector(
303
303
  "/{connector_id}",
304
304
  responses={401: error_response, 404: error_response, 422: error_response},
305
305
  )
306
- @handle_exceptions
306
+ @async_fastapi_endpoint_wrapper
307
307
  def delete_service_connector(
308
308
  connector_id: UUID,
309
309
  _: AuthContext = Security(authorize),
@@ -324,7 +324,7 @@ def delete_service_connector(
324
324
  SERVICE_CONNECTOR_VERIFY,
325
325
  responses={401: error_response, 409: error_response, 422: error_response},
326
326
  )
327
- @handle_exceptions
327
+ @async_fastapi_endpoint_wrapper
328
328
  def validate_and_verify_service_connector_config(
329
329
  connector: ServiceConnectorRequest,
330
330
  list_resources: bool = True,
@@ -357,7 +357,7 @@ def validate_and_verify_service_connector_config(
357
357
  "/{connector_id}" + SERVICE_CONNECTOR_VERIFY,
358
358
  responses={401: error_response, 404: error_response, 422: error_response},
359
359
  )
360
- @handle_exceptions
360
+ @async_fastapi_endpoint_wrapper
361
361
  def validate_and_verify_service_connector(
362
362
  connector_id: UUID,
363
363
  resource_type: Optional[str] = None,
@@ -398,7 +398,7 @@ def validate_and_verify_service_connector(
398
398
  "/{connector_id}" + SERVICE_CONNECTOR_CLIENT,
399
399
  responses={401: error_response, 404: error_response, 422: error_response},
400
400
  )
401
- @handle_exceptions
401
+ @async_fastapi_endpoint_wrapper
402
402
  def get_service_connector_client(
403
403
  connector_id: UUID,
404
404
  resource_type: Optional[str] = None,
@@ -435,7 +435,7 @@ def get_service_connector_client(
435
435
  "",
436
436
  responses={401: error_response, 404: error_response, 422: error_response},
437
437
  )
438
- @handle_exceptions
438
+ @async_fastapi_endpoint_wrapper
439
439
  def list_service_connector_types(
440
440
  connector_type: Optional[str] = None,
441
441
  resource_type: Optional[str] = None,
@@ -465,7 +465,7 @@ def list_service_connector_types(
465
465
  "/{connector_type}",
466
466
  responses={401: error_response, 404: error_response, 422: error_response},
467
467
  )
468
- @handle_exceptions
468
+ @async_fastapi_endpoint_wrapper
469
469
  def get_service_connector_type(
470
470
  connector_type: str,
471
471
  _: AuthContext = Security(authorize),
@@ -485,7 +485,7 @@ def get_service_connector_type(
485
485
  SERVICE_CONNECTOR_FULL_STACK,
486
486
  responses={401: error_response, 409: error_response, 422: error_response},
487
487
  )
488
- @handle_exceptions
488
+ @async_fastapi_endpoint_wrapper
489
489
  def get_resources_based_on_service_connector_info(
490
490
  connector_info: Optional[ServiceConnectorInfo] = None,
491
491
  connector_uuid: Optional[UUID] = None,
@@ -38,7 +38,7 @@ from zenml.zen_server.rbac.endpoint_utils import (
38
38
  from zenml.zen_server.rbac.models import ResourceType
39
39
  from zenml.zen_server.routers.projects_endpoints import workspace_router
40
40
  from zenml.zen_server.utils import (
41
- handle_exceptions,
41
+ async_fastapi_endpoint_wrapper,
42
42
  make_dependable,
43
43
  zen_store,
44
44
  )
@@ -62,7 +62,7 @@ router = APIRouter(
62
62
  deprecated=True,
63
63
  tags=["services"],
64
64
  )
65
- @handle_exceptions
65
+ @async_fastapi_endpoint_wrapper
66
66
  def create_service(
67
67
  service: ServiceRequest,
68
68
  project_name_or_id: Optional[Union[str, UUID]] = None,
@@ -91,7 +91,7 @@ def create_service(
91
91
  "",
92
92
  responses={401: error_response, 404: error_response, 422: error_response},
93
93
  )
94
- @handle_exceptions
94
+ @async_fastapi_endpoint_wrapper
95
95
  def list_services(
96
96
  filter_model: ServiceFilter = Depends(make_dependable(ServiceFilter)),
97
97
  hydrate: bool = False,
@@ -120,7 +120,7 @@ def list_services(
120
120
  "/{service_id}",
121
121
  responses={401: error_response, 404: error_response, 422: error_response},
122
122
  )
123
- @handle_exceptions
123
+ @async_fastapi_endpoint_wrapper
124
124
  def get_service(
125
125
  service_id: UUID,
126
126
  hydrate: bool = True,
@@ -147,7 +147,7 @@ def get_service(
147
147
  "/{service_id}",
148
148
  responses={401: error_response, 404: error_response, 422: error_response},
149
149
  )
150
- @handle_exceptions
150
+ @async_fastapi_endpoint_wrapper
151
151
  def update_service(
152
152
  service_id: UUID,
153
153
  update: ServiceUpdate,
@@ -174,7 +174,7 @@ def update_service(
174
174
  "/{service_id}",
175
175
  responses={401: error_response, 404: error_response, 422: error_response},
176
176
  )
177
- @handle_exceptions
177
+ @async_fastapi_endpoint_wrapper
178
178
  def delete_service(
179
179
  service_id: UUID,
180
180
  _: AuthContext = Security(authorize),