import * as dotenv from 'dotenv';
import {Friendship} from './Friendship.interface';
import {PartyPlanerDB} from '../PartyPlaner.db';

dotenv.config();

/**
 * Returns all friends of the given user
 * @param useDev If the dev or prod database should be used
 * @param userId The userId of the user to fetch the friends for
 * @return Friendship[] A list of friends
 */
export const getFriendshipData = async (useDev: boolean, userId: string): Promise<Friendship[]> => {
    let conn = PartyPlanerDB.getConnection(useDev);
    try {
        let rows = await conn.query('SELECT f.friendship_id, f.friend_id, u.first_name as friend_first_name, u.last_name as friend_last_name, u.username as friend_username FROM friendships f LEFT OUTER JOIN users u ON f.friend_id = u.user_id WHERE f.user_id = ?', userId);

        let friends: Friendship[] = [];

        for (let row of rows) {
            friends.push({
                friendshipId: row.friendship_id,
                friendId: row.friend_id,
                friendFirstName: row.friend_first_name,
                friendLastName: row.friend_last_name,
                friendUsername: row.friend_username
            });
        }

        return friends;
    } catch (err) {
        throw err;
    }
};