Как отменить ежемесячный периодический платеж после того, как первые 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();
Другие вопросы по тегам