Tue Oct 03 2023

MySQL Data Insertion

Node JS61 views

You can download the full project from WebGraphiz

MySQL Data Insertion

File Name: db.utils.js

const config = require("config");
const mysql = require("mysql2/promise");

const con = mysql.createConnection({
  connectionLimit: 50,
  host: config.get("dbHost"),
  user: config.get("dbUser"),
  password: config.get("dbPWD"),
  database: config.get("database"),
});

module.exports = con;

File Name: user.service.js

const config = require("config");
const bcrypt = require("bcrypt");
const connectDB = require("../utils/db.utils");

const createUser = async (data) => {
  try {
    const salt = await bcrypt.genSalt(config.get("saltFactor"));
    const passHash = bcrypt.hashSync(data.usrPass, salt);

    const userData = [data.usrName, data.usrEmail, passHash];

    const con = await connectDB;

    const sql =
      "INSERT INTO users (fullName, email, password) VALUES (?, ?, ?)";

    const [rows, fields] = await con.execute(sql, userData);
    return true;
  } catch (e) {
    return false;
  }
};

const checkEmail = async (email) => {
  try {
    const con = await connectDB;
    const sql = "SELECT COUNT(*) AS rowCount FROM users WHERE email = ?";
    const [rows, fields] = await con.execute(sql, [email]);

    if (rows[0].rowCount == 0) return true;
    else return false;
  } catch (e) {
    return false;
  }
};

const validUser = async (data) => {
  try {
    const con = await connectDB;
    const sql = "SELECT * FROM users WHERE email = ?";
    const [rows, fields] = await con.execute(sql, [data.usrEmail]);

    if (!rows) return false;

    const isValid = await bcrypt
      .compare(data.usrPass, rows[0].password)
      .catch((e) => false);

    if (!isValid) return false;
    else return rows[0].fullName;
  } catch (e) {
    return false;
  }
};

module.exports = { createUser, checkEmail, validUser };

We use cookies to improve your experience on our site and to show you personalised advertising. Please read our cookie policy and privacy policy.