online payments for card order
This commit is contained in:
@@ -59,6 +59,16 @@ class CardOrderModule implements ModuleContract
|
|||||||
name: 'Branch',
|
name: 'Branch',
|
||||||
message: 'This module is used for branches.',
|
message: 'This module is used for branches.',
|
||||||
),
|
),
|
||||||
|
new ModulePackage(
|
||||||
|
type: ModulePackageType::MODULE,
|
||||||
|
name: 'OrderStatus',
|
||||||
|
message: 'Supports orders.',
|
||||||
|
),
|
||||||
|
new ModulePackage(
|
||||||
|
type: ModulePackageType::MODULE,
|
||||||
|
name: 'OnlinePayment',
|
||||||
|
message: 'Is online payable.',
|
||||||
|
),
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -6,6 +6,7 @@ use App\Models\User;
|
|||||||
use App\Modules\Branch\Interfaces\BelongsToBranch;
|
use App\Modules\Branch\Interfaces\BelongsToBranch;
|
||||||
use App\Modules\Branch\Models\Branch;
|
use App\Modules\Branch\Models\Branch;
|
||||||
use App\Modules\LoanOrder\Repositories\LoanOrderRepository;
|
use App\Modules\LoanOrder\Repositories\LoanOrderRepository;
|
||||||
|
use App\Modules\OnlinePayment\Contracts\HasOnlinePayments;
|
||||||
use App\Modules\OrderStatus\Interfaces\HasStatus;
|
use App\Modules\OrderStatus\Interfaces\HasStatus;
|
||||||
use Illuminate\Database\Eloquent\Model;
|
use Illuminate\Database\Eloquent\Model;
|
||||||
use Illuminate\Database\Eloquent\Relations\BelongsTo;
|
use Illuminate\Database\Eloquent\Relations\BelongsTo;
|
||||||
|
|||||||
@@ -19,7 +19,7 @@ class CardOrderRepository
|
|||||||
/** @var \App\Modules\Branch\Models\Branch */
|
/** @var \App\Modules\Branch\Models\Branch */
|
||||||
$branch = $record->branch;
|
$branch = $record->branch;
|
||||||
|
|
||||||
return OnlinePaymentRepository::make()
|
return OnlinePaymentRepository::make(relatedModel: $record)
|
||||||
->paymentProvider(
|
->paymentProvider(
|
||||||
HalkbankOnlinePaymentRepository::make()
|
HalkbankOnlinePaymentRepository::make()
|
||||||
->setUsername($branch->billingUsername())
|
->setUsername($branch->billingUsername())
|
||||||
|
|||||||
@@ -64,7 +64,7 @@ class HalkbankOnlinePaymentRepository implements PaymentProviderContract
|
|||||||
return new Response(new GuzzleResponse(
|
return new Response(new GuzzleResponse(
|
||||||
503,
|
503,
|
||||||
['Content-Type' => 'application/json'],
|
['Content-Type' => 'application/json'],
|
||||||
sprintf('{"error":"Payment provider connection failed","exception_message":"%s"}', $e->getMessage())
|
sprintf('{"errorCode":"1","errorMessage":"%s"}', $e->getMessage())
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,8 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Modules\OnlinePayment\Contracts;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @property int $id
|
||||||
|
*/
|
||||||
|
interface HasOnlinePayments {}
|
||||||
@@ -7,4 +7,14 @@ use Illuminate\Http\Client\Response;
|
|||||||
interface PaymentProviderContract
|
interface PaymentProviderContract
|
||||||
{
|
{
|
||||||
public function sendRequest(): Response;
|
public function sendRequest(): Response;
|
||||||
|
|
||||||
|
public function orderNumber(): int|string;
|
||||||
|
|
||||||
|
public function amount(): int|float|string;
|
||||||
|
|
||||||
|
public function description(): string;
|
||||||
|
|
||||||
|
public function returnUrl(): string;
|
||||||
|
|
||||||
|
public function username(): string;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,10 +3,11 @@
|
|||||||
namespace App\Modules\OnlinePayment\Repositories;
|
namespace App\Modules\OnlinePayment\Repositories;
|
||||||
|
|
||||||
use App\Modules\AppHelpers\Contracts\HasOnlinePaymentStatusFields;
|
use App\Modules\AppHelpers\Contracts\HasOnlinePaymentStatusFields;
|
||||||
use App\Modules\CardOrder\Models\CardOrder;
|
|
||||||
use App\Modules\Makeable;
|
use App\Modules\Makeable;
|
||||||
|
use App\Modules\OnlinePayment\Contracts\HasOnlinePayments;
|
||||||
use App\Modules\OnlinePayment\Contracts\PaymentProviderContract;
|
use App\Modules\OnlinePayment\Contracts\PaymentProviderContract;
|
||||||
use App\Modules\OnlinePayment\Models\OnlinePayment;
|
use App\Modules\OnlinePayment\Models\OnlinePayment;
|
||||||
|
use Illuminate\Database\Eloquent\Model;
|
||||||
use Illuminate\Http\Client\Response;
|
use Illuminate\Http\Client\Response;
|
||||||
|
|
||||||
class OnlinePaymentRepository implements HasOnlinePaymentStatusFields
|
class OnlinePaymentRepository implements HasOnlinePaymentStatusFields
|
||||||
@@ -28,6 +29,11 @@ class OnlinePaymentRepository implements HasOnlinePaymentStatusFields
|
|||||||
*/
|
*/
|
||||||
public const PAID = 'paid';
|
public const PAID = 'paid';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Related model
|
||||||
|
*/
|
||||||
|
protected ?Model $relatedModel;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Payment provider
|
* Payment provider
|
||||||
*/
|
*/
|
||||||
@@ -48,11 +54,21 @@ class OnlinePaymentRepository implements HasOnlinePaymentStatusFields
|
|||||||
*/
|
*/
|
||||||
protected bool $failed;
|
protected bool $failed;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Payment order id
|
||||||
|
*/
|
||||||
|
protected string $orderId;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Online payment link
|
* Online payment link
|
||||||
*/
|
*/
|
||||||
protected string $paymentLink;
|
protected string $paymentLink;
|
||||||
|
|
||||||
|
public function __construct(?Model $relatedModel)
|
||||||
|
{
|
||||||
|
$this->relatedModel = $relatedModel;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Status Values
|
* Status Values
|
||||||
*
|
*
|
||||||
@@ -102,17 +118,35 @@ class OnlinePaymentRepository implements HasOnlinePaymentStatusFields
|
|||||||
return $this->failed;
|
return $this->failed;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set respond results
|
||||||
|
*/
|
||||||
|
public function setResponseResults(bool $result): void
|
||||||
|
{
|
||||||
|
$this->successful = $result;
|
||||||
|
$this->failed = ! $result;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Send request via provider
|
* Send request via provider
|
||||||
*/
|
*/
|
||||||
public function sendRequest(): self
|
public function sendRequest(): self
|
||||||
{
|
{
|
||||||
$response = $this->provider->sendRequest();
|
$this->response = $this->provider->sendRequest();
|
||||||
|
|
||||||
$this->failed = $response->failed();
|
$this->failed = $this->response->failed();
|
||||||
$this->successful = $response->successful();
|
$this->successful = $this->response->successful();
|
||||||
|
|
||||||
$this->response = $response;
|
if ($this->response['errorCode'] != 0) {
|
||||||
|
$this->setResponseResults(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($this->successful) {
|
||||||
|
$this->orderId = string($this->response['orderId']);
|
||||||
|
$this->paymentLink = string($this->response['formUrl']);
|
||||||
|
|
||||||
|
$this->createHistory();
|
||||||
|
}
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
@@ -125,33 +159,28 @@ class OnlinePaymentRepository implements HasOnlinePaymentStatusFields
|
|||||||
return $this->paymentLink;
|
return $this->paymentLink;
|
||||||
}
|
}
|
||||||
|
|
||||||
// public function payCardOrder()
|
/**
|
||||||
// {
|
* Create online payment history
|
||||||
// if ($paymentResponse->failed()) {
|
*/
|
||||||
// return [
|
public function createHistory(): void
|
||||||
// 'status' => 'failed',
|
{
|
||||||
// 'url' => '',
|
$data = [
|
||||||
// ];
|
'amount' => $this->provider->amount(),
|
||||||
// }
|
'orderNumber' => $this->provider->orderNumber(),
|
||||||
|
'description' => $this->provider->description(),
|
||||||
|
'orderId' => $this->orderId,
|
||||||
|
'formUrl' => $this->paymentLink,
|
||||||
|
'successUrl' => $this->provider->returnUrl(),
|
||||||
|
'errorUrl' => $this->provider->returnUrl(),
|
||||||
|
'username' => $this->provider->username(),
|
||||||
|
'paymentStatus' => self::PENDING,
|
||||||
|
];
|
||||||
|
|
||||||
// $onlinePaymentHistory = new OnlinePayment;
|
if ($this->relatedModel) {
|
||||||
// $onlinePaymentHistory->online_paymantable_id = $resource->really();
|
$data['online_paymantable_id'] = $this->relatedModel->id; // @phpstan-ignore-line
|
||||||
// $onlinePaymentHistory->online_paymantable_type = CardOrder::class;
|
$data['online_paymantable_type'] = $this->relatedModel::class;
|
||||||
// $onlinePaymentHistory->amount = $resource->priceAmount();
|
}
|
||||||
// $onlinePaymentHistory->orderNumber = $orderNumber;
|
|
||||||
// $onlinePaymentHistory->description = 'Kart tölegi';
|
|
||||||
// $onlinePaymentHistory->orderId = $paymentResponse['orderId'];
|
|
||||||
// $onlinePaymentHistory->formUrl = $paymentResponse['formUrl'];
|
|
||||||
// $onlinePaymentHistory->successUrl = route('online-payment-store');
|
|
||||||
// $onlinePaymentHistory->errorUrl = route('online-payment-store');
|
|
||||||
// $onlinePaymentHistory->api_client = 'billing_username';
|
|
||||||
// $onlinePaymentHistory->username = $resource->branch->billing_username;
|
|
||||||
// $onlinePaymentHistory->paymentStatus = self::PENDING;
|
|
||||||
// $onlinePaymentHistory->save();
|
|
||||||
|
|
||||||
// return [
|
OnlinePayment::create($data);
|
||||||
// 'status' => 'success',
|
}
|
||||||
// 'url' => $paymentResponse['formUrl'],
|
|
||||||
// ];
|
|
||||||
// }
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -54,6 +54,18 @@ function module_exists(string $moduleName): bool
|
|||||||
return modular()->moduleExists($moduleName);
|
return modular()->moduleExists($moduleName);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Cast to string
|
||||||
|
*/
|
||||||
|
function string(mixed $value): string
|
||||||
|
{
|
||||||
|
if (! is_string($value)) {
|
||||||
|
throw new Exception('!!!Make it string!!!');
|
||||||
|
}
|
||||||
|
|
||||||
|
return $value;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create an anonymous dynamic object with both properties and callable methods.
|
* Create an anonymous dynamic object with both properties and callable methods.
|
||||||
*
|
*
|
||||||
|
|||||||
Reference in New Issue
Block a user