mirror of
https://github.com/xfarrow/blink
synced 2025-06-27 09:03:02 +02:00
Update api.js
This commit is contained in:
@@ -3,24 +3,25 @@
|
||||
** licensed under GPLv3
|
||||
*/
|
||||
|
||||
|
||||
const express = require('express');
|
||||
const { Client } = require('pg');
|
||||
const bcrypt = require('bcrypt');
|
||||
const { Pool } = require('pg');
|
||||
|
||||
const app = express();
|
||||
const port = 3000;
|
||||
|
||||
|
||||
// Middleware which parses JSON for POST requests
|
||||
app.use(express.json());
|
||||
|
||||
// Sample data (an array of items)
|
||||
const items = [
|
||||
{ id: 1, name: 'Item 1' },
|
||||
{ id: 2, name: 'Item 2' },
|
||||
{ id: 3, name: 'Item 3' },
|
||||
];
|
||||
const pool = new Pool({
|
||||
user: 'postgres',
|
||||
host: 'localhost',
|
||||
database: 'Blink',
|
||||
password: 'postgres',
|
||||
port: 5432,
|
||||
max: 10,
|
||||
idleTimeoutMillis: 30000,
|
||||
});
|
||||
|
||||
// Define a route to get all items
|
||||
app.get('/api/items', (req, res) => {
|
||||
@@ -32,25 +33,21 @@ app.post('/api/register', (req, res) => {
|
||||
const userData = req.body;
|
||||
|
||||
// Ensure that the required fields are present before proceeding
|
||||
if (!userData.display_name || !userData.email) {
|
||||
if (!userData.display_name || !userData.email || !userData.password) {
|
||||
return res.status(400).json("Invalid request");
|
||||
}
|
||||
|
||||
// Create a PostgreSQL client
|
||||
const client = new Client({
|
||||
user: 'postgres',
|
||||
host: 'localhost',
|
||||
database: 'Blink',
|
||||
password: 'postgres',
|
||||
port: 5432, // Default PostgreSQL port
|
||||
});
|
||||
|
||||
client.connect()
|
||||
.then(() => {
|
||||
bcrypt.hash(userData.password, 10, (err, hashedPassword) => {
|
||||
if (err) {
|
||||
console.error('Error hashing password:', err);
|
||||
} else {
|
||||
// Acquire a connection from the pool
|
||||
pool.connect()
|
||||
.then((client) => {
|
||||
// SQL query with placeholders for parameters
|
||||
const insertQuery = `
|
||||
INSERT INTO "User" (display_name, date_of_birth, place_of_living, is_looking_for_job, email)
|
||||
VALUES ($1, $2, $3, $4, $5)
|
||||
INSERT INTO "User" (display_name, date_of_birth, place_of_living, is_looking_for_job, email, password)
|
||||
VALUES ($1, $2, $3, $4, $5, $6)
|
||||
RETURNING *`; // Return the inserted row
|
||||
|
||||
return client.query(insertQuery, [
|
||||
@@ -58,9 +55,9 @@ app.post('/api/register', (req, res) => {
|
||||
userData.date_of_birth,
|
||||
userData.place_of_living,
|
||||
userData.is_looking_for_job,
|
||||
userData.email
|
||||
]);
|
||||
})
|
||||
userData.email,
|
||||
hashedPassword
|
||||
])
|
||||
.then((result) => {
|
||||
// Respond with the inserted user data
|
||||
res.status(200).json(result.rows[0]);
|
||||
@@ -70,8 +67,15 @@ app.post('/api/register', (req, res) => {
|
||||
res.status(500).json("Internal server error");
|
||||
})
|
||||
.finally(() => {
|
||||
// Close the database connection
|
||||
client.end();
|
||||
// Release the connection back to the pool
|
||||
client.release();
|
||||
});
|
||||
})
|
||||
.catch((error) => {
|
||||
console.error('Error acquiring a connection from the pool:', error);
|
||||
res.status(500).json("Internal server error");
|
||||
});
|
||||
}
|
||||
});
|
||||
});
|
||||
|
||||
|
Reference in New Issue
Block a user