-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtransact_initialize.php
79 lines (68 loc) · 2.27 KB
/
transact_initialize.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
<?php
require __DIR__ . '/vendor/autoload.php';
$dotenv = Dotenv\Dotenv::createImmutable(__DIR__);
$dotenv->load();
include 'session.php';
// // Check if user is signed in
// if (!isset($_POST['id'])) {
// $_SESSION['error'] = 'Signin First !!!';
// header("Location: Signin");
// exit();
// }
// Check if a product ID is provided in the URL
// if (isset($_GET['id'])) {
// $id = $_GET['id'];
// $stmt = $conn->prepare("SELECT * FROM producttb WHERE id = :id");
// $stmt->execute(['id' => $_GET['id']]);
// $row = $stmt->fetch(PDO::FETCH_ASSOC);
// if (!$row) {
// $_SESSION['error'] = "No file found.";
// header("location:description_pro.php?id=" . $id);
// exit();
// }
// } else {
// $_SESSION['error'] = "No file specified.";
// header("location:description_pro.php?id=" . $id);
// exit();
// }
// Initialize Paystack transaction
$email = $_POST['email'];
$first_name = $_POST['firstname'] ;
$last_name=$_POST['lastname'];
$phone = $_POST['phone'];
$amount = $_POST['amount'] * 100; // Convert to kobo
$callback_url = "http://localhost/Online/fm-selection-2025585_07-30-15\public_html/transact_verify.php"; // Replace with your callback URL
// $callback_url = "https://unibooks.com.ng/transact_verify_pro.php"; // Replace with your callback URL
$curl = curl_init();
curl_setopt_array($curl, [
CURLOPT_URL => "https://api.paystack.co/transaction/initialize",
CURLOPT_RETURNTRANSFER => true,
CURLOPT_CUSTOMREQUEST => "POST",
CURLOPT_POSTFIELDS => json_encode([
'amount' => $amount,
'last_name' => $last_name,
'first_name' => $first_name,
'phone' => $phone,
'email' => $email,
'callback_url' => $callback_url
]),
CURLOPT_HTTPHEADER => [
"authorization: Bearer " . $_ENV['PAYSTACK_SECRET_KEY'],
"content-type: application/json",
"cache-control: no-cache"
],
]);
$response = curl_exec($curl);
$err = curl_error($curl);
if ($err) {
die('Curl returned error: ' . $err);
}
$tranx = json_decode($response, true);
if (!$tranx['status']) {
die('API returned error: ' . $tranx['message']);
}
// Store transaction reference so we can verify in `verify_payment.php`
$_SESSION['transaction_reference'] = $tranx['data']['reference'];
// Redirect to Paystack payment page
header('Location: ' . $tranx['data']['authorization_url']);
exit();