def accept_invite(cls, invitation_data): user = Authenticator.authenticate(invitation_data) invite = TeamDatabaseClient.get_team_invite_by_token( invitation_data.invite_token, user.email) if invite is None: return BadRequestTeamMessageResponse( "You weren't invited to this team.", UserResponseStatus.WRONG_CREDENTIALS.value) new_user_team = TeamUser(user_id=user.id, team_id=invite.team_id) try: TeamDatabaseClient.add_team_user(new_user_team) TeamDatabaseClient.delete_invite(invite) DatabaseClient.commit() BotService.tito_welcome(new_user_team.user_id, new_user_team.team_id) cls.logger().info( f"User #{user.id} joined team #{invite.team_id}.") except IntegrityError: DatabaseClient.rollback() cls.logger().error( f"User #{user.id} failed at joining team #{invite.team_id}.") return UnsuccessfulTeamMessageResponse("Couldn't join team.") else: return SuccessfulTeamMessageResponse( "Team joined!", TeamResponseStatus.ADDED.value)
def add_user(cls, add_data): admin = Authenticator.authenticate(add_data.authentication, UserRoles.is_admin) user = UserDatabaseClient.get_user_by_id(add_data.add_user_id) if user is None: cls.logger().info(f"User {add_data.add_user_id} not found.") raise UserNotFoundError("User not found.", UserResponseStatus.USER_NOT_FOUND.value) if user.role == UserRoles.ADMIN.value: cls.logger().warning( f"Admin #{admin.id} trying to add other admin to a team.") return BadRequestTeamMessageResponse( "You cannot add an admin to a team!", TeamResponseStatus.ROLE_UNAVAILABLE.value) if TeamDatabaseClient.get_user_in_team_by_ids( user.id, add_data.authentication.team_id) is not None: cls.logger().info( f"User {add_data.add_user_id} already part of team #{add_data.authentication.team_id}." ) return BadRequestTeamMessageResponse( "This user already belongs to the team.", TeamResponseStatus.ALREADY_REGISTERED.value) previous_invitation = TeamDatabaseClient.get_team_invite( add_data.authentication.team_id, user.email) if previous_invitation is not None: cls.logger().info( f"Deleting old invitation for user {add_data.add_user_id} to team " f"#{add_data.authentication.team_id}.") TeamDatabaseClient.delete_invite(previous_invitation) DatabaseClient.commit() added_user = TeamUser(user_id=add_data.add_user_id, team_id=add_data.authentication.team_id) try: TeamDatabaseClient.add_team_user(added_user) DatabaseClient.commit() BotService.tito_welcome(added_user.user_id, added_user.team_id) cls.logger().info( f"Added user #{added_user.user_id} to team #{added_user.team_id} by admin #{admin.id}." ) return SuccessfulTeamMessageResponse( "User added.", TeamResponseStatus.ADDED.value) except IntegrityError: DatabaseClient.rollback() cls.logger().error( f"Couldn't add user #{added_user.user_id} to team #{added_user.team_id}." ) return UnsuccessfulTeamMessageResponse( "Couldn't invite user to team.")