shoppingmallv2/app/Controllers/Front/Order/Payment/CardController.php
2023-08-16 13:30:11 +09:00

117 lines
4.1 KiB
PHP

<?php
namespace App\Controllers\Front\Order\Payment;
use App\Libraries\Adapter\Payment\CookiePayment as PaymentAdapter;
use CodeIgniter\HTTP\RequestInterface;
use CodeIgniter\HTTP\ResponseInterface;
use Psr\Log\LoggerInterface;
class CardController extends PaymentController
{
public function initController(RequestInterface $request, ResponseInterface $response, LoggerInterface $logger)
{
parent::initController($request, $response, $logger);
$this->_viewDatas['className'] = 'Card';
$this->_viewPath .= '/' . strtolower($this->_viewDatas['className']);
$this->_viewDatas['title'] = lang($this->_viewDatas['className'] . '.title');
$this->_viewDatas['class_icon'] = CLASS_ICONS[strtoupper($this->_viewDatas['className'])];
helper($this->_viewDatas['className']);
}
public function getFields(string $action = ""): array
{
switch ($action) {
case 'update':
return ["card_quota", "card_number", "card_expiration", "email", "mobile"];
break;
default:
return [];
break;
}
}
protected function getFieldRule(string $field, array $rules, string $action = ""): array
{
switch ($field) {
case "order_uid":
$rules[$field] = 'required|regex_match[/^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}/]';
break;
case "card_quota":
$rules[$field] = 'required|in_list[00,01]';
break;
case "card_number":
$rules[$field] = 'required|regex_match[/^[0-9]{4}-[0-9]{4}-[0-9]{4}-[0-9]{4}/]';
break;
case "card_expiration":
$rules[$field] = 'required|regex_match[/^[1-12]{2}-[0-9]{4}/]';
break;
case "email":
$rules[$field] = 'required|valid_email';
break;
case "mobile":
$rules[$field] = 'required|regex_match[/^[0-9]{3}-[0-9]{4}-[0-9]{4}/]';
break;
default:
$rules = parent::getFieldRule($field, $rules, $action);
break;
}
return $rules;
}
public function getFieldFilters(): array
{
return ['card_quota'];
}
public function getFieldBatchFilters(): array
{
return parent::getFieldBatchFilters();
}
//Field별 Form Option용
public function getFieldFormOption(string $field): array
{
switch ($field) {
case 'card_quota':
$options = lang($this->_viewDatas['className'] . '.CARD_QUOTA');
break;
default:
$options = parent::getFieldFormOption($field);
break;
}
if (!is_array($options)) {
throw new \Exception(__FUNCTION__ . "에서 {$this->_viewDatas['className']}의 Field:{$field}의 FormOptionData가 array가 아닙니다.\n" . var_export($options, true));
}
return $options;
}
//카드결제처리
private function pg_process(): string
{
//PG사 결제후 정보저장
$adapter = new PaymentAdapter();
$adapter->setDatas($this->_viewDatas['fieldDatas']);
$result = $adapter->execute();
$response = "";
foreach ($result as $key => $value) {
$response .= "{$key}:{$value}\n";
}
return $response;
}
protected function update_process($entity)
{
//결제처리
$this->_viewDatas['fieldDatas'] = array("status" => $this->_viewDatas['className']);
$entity = parent::update_process($entity);
//카드결제
$response = $this->pg_process();
//청구서 발행정보
$subject = sprintf("%s %s 청구서입니다.", $entity->getTitle(), date("Y년 m월"));
$html = view(
$this->_viewPath . 'billing',
['viewDatas' => $this->_viewDatas['fieldDatas']]
);
//청구서 발행
$this->billing($entity, $subject, $html);
return $entity;
}
}