Uber_Clone/server.js

169 lines
4.9 KiB
JavaScript

require("dotenv").config();
const http = require("http");
const { neon } = require("@neondatabase/serverless");
const sql = neon(process.env.DATABASE_URL);
const requestHandler = async (req, res) => {
if (req.method === "GET" && req.url === "/api/users") {
res.writeHead(200, { "Content-Type": "application/json" });
res.end(JSON.stringify({ message: "GET is working" }));
return;
}
if (req.method === "GET" && req.url === "/api/ride/create") {
res.writeHead(200, { "Content-Type": "application/json" });
res.end(JSON.stringify({ message: "GET is working" }));
return;
}
if (req.method === "GET" && req.url === "/api/driver") {
try {
const drivers = await sql`SELECT * FROM drivers`; // Adjust table name
res.writeHead(200, { "Content-Type": "application/json" });
res.end(JSON.stringify({ data: drivers }));
} catch (err) {
console.error("❌ Error fetching drivers:", err);
res.writeHead(500, { "Content-Type": "application/json" });
res.end(JSON.stringify({ error: "Error fetching drivers" }));
}
return;
}
if (req.method === "POST" && req.url === "/api/users") {
let body = "";
req.on("data", (chunk) => {
body += chunk.toString();
});
req.on("end", async () => {
try {
const { name, email, clerkId } = JSON.parse(body);
if (!name || !email || !clerkId) {
res.writeHead(400, { "Content-Type": "application/json" });
res.end(JSON.stringify({ error: "Missing required fields" }));
return;
}
// Check if user already exists
const existing = await sql`
SELECT * FROM users WHERE clerk_id = ${clerkId}
`;
if (existing.length > 0) {
res.writeHead(200, { "Content-Type": "application/json" });
res.end(JSON.stringify(existing[0]));
return;
}
// Insert new user
const result = await sql`
INSERT INTO users (name, email, clerk_id)
VALUES (${name}, ${email}, ${clerkId})
RETURNING *;
`;
res.writeHead(201, { "Content-Type": "application/json" });
res.end(JSON.stringify(result[0]));
} catch (err) {
console.error("❌ Database Error:", err);
res.writeHead(500, { "Content-Type": "application/json" });
res.end(JSON.stringify({ error: "Database error" }));
}
});
return;
}
if (req.method === "POST" && req.url === "/api/ride/rides") {
let body = "";
req.on("data", (chunk) => {
body += chunk.toString();
});
req.on("end", async () => {
try {
const {
origin_address,
destination_address,
origin_latitude,
origin_longitude,
destination_latitude,
destination_longitude,
ride_time,
fare_price,
payment_status,
driver_id,
user_id,
} = JSON.parse(body);
if (
!origin_address ||
!destination_address ||
!origin_latitude ||
!origin_longitude ||
!destination_latitude ||
!destination_longitude ||
!ride_time ||
!fare_price ||
!payment_status ||
!driver_id ||
!user_id
) {
res.writeHead(400, { "Content-Type": "application/json" });
res.end(JSON.stringify({ error: "Missing required fields" }));
return;
}
const sql = neon(`${process.env.DATABASE_URL}`);
const response = await sql`
INSERT INTO rides (
origin_address,
destination_address,
origin_latitude,
origin_longitude,
destination_latitude,
destination_longitude,
ride_time,
fare_price,
payment_status,
driver_id,
user_id
) VALUES (
${origin_address},
${destination_address},
${origin_latitude},
${origin_longitude},
${destination_latitude},
${destination_longitude},
${ride_time},
${fare_price},
${payment_status},
${driver_id},
${user_id}
)
RETURNING *;
`;
res.writeHead(201, { "Content-Type": "application/json" });
res.end(JSON.stringify({ data: response[0] }));
} catch (error) {
console.error("Error inserting data into recent_rides:", error);
res.writeHead(500, { "Content-Type": "application/json" });
res.end(JSON.stringify({ error: "Internal Server Error" }));
}
});
return;
}
// Fallback for unrecognized routes
res.writeHead(404, { "Content-Type": "text/plain" });
res.end("Not Found");
};
http.createServer(requestHandler).listen(3000, "0.0.0.0", () => {
console.log("✅ Server running at http://0.0.0.0:3000");
});