leksyib/iReporter

View on GitHub
server/models/userModel.js

Summary

Maintainability
A
0 mins
Test Coverage
import { Pool } from 'pg';
import dotenv from 'dotenv';

dotenv.config();

const pool = new Pool({
  connectionString: process.env.DATABASE_URL,
});

export default class UserModel {
  /**
   * @description - Sign
   * @static
   *
   * @param {object} - User data object
   *
   * @memberof UserModel
   *
   * @returns {object} Class instance
   * */
  static async createUser(userObj) {
    try {
      const {
        firstname, lastname, othernames, phonenumber, email,
        username, password, isadmin, registered,
      } = userObj;

      const query = `
        INSERT INTO users(firstname, lastname, othernames, username, phonenumber, password, email, isadmin, registered)
        VALUES ('${firstname.trim()}', '${lastname.trim()}', '${othernames.trim()}', '${username.trim()}', '${phonenumber.trim().trim()}', '${password.trim()}', '${email.trim()}', '${isadmin}', '${registered}')
        RETURNING *
      `;
      const res = await pool.query(query);
      return res;
    } catch (error) {
      return error;
    }
  }

  /**
   * @description - Sign
   * @static
   *
   * @param {object} - username
   *
   * @memberof UserModel
   *
   * @returns {object} Class instance
   * */
  static async findOneByUsername(username) {
    try {
      const query = `SELECT * FROM users WHERE username = '${username.trim()}' `;
      const res = await pool.query(query);
      return res;
    } catch (error) {
      return error;
    }
  }

  /**
   * @description - Sign
   * @static
   *
   * @param {object} - User id
   *
   * @memberof UserModel
   *
   * @returns {object} Class instance
   * */
  static async findById(id) {
    try {
      const query = `SELECT * FROM users WHERE id = ${id} `;
      const res = await pool.query(query);
      return res;
    } catch (error) {
      return error;
    }
  }
}