1.修复index.vue表格翻译错误
2.限制统一订单类型审核 3.统一订单手动推送报错PlayX 接口未配置
This commit is contained in:
@@ -166,7 +166,7 @@ class Order extends Backend
|
||||
if ($order->status !== MallOrder::STATUS_PENDING) {
|
||||
return $this->error(__('Order status must be PENDING'));
|
||||
}
|
||||
if ($order->type === MallOrder::TYPE_PHYSICAL) {
|
||||
if ($order->type !== MallOrder::TYPE_WITHDRAW) {
|
||||
return $this->error(__('Order type not supported'));
|
||||
}
|
||||
|
||||
@@ -214,6 +214,9 @@ class Order extends Backend
|
||||
if ($order->status !== MallOrder::STATUS_PENDING) {
|
||||
return $this->error(__('Order status must be PENDING'));
|
||||
}
|
||||
if (!in_array($order->type, [MallOrder::TYPE_PHYSICAL, MallOrder::TYPE_WITHDRAW], true)) {
|
||||
return $this->error(__('Order type not supported'));
|
||||
}
|
||||
|
||||
if ($order->type === MallOrder::TYPE_PHYSICAL && $rejectReason === '') {
|
||||
return $this->error(__('Missing required fields'));
|
||||
@@ -291,7 +294,7 @@ class Order extends Backend
|
||||
return $this->error(__('Current grant status cannot be manually pushed'));
|
||||
}
|
||||
|
||||
if (strval(config('playx.api.base_url', '')) === '') {
|
||||
if (strval(config('playx.angpow_import.base_url', '')) === '') {
|
||||
return $this->error(__('PlayX API not configured'));
|
||||
}
|
||||
|
||||
|
||||
@@ -6,6 +6,7 @@ namespace app\common\library;
|
||||
|
||||
use app\common\model\MallItem;
|
||||
use app\common\model\MallOrder;
|
||||
use app\common\model\MallUserAsset;
|
||||
use GuzzleHttp\Client;
|
||||
|
||||
/**
|
||||
@@ -18,60 +19,117 @@ final class MallBonusGrantPush
|
||||
*/
|
||||
public static function push(MallOrder $order): array
|
||||
{
|
||||
$baseUrl = rtrim(strval(config('playx.api.base_url', '')), '/');
|
||||
if ($baseUrl === '') {
|
||||
$conf = config('playx.angpow_import');
|
||||
if (!is_array($conf)) {
|
||||
return [
|
||||
'ok' => false,
|
||||
'message' => 'PlayX base_url not configured',
|
||||
'message' => 'PlayX angpow_import not configured',
|
||||
'playx_transaction_id' => '',
|
||||
];
|
||||
}
|
||||
|
||||
$baseUrl = rtrim(strval($conf['base_url'] ?? ''), '/');
|
||||
$path = strval($conf['path'] ?? '');
|
||||
$merchantCode = strval($conf['merchant_code'] ?? '');
|
||||
$authKey = strval($conf['auth_key'] ?? '');
|
||||
if ($baseUrl === '' || $path === '' || $merchantCode === '' || $authKey === '') {
|
||||
return [
|
||||
'ok' => false,
|
||||
'message' => 'PlayX Angpow Import API not configured',
|
||||
'playx_transaction_id' => '',
|
||||
];
|
||||
}
|
||||
|
||||
$path = strval(config('playx.api.bonus_grant_url', '/api/v1/bonus/grant'));
|
||||
$url = $baseUrl . $path;
|
||||
|
||||
$asset = MallUserAsset::where('playx_user_id', $order->user_id)->find();
|
||||
if (!$asset || !is_string($asset->playx_user_id ?? null) || strval($asset->playx_user_id) === '') {
|
||||
return [
|
||||
'ok' => false,
|
||||
'message' => 'User asset not found',
|
||||
'playx_transaction_id' => '',
|
||||
];
|
||||
}
|
||||
|
||||
$item = MallItem::where('id', $order->mall_item_id)->find();
|
||||
$rewardName = $item ? strval($item->title) : '';
|
||||
$category = $item ? strval($item->category) : 'daily';
|
||||
$categoryTitle = $item ? strval($item->category_title) : '';
|
||||
if (!$item) {
|
||||
return [
|
||||
'ok' => false,
|
||||
'message' => 'Item not found',
|
||||
'playx_transaction_id' => '',
|
||||
];
|
||||
}
|
||||
|
||||
$reportDate = strval(time());
|
||||
$signatureInput = 'merchant_code=' . $merchantCode . '&report_date=' . $reportDate;
|
||||
$signature = self::buildSignature($signatureInput, $authKey);
|
||||
if ($signature === null) {
|
||||
return [
|
||||
'ok' => false,
|
||||
'message' => 'Build signature failed',
|
||||
'playx_transaction_id' => '',
|
||||
];
|
||||
}
|
||||
|
||||
$start = gmdate('Y-m-d\TH:i:s\Z', strtotime(strval($order->start_time)));
|
||||
$end = gmdate('Y-m-d\TH:i:s\Z', strtotime(strval($order->end_time)));
|
||||
$multiplier = intval($order->multiplier ?? 0);
|
||||
if ($multiplier <= 0) {
|
||||
$multiplier = 1;
|
||||
}
|
||||
|
||||
$payload = [
|
||||
'merchant_code' => $merchantCode,
|
||||
'report_date' => $reportDate,
|
||||
'angpow' => [
|
||||
[
|
||||
'member_login' => strval($asset->playx_user_id),
|
||||
'start_time' => $start,
|
||||
'end_time' => $end,
|
||||
'amount' => $order->amount,
|
||||
'reward_name' => strval($item->title ?? ''),
|
||||
'description' => strval($item->description ?? ''),
|
||||
'member_inbox_message' => 'Congratulations! You received an angpow.',
|
||||
'category' => strval($item->category ?? ''),
|
||||
'category_title' => strval($item->category_title ?? ''),
|
||||
'one_time_turnover' => 'yes',
|
||||
'multiplier' => $multiplier,
|
||||
],
|
||||
],
|
||||
'currency_visual' => [
|
||||
[
|
||||
'currency' => strval($conf['currency'] ?? 'MYR'),
|
||||
'visual_name' => strval($conf['visual_name'] ?? 'Angpow'),
|
||||
],
|
||||
],
|
||||
];
|
||||
|
||||
$client = new Client([
|
||||
'timeout' => 20,
|
||||
'http_errors' => false,
|
||||
]);
|
||||
|
||||
$requestId = 'mall_bonus_' . uniqid();
|
||||
|
||||
try {
|
||||
$res = $client->post($url, [
|
||||
'json' => [
|
||||
'request_id' => $requestId,
|
||||
'externalTransactionId' => $order->external_transaction_id,
|
||||
'user_id' => $order->user_id,
|
||||
'amount' => $order->amount,
|
||||
'rewardName' => $rewardName,
|
||||
'category' => $category,
|
||||
'categoryTitle' => $categoryTitle,
|
||||
'multiplier' => $multiplier,
|
||||
'headers' => [
|
||||
'Content-Type' => 'application/json',
|
||||
'X-Request-Signature' => $signature,
|
||||
],
|
||||
'json' => $payload,
|
||||
]);
|
||||
|
||||
$data = json_decode(strval($res->getBody()), true) ?? [];
|
||||
if ($res->getStatusCode() === 200 && ($data['status'] ?? '') === 'accepted') {
|
||||
if (($data['code'] ?? null) === '0' || ($data['code'] ?? null) === 0) {
|
||||
return [
|
||||
'ok' => true,
|
||||
'message' => '',
|
||||
'playx_transaction_id' => strval($data['playx_transaction_id'] ?? ''),
|
||||
'playx_transaction_id' => '',
|
||||
];
|
||||
}
|
||||
|
||||
return [
|
||||
'ok' => false,
|
||||
'message' => strval($data['message'] ?? 'PlayX bonus grant not accepted'),
|
||||
'message' => strval($data['message'] ?? 'PlayX angpow import not accepted'),
|
||||
'playx_transaction_id' => '',
|
||||
];
|
||||
} catch (\Throwable $e) {
|
||||
@@ -82,4 +140,35 @@ final class MallBonusGrantPush
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
private static function buildSignature(string $input, string $authKey): ?string
|
||||
{
|
||||
$keyBytes = null;
|
||||
|
||||
$maybeBase64 = base64_decode($authKey, true);
|
||||
if ($maybeBase64 !== false && $maybeBase64 !== '') {
|
||||
$keyBytes = $maybeBase64;
|
||||
}
|
||||
|
||||
if ($keyBytes === null) {
|
||||
$isHex = ctype_xdigit($authKey) && (strlen($authKey) % 2 === 0);
|
||||
if ($isHex) {
|
||||
$hex = hex2bin($authKey);
|
||||
if ($hex !== false && $hex !== '') {
|
||||
$keyBytes = $hex;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if ($keyBytes === null) {
|
||||
$keyBytes = $authKey;
|
||||
}
|
||||
|
||||
$raw = hash_hmac('sha1', $input, $keyBytes, true);
|
||||
if (!is_string($raw) || $raw === '') {
|
||||
return null;
|
||||
}
|
||||
|
||||
return base64_encode($raw);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -247,8 +247,8 @@ class AngpowImportJobs
|
||||
// }
|
||||
// }
|
||||
|
||||
$start = gmdate('Y-m-d H:i:s', strtotime($order->start_time));
|
||||
$end = gmdate('Y-m-d H:i:s', strtotime($order->end_time));
|
||||
$start = gmdate('Y-m-d\TH:i:s\Z', strtotime($order->start_time));
|
||||
$end = gmdate('Y-m-d\TH:i:s\Z', strtotime($order->end_time));
|
||||
|
||||
return [
|
||||
'member_login' => strval($asset->playx_user_id),
|
||||
|
||||
Reference in New Issue
Block a user