Files
EMI-Backend/routes/payments.js
2025-07-17 09:32:49 -04:00

128 lines
3.8 KiB
JavaScript

var express = require('express');
var router = express.Router();
const DB = require("../mongoDB.js");
const mongo = require('mongodb');
//const Payments = require("../payments.js");
const Stripe = require('stripe');
const stripe = Stripe(process.env.STRIPE);
DB.getDB.then((DB) => {
const getUserId = function (req) {
const user_sid = req.cookies.user_sid || req.query.user_sid || req.body.user_sid;
return DB.ObjectID(user_sid);
}
const getProfileId = (req) => {
return DB.ObjectID(req.cookies.profile_id || req.query.profile_id || req.body.profile_id);
}
// router.get("/", async (req, res) => {
// //let profiles = await DB.getUserProfiles(userid);
// //Payments.getCustomerCard()
// return res.json({
// status: "ok",
// });
// });
// router.post("/card", async (req, res) => {
// //get user stripe customer
// //Payments.getCustomerByID
// //if not customer register, make one
// //Payments.addNewCustomer()
// //add card to customer
// const cardInfo = req.body.cardInfo;
// //Payments.addNewCustomerCard()
// return res.json({
// status: "ok",
// });
// });
let intent = async (req, res) => {
const userid = req.body.userid;
const price = req.body.price || 500;
const description = req.body.description;
// Create a PaymentIntent with the order amount and currency
const paymentIntent = await stripe.paymentIntents.create({
amount: price,
currency: "usd",
payment_method_types: [
"card",
],
});
// check if user is email or userid
const isUserId = mongo.ObjectId.isValid(userid);
const emailRegex = /^[^\s@]+@[^\s@]+\.[^\s@]+$/;
const isEmail = emailRegex.test(userid.trim().toLowerCase());
console.log("isUserId: ", isUserId);
console.log("isEmail: ", isEmail);
console.log("userid: ", userid);
if (isUserId) {
//Register in DB
const intent = {
paymentIntent,
userid,
price,
description,
client_secret: paymentIntent.client_secret,
};
DB.newIntent(intent);
return res.send({
clientSecret: paymentIntent.client_secret,
email: await DB.getUsernameByIdCache(userid),
price
});
}
if (isEmail) {
//Register in DB
return res.send({
clientSecret: paymentIntent.client_secret,
email: userid,
price
});
}
return res.send({
clientSecret: paymentIntent.client_secret,
email: 'guess',
price
});
};
router.post("/create-payment-intent", intent);
router.post("/intent", intent);
router.post("/register", async (req, res) => {
const userid = req.body.userid;
const result = req.body.result;
//Register in DB
const payment = {
result,
userid
};
//console.log(payment);
const intent = await DB.getIntent(result.client_secret);
if (intent.description === "Subscription 1 Month") {
//update profile subscription status
const profileid = getProfileId(req);
const isSubscriptor = await DB.isSubscriptor(profileid);
const updateR = await DB.updateProfileSubscription(profileid, !isSubscriptor);
console.log(updateR);
}
await DB.newResult(payment, result.client_secret);
return res.send({
status: 'ok'
});
});
});
module.exports = router