From 83564b2c3ca6f2a38f64a13f1aedab4e4156d8d9 Mon Sep 17 00:00:00 2001 From: Stefan Nica Date: Fri, 20 Dec 2024 23:10:51 +0100 Subject: [PATCH] Fix the client user-agent headers --- src/zenml/zen_server/auth.py | 1 + src/zenml/zen_stores/rest_zen_store.py | 7 ++++++- 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/src/zenml/zen_server/auth.py b/src/zenml/zen_server/auth.py index 18a5b6774e..f7d21ed99f 100644 --- a/src/zenml/zen_server/auth.py +++ b/src/zenml/zen_server/auth.py @@ -775,6 +775,7 @@ def authenticate_external_user( # between web clients (i.e. the dashboard) and CLI clients (i.e. the # zenml CLI). user_agent = request.headers.get("User-Agent", "").lower() + logger.info(f"User agent: {user_agent}") if "zenml/" in user_agent: store.update_onboarding_state( completed_steps={OnboardingStep.DEVICE_VERIFIED} diff --git a/src/zenml/zen_stores/rest_zen_store.py b/src/zenml/zen_stores/rest_zen_store.py index a7f013904a..f0cab2de00 100644 --- a/src/zenml/zen_stores/rest_zen_store.py +++ b/src/zenml/zen_stores/rest_zen_store.py @@ -4053,7 +4053,12 @@ def get_or_generate_api_token(self) -> str: ) data: Optional[Dict[str, str]] = None - headers: Dict[str, str] = {} + + # Use a custom user agent to identify the ZenML client in the server + # logs. + headers: Dict[str, str] = { + "User-Agent": "zenml/" + zenml.__version__, + } # Check if an API key is configured api_key = credentials_store.get_api_key(self.url)