Files
GenBI-Node-Setup/controller/loginUser.js
T
Gitea e8ab511b0d
Deploy Node App / deploy (push) Successful in 6s
first commit
2026-05-25 16:24:32 +05:30

69 lines
1.4 KiB
JavaScript

const clickhouse = require('../database/clickhouse');
const jwt = require('jsonwebtoken');
const JWT_SECRET = 'secretkey';
const loginUser = async (req, res) => {
try {
const { username, password } = req.body;
return res.send("hello");
if (!username || !password) {
return res.status(400).json({
success: false,
message: "Username and password are required"
});
}
const resultSet = await clickhouse.query({
query: 'SELECT * FROM usertable WHERE username = {user: String} AND password = {pass: String}',
query_params: {
user: username,
pass: password
},
format: 'JSONEachRow',
});
const rows = await resultSet.json();
if (rows.length === 0) {
return res.status(401).json({
success: false,
message: "Invalid username or password"
});
}
const user = rows[0];
const token = jwt.sign(
{
client_id: user.client_id,
username: user.username
},
JWT_SECRET,
{ expiresIn: '24h' }
);
res.status(200).json({
success: true,
message: "Login successful",
token: token,
});
} catch (error) {
console.error("Login Error:", error);
res.status(500).json({
success: false,
message: "Internal server error",
error: error.message
});
}
};
module.exports = { loginUser };