Laravel payment dummy driver, a dummy payment gateway for development.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

DummyPayDriver.php 2.3KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. <?php
  2. namespace MirfalahTech\Laravel\Payment\Gateway\DummyPay;
  3. use Illuminate\Http\Request;
  4. use Illuminate\Support\Facades\Response as Res;
  5. use MirfalahTech\Laravel\Payment\Contracts\PayableEntity;
  6. use MirfalahTech\Laravel\Payment\Contracts\PaymentGatewayDriver;
  7. use MirfalahTech\Laravel\Payment\Facade\Payment;
  8. use MirfalahTech\Laravel\Payment\Traits\BillStatusBoolean;
  9. use Symfony\Component\HttpFoundation\Response;
  10. class DummyPayDriver implements PaymentGatewayDriver
  11. {
  12. use BillStatusBoolean;
  13. /**
  14. * @var string
  15. */
  16. protected $callback_url;
  17. /**
  18. * @var string
  19. */
  20. protected $return_url;
  21. public function __construct(string $callback_url, string $return_url){
  22. $this->callback_url = rtrim($callback_url, '/');
  23. $this->return_url = rtrim($return_url, '/');
  24. }
  25. public function createPaymentURL(PayableEntity $payable, array $options = []): string
  26. {
  27. $order_id = $payable->getBillId();
  28. return "$this->callback_url?".http_build_query(compact('order_id'));
  29. }
  30. public function verifyGatewayReturn(Request $request): bool
  31. {
  32. return true;
  33. }
  34. public function verifyGatewayCallback(Request $request, Response &$response = null): bool
  35. {
  36. $order_id = $request->query->get('order_id');
  37. if($request->query->has('status')){
  38. $response = Res::redirectTo($this->return_url.'?'.http_build_query(['order_id' => $order_id, 'status' => 'success']));
  39. return true;
  40. } else {
  41. /** @noinspection HtmlUnknownTarget */
  42. $html = sprintf(
  43. '<a href="%s">Click Here for Positive Response</a><br/><br/><a href="%s">Click Here for Negative Response</a>',
  44. $this->callback_url.'?'.http_build_query(['order_id' => $order_id, 'status' => 'success']),
  45. $this->callback_url.'?'.http_build_query(['order_id' => $order_id, 'status' => 'failed'])
  46. );
  47. $response = Res::make($html);
  48. return false;
  49. }
  50. }
  51. public function getBillIdFromRequest(Request $request): ?string{
  52. return $request->query->get('order_id');
  53. }
  54. public function getBillStatus(Request $request): ?int
  55. {
  56. return $request->query->get('status') == 'success' ?
  57. Payment::SUCCESS : Payment::FAILED;
  58. }
  59. }