From 4273a005caf3543232c672c05e9a9ee6a5f7efba Mon Sep 17 00:00:00 2001 From: KatHellg Date: Tue, 26 Nov 2024 11:58:34 +0100 Subject: [PATCH] fixed feedback --- fedn/cli/.fedn/context.yaml | 2 ++ fedn/cli/__init__.py | 1 + fedn/cli/login_cmd.py | 71 +++++++++++++++++++++++++++++++++++++ fedn/utils/dist.py | 2 +- 4 files changed, 75 insertions(+), 1 deletion(-) create mode 100644 fedn/cli/.fedn/context.yaml create mode 100644 fedn/cli/login_cmd.py diff --git a/fedn/cli/.fedn/context.yaml b/fedn/cli/.fedn/context.yaml new file mode 100644 index 000000000..40a8ae693 --- /dev/null +++ b/fedn/cli/.fedn/context.yaml @@ -0,0 +1,2 @@ +access: eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ0b2tlbl90eXBlIjoiYWNjZXNzIiwiZXhwIjoxNzM1MjEwMjY5LCJpYXQiOjE3MzI2MTgyNjksImp0aSI6ImIxNDY4ODVlMzM4NTRiYWRhM2I3YTExODUyNzJjOTNjIiwidXNlcl9pZCI6MzQ3LCJjcmVhdG9yIjoiS2F0amFIIiwicm9sZSI6bnVsbCwicHJvamVjdF9zbHVnIjoiIn0.aUpJTSQYe_yTi2QiY0yzhdaAjkS9gd07o4V3X5f6LCg +refresh: eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ0b2tlbl90eXBlIjoicmVmcmVzaCIsImV4cCI6MTc0MDM5NDI2OSwiaWF0IjoxNzMyNjE4MjY5LCJqdGkiOiI3M2NmNDhhNDE3Mjc0ZTVlYTUwNTA5YWNiZDBlNDI4MyIsInVzZXJfaWQiOjM0NywiY3JlYXRvciI6IkthdGphSCIsInJvbGUiOm51bGwsInByb2plY3Rfc2x1ZyI6IiJ9.Y1sSbRKlI07kLv2p3YlCwP5lEKUBTOH-QqiOhVG9NBo diff --git a/fedn/cli/__init__.py b/fedn/cli/__init__.py index 7028dbfa6..be680eb23 100644 --- a/fedn/cli/__init__.py +++ b/fedn/cli/__init__.py @@ -11,3 +11,4 @@ from .status_cmd import status_cmd # noqa: F401 from .validation_cmd import validation_cmd # noqa: F401 from .controller_cmd import controller_cmd # noqa: F401 +from .login_cmd import login_cmd # noqa: F401 diff --git a/fedn/cli/login_cmd.py b/fedn/cli/login_cmd.py new file mode 100644 index 000000000..8ba406600 --- /dev/null +++ b/fedn/cli/login_cmd.py @@ -0,0 +1,71 @@ +import os +import yaml +import click +import requests + +from .main import main +from getpass import getpass + +# Replace this with the platform's actual login endpoint +home_dir = os.path.expanduser("~") + +DEFAULT_URL = "https://fedn.scaleoutsystems.com" + + +@main.group("studio") +@click.pass_context +def login_cmd(ctx): + """:param ctx:""" + pass + + +@login_cmd.command("login") +@click.pass_context +def login_cmd(ctx): + """Logging into FEDn Studio + + """ + # Step 1: Display welcome message + click.secho("Welcome to Scaleout FEDn!", fg="green") + + # Step 2: Prompt for domain + domain = input("Please enter your domain or press enter to use default domain: ").strip() + if domain: + URL = f"https//:{domain}/api/token/" + else: + URL = f"{DEFAULT_URL}/api/token/" + + # Step 3: Prompt for username and password + username = input("Please enter your username: ") + password = getpass("Please enter your password: ") + + # Call the authentication API + try: + response = requests.post( + URL, + json={"username": username, "password": password}, + headers={"Content-Type": "application/json"} + ) + response.raise_for_status() # Raise an error for HTTP codes 4xx/5xx + except requests.exceptions.RequestException as e: + click.secho("Error connecting to the platform. Please try again.", fg="red") + click.secho(str(e), fg="red") + return + + # Handle the response + if response.status_code == 200: + data = response.json() + if data.get("access"): + click.secho("Login successful!", fg="green") + context_path = os.path.join(home_dir, ".fedn") + if not os.path.exists(context_path): + os.makedirs(context_path) + try: + with open(f"{context_path}/context.yaml", "w") as yaml_file: + yaml.dump(data, yaml_file, default_flow_style=False) # Add access and refresh tokens to context yaml file + except Exception as e: + print(f"Error: Failed to write to YAML file. Details: {e}") + else: + click.secho("Login failed. Please check your credentials.", fg="red") + else: + click.secho(f"Unexpected error: {response.text}", fg="red") diff --git a/fedn/utils/dist.py b/fedn/utils/dist.py index e5fa7192b..82812dfc3 100644 --- a/fedn/utils/dist.py +++ b/fedn/utils/dist.py @@ -3,7 +3,7 @@ import fedn -def get_version(pacakge): +def get_version(package): # Dynamically get the version of the package try: version = importlib.metadata.version("fedn")