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 3.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. <?php
  2. namespace MirfalahTech\Laravel\Payment\Gateway\DummyPay;
  3. use Illuminate\Events\Dispatcher;
  4. use Illuminate\Http\Request;
  5. use Illuminate\Support\Facades\Response as Res;
  6. use MirfalahTech\Laravel\Payment\Contracts\PayableEntity;
  7. use MirfalahTech\Laravel\Payment\Contracts\PaymentGatewayDriver;
  8. use MirfalahTech\Laravel\Payment\Events\PaymentFailedEvent;
  9. use MirfalahTech\Laravel\Payment\Events\PaymentPendingEvent;
  10. use MirfalahTech\Laravel\Payment\Events\PaymentSuccessEvent;
  11. use MirfalahTech\Laravel\Payment\Events\ReturnVerifiedEvent;
  12. use MirfalahTech\Laravel\Payment\Facade\Payment;
  13. use MirfalahTech\Laravel\Payment\Traits\BillStatusBoolean;
  14. use Symfony\Component\HttpFoundation\Response;
  15. class DummyPayDriver implements PaymentGatewayDriver
  16. {
  17. use BillStatusBoolean;
  18. /**
  19. * @var string
  20. */
  21. protected $callback_url;
  22. /**
  23. * @var string
  24. */
  25. protected $return_url;
  26. /**
  27. * @var Dispatcher
  28. */
  29. protected $events;
  30. public function __construct(Dispatcher $events, string $callback_url, string $return_url){
  31. $this->callback_url = rtrim($callback_url, '/');
  32. $this->return_url = rtrim($return_url, '/');
  33. $this->events = $events;
  34. }
  35. public function createPaymentURL(PayableEntity $payable, array $options = []): string
  36. {
  37. $order_id = $payable->getBillId();
  38. return "$this->callback_url?".http_build_query(compact('order_id'));
  39. }
  40. public function verifyGatewayReturn(Request $request): bool
  41. {
  42. $this->events->dispatch(new ReturnVerifiedEvent('dummy', $this, $request));
  43. $this->dispatchStatusEvent($request);
  44. return true;
  45. }
  46. public function verifyGatewayCallback(Request $request, Response &$response = null): bool
  47. {
  48. $order_id = $request->query->get('order_id');
  49. if($request->query->has('status')){
  50. $response = Res::redirectTo($this->return_url.'?'.http_build_query(['order_id' => $order_id, 'status' => 'success']));
  51. return true;
  52. } else {
  53. /** @noinspection HtmlUnknownTarget */
  54. $html = sprintf(
  55. '<a href="%s">Click Here for Positive Response</a><br/><br/><a href="%s">Click Here for Negative Response</a>',
  56. $this->callback_url.'?'.http_build_query(['order_id' => $order_id, 'status' => 'success']),
  57. $this->callback_url.'?'.http_build_query(['order_id' => $order_id, 'status' => 'failed'])
  58. );
  59. $response = Res::make($html);
  60. return false;
  61. }
  62. }
  63. public function getBillIdFromRequest(Request $request): ?string{
  64. return $request->query->get('order_id');
  65. }
  66. public function getBillStatus(Request $request): ?int
  67. {
  68. return $request->query->get('status') == 'success' ?
  69. Payment::SUCCESS : Payment::FAILED;
  70. }
  71. protected function dispatchStatusEvent(Request $request)
  72. {
  73. switch ($this->getBillStatus($request)) {
  74. case Payment::SUCCESS:
  75. $this->events->dispatch(new PaymentSuccessEvent('dummy', $this, $request));
  76. break;
  77. case Payment::PENDING:
  78. $this->events->dispatch(new PaymentPendingEvent('dummy', $this, $request));
  79. break;
  80. case Payment::FAILED:
  81. $this->events->dispatch(new PaymentFailedEvent('dummy', $this, $request));
  82. break;
  83. }
  84. }
  85. }