mirror of
https://github.com/xfarrow/blink
synced 2025-06-27 09:03:02 +02:00
transaction non funzionante
This commit is contained in:
@@ -18,7 +18,6 @@ const port = 3000;
|
||||
app.use(express.json());
|
||||
|
||||
app.post('/blinkapi/register', api_controller.register_async);
|
||||
app.post('blinkapi/login', api_controller.login);
|
||||
|
||||
// Start the server
|
||||
app.listen(port, () => {
|
||||
|
@@ -1,15 +1,19 @@
|
||||
const bcrypt = require('bcrypt');
|
||||
const { Pool } = require('pg');
|
||||
const crypto = require('crypto');
|
||||
const pgp = require('pg-promise')();
|
||||
const Pool = require('pg-pool');
|
||||
|
||||
const pool = new Pool({
|
||||
user: 'postgres',
|
||||
host: 'localhost',
|
||||
database: 'Blink',
|
||||
password: 'postgres',
|
||||
const dbConfig = {
|
||||
host: "localhost",
|
||||
port: 5432,
|
||||
max: 10,
|
||||
idleTimeoutMillis: 30000,
|
||||
database: "Blink",
|
||||
user: "postgres",
|
||||
password: "postgres"
|
||||
};
|
||||
|
||||
// Create a new connection pool
|
||||
const db = pgp({
|
||||
pool: new Pool(dbConfig),
|
||||
});
|
||||
|
||||
function register(req, res){
|
||||
@@ -81,34 +85,43 @@ async function register_async(req, res){
|
||||
|
||||
// Generate activation link token
|
||||
const activationLink = crypto.randomBytes(16).toString('hex');
|
||||
|
||||
const hashPasswordPromise = bcrypt.hash(userData.password, 10);
|
||||
var client;
|
||||
|
||||
try{
|
||||
client = await pool.connect();
|
||||
const insertQuery = `
|
||||
INSERT INTO "User" (display_name, date_of_birth, place_of_living, is_looking_for_job, email, password)
|
||||
const result = await db.tx(async (t) => {
|
||||
|
||||
// Inserting in "Person" table
|
||||
const userInsertQuery = `
|
||||
INSERT INTO "Person" (email, password, display_name, date_of_birth, available, enabled, place_of_living)
|
||||
VALUES ($1, $2, $3, $4, $5, $6)
|
||||
RETURNING *`;
|
||||
const result = await client.query(insertQuery, [
|
||||
RETURNING id`;
|
||||
|
||||
const userResult = await t.one(userInsertQuery, [
|
||||
userData.email,
|
||||
await hashPasswordPromise,
|
||||
userData.display_name,
|
||||
userData.date_of_birth,
|
||||
userData.place_of_living,
|
||||
userData.is_looking_for_job,
|
||||
userData.email,
|
||||
await hashPasswordPromise
|
||||
userData.available,
|
||||
false,
|
||||
userData.place_of_living
|
||||
]);
|
||||
res.status(200).json(result.rows[0]);
|
||||
|
||||
const activationLinkInsertQuery = `
|
||||
INSERT INTO "ActivationLink" (user_id, activation_code)
|
||||
VALUES ($1, $2)
|
||||
RETURNING *`;
|
||||
|
||||
const activationLinkResult = await t.one(activationLinkInsertQuery, [
|
||||
userResult.id,
|
||||
activationLink,
|
||||
]);
|
||||
return res.status(200).json({ user: userResult, activationLink: activationLinkResult });
|
||||
});
|
||||
}
|
||||
catch (error){
|
||||
console.error('Error inserting data:', error);
|
||||
res.status(500).json("Internal server error");
|
||||
}
|
||||
finally {
|
||||
if (client) {
|
||||
client.release();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
function login(req, res){
|
||||
@@ -116,6 +129,5 @@ function login(req, res){
|
||||
}
|
||||
|
||||
module.exports = {
|
||||
register_async,
|
||||
login
|
||||
register_async
|
||||
};
|
Reference in New Issue
Block a user