Как отменить ежемесячный периодический платеж после того, как первые 30 дней были заполнены?
Я использую полосу для создания плана подписки, и все идет гладко, но я хотел бы создать кнопку отмены подписки, я просмотрел stackru для ответа, но я не могу найти какую-либо помощь, любые полезные ресурсы или код очень оценили!
premium.php:
<?php
require_once 'app/init.php';
include 'app/dbh.inc.php';
?>
<html>
<body>
<p>You're about to go premium.</p>
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Premium</title>
</head>
<body>
<form action="premium_charge.php" method="POST">
<script
src="https://checkout.stripe.com/checkout.js"
class="stripe-button"
data-key="<?php echo $stripe['publishable']; ?>"
data-name="Connect Kitty"
data-description="Catwalk"
data-email="<?php echo $user->email; ?>"
data-amount="599"
data-currency="usd">
</script>
</form>
</body>
</html>
premium_charge.php:
<?php
require_once 'app/init.php';
if(isset($_POST['stripeToken'])) {
$token = $_POST['stripeToken'];
try {
Stripe_Charge::create([
"amount" => 599,
"currency" => "usd",
"source" => $token,
"description" => $user->email
]);
$db->query("
UPDATE tbl_twitter_user SET premium = 1
WHERE user_id = {$user->user_id}
");
} catch(Stripe_CardError $e) {
}
header('Location: index1.php');
exit();
}
?>
init.php:
<?php
session_start();
require_once 'vendor/autoload.php';
$stripe = [
'publishable' => 'pk_test_QR1JpboiLh5acjEhK6vwclar00N1Y0Evjd',
'private' => 'sk_test_N62K1YeWqBN1WyEsWmK149Rh00It8OTxqg'
];
Stripe::setApiKey($stripe['private']);
$db = new PDO('mysql:host=127.0.0.1;dbname=am', 'nt', 'f9');
$userQuery = $db->prepare("
SELECT user_id, username, email, premium
FROM tbl_twitter_user
WHERE username = :username
");
$userQuery->execute(['username' => $_SESSION['username']]);
$user = $userQuery->fetchObject();
?>
Я включил весь код, потому что я не уверен, с каким файлом мне нужно будет работать.
И даже если кто-то обеспокоен SQL-инъекциями!
1 ответ
Когда вы создаете подписку, вы должны сохранить идентификатор подписки в вашей базе данных. Когда пользователь просит отменить подписку, получите его идентификатор подписки из базы данных и вызовите Stripe API:
$stmt = $db->prepare("SELECT subscription_id FROM tbl_twitter_user WHERE user_id = :userid");
$stmt->execute(['user_id' => $user->user_id]);
$row = $stmt->fetch(PDO::FETCH_OBJ);
$sub = \Stripe\Subscription::retrieve($row->subscription_id);
$sub->cancel();