diff --git a/connect/api/v2/commerce/serializers.py b/connect/api/v2/commerce/serializers.py index 3befd32d..bdfa67bd 100644 --- a/connect/api/v2/commerce/serializers.py +++ b/connect/api/v2/commerce/serializers.py @@ -99,10 +99,8 @@ def create(self, validated_data): ) create_keycloak_user_use_case = CreateKeycloakUserUseCase(user_dto) user_info = create_keycloak_user_use_case.execute() - except Exception: - raise serializers.ValidationError( - {"user_email": "User already exists in Keycloak"} - ) + except Exception as e: + raise serializers.ValidationError({"keycloak_error": str(e)}) # Create organization organization = Organization.objects.create( diff --git a/connect/usecases/users/create.py b/connect/usecases/users/create.py index 05878b9b..5199fc9f 100644 --- a/connect/usecases/users/create.py +++ b/connect/usecases/users/create.py @@ -19,7 +19,24 @@ class CreateKeycloakUserUseCase: user_dto: KeycloakUserDTO def generate_password(self) -> str: - return "".join(random.choices(string.ascii_letters + string.digits, k=10)) + uppercase = string.ascii_uppercase + lowercase = string.ascii_lowercase + digits = string.digits + special = "!@#$%^&*()_+-=[]{}|;:,.<>?" + + password = [ + random.choice(uppercase), # 1 uppercase + random.choice(lowercase), # 1 lowercase + random.choice(digits), # 1 digit + random.choice(special), # 1 special + ] + + all_chars = uppercase + lowercase + digits + special + password.extend(random.choices(all_chars, k=4)) + + random.shuffle(password) + + return "".join(password) def execute(self) -> dict: try: