-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsales.php
113 lines (94 loc) · 3.84 KB
/
sales.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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
<?php
require __DIR__ . '/vendor/autoload.php';
$dotenv = Dotenv\Dotenv::createImmutable(__DIR__);
$dotenv->load();
// session_start();
include_once 'session.php';
// Validate and sanitize input
$status = filter_input(INPUT_GET, 'status', FILTER_SANITIZE_SPECIAL_CHARS);
$transactionId = filter_input(INPUT_GET, 'transaction_id', FILTER_SANITIZE_SPECIAL_CHARS);
if (empty($status) || empty($transactionId) ) {
$_SESSION['error'] = 'Invalid transaction details.';
header("location: checkout#payment");
exit;
}
$curl = curl_init();
curl_setopt_array($curl, array(
CURLOPT_URL => "https://api.flutterwave.com/v3/transactions/{$transactionId}/verify",
CURLOPT_RETURNTRANSFER => true,
CURLOPT_ENCODING => "",
CURLOPT_MAXREDIRS => 10,
CURLOPT_TIMEOUT => 30,
CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
CURLOPT_CUSTOMREQUEST => "GET",
CURLOPT_HTTPHEADER => array(
"Authorization: Bearer " . $_ENV['FLUTTERWAVE_SECRET_KEY'],
"Content-Type: application/json"
),
));
$response = curl_exec($curl);
$err = curl_error($curl);
curl_close($curl);
if ($err) {
$_SESSION['error'] = 'Payment verification error: ' . $err;
header("location: checkout#payment");
exit;
} else {
$result = json_decode($response);
if ($result->status == 'success' && $result->data->status == 'successful') {
$status = $result->data->status;
$email = filter_var($result->data->customer->email, FILTER_SANITIZE_EMAIL);
$phone = filter_var($result->data->meta->phone, FILTER_SANITIZE_SPECIAL_CHARS);
$payid = filter_var($result->data->tx_ref, FILTER_SANITIZE_SPECIAL_CHARS);
$amount = filter_var($result->data->amount, FILTER_SANITIZE_NUMBER_FLOAT, FILTER_FLAG_ALLOW_FRACTION);
$address1 = filter_var($result->data->meta->address1, FILTER_SANITIZE_SPECIAL_CHARS);
$address2 = filter_var($result->data->meta->address2, FILTER_SANITIZE_SPECIAL_CHARS);
$id = filter_var($result->data->meta->id, FILTER_SANITIZE_NUMBER_INT);
date_default_timezone_set('Africa/Lagos');
$date = date("Y-m-d");
$coupon_id = isset($_SESSION['coupon']) ? $_SESSION['coupon']['id'] : 0;
$shipping_id = isset($_SESSION['shipping']['shipping_price']) ? $_SESSION['shipping']['shipping_id'] : 0;
try {
$conn = $pdo->open();
$stmt = $conn->prepare("INSERT INTO sales (user_id, tx_ref, status, shipping_id, coupon_id, address_1, address_2, phone, email, sales_date) VALUES (:user_id, :tx_ref, :status, :shipping_id, :coupon_id, :address_1, :address_2, :phone, :email, :sales_date)");
$stmt->execute([
'user_id' => $user['id'],
'tx_ref' => $payid,
'status' => $status,
'shipping_id' => $shipping_id,
'coupon_id' => $coupon_id,
'address_1' => $address1,
'address_2' => $address2,
'phone' => $phone,
'email' => $email,
'sales_date' => $date
]);
$salesid = $conn->lastInsertId();
$stmt = $conn->prepare("SELECT * FROM cart LEFT JOIN products ON products.id=cart.product_id WHERE user_id=:user_id");
$stmt->execute(['user_id' => $user['id']]);
foreach ($stmt as $row) {
$stmt = $conn->prepare("INSERT INTO details (sales_id, product_id, quantity) VALUES (:sales_id, :product_id, :quantity)");
$stmt->execute([
'sales_id' => $salesid,
'product_id' => $row['product_id'],
'quantity' => $row['quantity']
]);
$new_value = $row['qty'] - $row['quantity'];
$stmt = $conn->prepare("UPDATE products SET qty = :new_value WHERE id = :id");
$stmt->execute(['new_value' => $new_value, 'id' => $row['product_id']]);
}
$stmt = $conn->prepare("DELETE FROM cart WHERE user_id=:user_id");
$stmt->execute(['user_id' => $user['id']]);
$_SESSION['success'] = 'Transaction successful. Thank you.';
header("location: profile#trans");
exit;
} catch (PDOException $e) {
$_SESSION['error'] = $e->getMessage();
}
$pdo->close();
} else {
$_SESSION['error'] = 'Transaction failed.';
header("location: checkout#payment");
exit;
}
}