quickpos
Version:
<div align="center"> <h1>💳 QuickPos 🚀</h1> <p><strong>A powerful, multi-gateway payment integration module for Node.js</strong></p> <p>Seamlessly integrate with 50+ payment providers worldwide</p>
81 lines (70 loc) • 2.51 kB
JavaScript
const express = require('express');
const bodyParser = require('body-parser');
const QuickPos = require('./app');
const app = express();
app.use(bodyParser.urlencoded({ extended: true }));
app.use(bodyParser.json());
const quickPos = new QuickPos({
providers: {
toyyibpay: {
secretKey: 'your-secret-key',
categoryCode: 'your-category-code'
}
},
});
app.use(quickPos.middleware());
// Payment form
app.get('/', (req, res) => {
res.send(`
<h1>ToyyibPay Payment Example</h1>
<form action="/payment/toyyibpay" method="post">
<input type="text" name="amount" placeholder="Amount (MYR)" required>
<input type="email" name="email" placeholder="Email" required>
<input type="text" name="name" placeholder="Customer Name" required>
<input type="text" name="phone" placeholder="Phone (60XXXXXXXXX)" required>
<input type="text" name="orderId" placeholder="Order ID" required>
<input type="text" name="description" placeholder="Bill Description" required>
<button type="submit">Pay with ToyyibPay</button>
</form>
`);
});
// Create payment
app.post('/payment/:provider', async (req, res) => {
const { provider } = req.params;
if (!req.quickPos[provider]) {
return res.status(400).json({ error: 'Invalid payment provider' });
}
try {
const result = await req.quickPos[provider].createPayment({
billName: req.body.name || 'Bill Payment',
billDescription: req.body.description,
amount: req.body.amount,
email: req.body.email,
phone: req.body.phone,
customerName: req.body.name,
orderId: req.body.orderId,
callback_link: `http://localhost:3000/payment-callback/${provider}`
});
if (result.status === 'success') {
res.json({
success: true,
redirectUrl: result.data.url,
billCode: result.data.billCode
});
} else {
res.status(400).json(result);
}
} catch (error) {
res.status(500).json({ error: error.message });
}
});
// Payment callback
app.post('/payment-callback/:provider', quickPos.handleCallback('toyyibpay'), (req, res) => {
console.log('Payment result:', req.paymentResult);
res.json({ success: true, data: req.paymentResult });
});
const PORT = process.env.PORT || 3000;
app.listen(PORT, () => {
console.log(`Server is running on port ${PORT}`);
console.log(`Open http://localhost:${PORT} to test`);
});