store ufutx customer
This commit is contained in:
parent
9630a069f2
commit
f550a4a539
File diff suppressed because it is too large
Load Diff
@ -40,6 +40,7 @@ use App\Models\Server\Survey;
|
||||
use App\Models\UnionUser;
|
||||
use App\Server\ReportFile;
|
||||
use App\Services\LiveAlipayService;
|
||||
use App\Services\OrderService;
|
||||
use Illuminate\Foundation\Bus\DispatchesJobs;
|
||||
use Illuminate\Routing\Controller as BaseController;
|
||||
use Illuminate\Foundation\Validation\ValidatesRequests;
|
||||
@ -2166,17 +2167,10 @@ class Controller extends BaseController
|
||||
|
||||
public function test(Request $request)
|
||||
{
|
||||
// $access_token = "";
|
||||
// $app = \WechatService::officialApp()->access_token;
|
||||
// $token = $app->getToken(true);
|
||||
// $access_token = $token['access_token'];
|
||||
// if (empty($access_token)) {
|
||||
// return $this->failure("缺少access_token");
|
||||
// }
|
||||
// $url = "https://api.weixin.qq.com/cgi-bin/get_current_selfmenu_info?access_token=" . $access_token;
|
||||
|
||||
// $result = Http::get($url);
|
||||
// dd($result);
|
||||
$order = TouristOrder::find($request->order_id);
|
||||
$orderService = new OrderService();
|
||||
$res = $orderService->storeUftxCustomer($order);
|
||||
dd($res);
|
||||
}
|
||||
|
||||
public function postIndex()
|
||||
|
||||
File diff suppressed because it is too large
Load Diff
@ -61,6 +61,7 @@ use App\Models\TouristOrder;
|
||||
use App\Models\User;
|
||||
use App\Models\Wechat;
|
||||
use App\Services\IMService;
|
||||
use App\Services\OrderService;
|
||||
use App\Services\SaasVipService;
|
||||
use App\Services\TestService;
|
||||
use App\Utils\Http;
|
||||
@ -171,8 +172,7 @@ class TestController extends Controller
|
||||
}
|
||||
public function test($request)
|
||||
{
|
||||
$time = '2023-01-01 00:00';
|
||||
dd(date('Y-m-d', strtotime($time)));
|
||||
|
||||
}
|
||||
|
||||
public function merchantEarningExport(Request $request)
|
||||
|
||||
11
app/Models/Dma/DmaServiceUserRole.php
Normal file
11
app/Models/Dma/DmaServiceUserRole.php
Normal file
@ -0,0 +1,11 @@
|
||||
<?php
|
||||
|
||||
namespace App\Models\Dma;
|
||||
|
||||
use Illuminate\Database\Eloquent\Model;
|
||||
|
||||
class DmaServiceUserRole extends Model
|
||||
{
|
||||
protected $table = 'dma_service_user_role';
|
||||
protected $connection = 'dma';
|
||||
}
|
||||
14
app/Models/Dma/S2Customer.php
Normal file
14
app/Models/Dma/S2Customer.php
Normal file
@ -0,0 +1,14 @@
|
||||
<?php
|
||||
|
||||
namespace App\Models\Dma;
|
||||
|
||||
use Illuminate\Database\Eloquent\Model;
|
||||
|
||||
class S2Customer extends Model
|
||||
{
|
||||
protected $table = 's2_customer';
|
||||
protected $connection = 'dma';
|
||||
|
||||
public $fillable = [];
|
||||
public $guarded = [];
|
||||
}
|
||||
@ -3,6 +3,8 @@
|
||||
namespace App\Services;
|
||||
|
||||
use App\Contracts\OrderContract;
|
||||
use App\Models\Dma\DmaServiceUserRole;
|
||||
use App\Models\Dma\S2Customer;
|
||||
use App\Models\Order;
|
||||
use App\Models\PayOrder;
|
||||
use App\Models\RankHistory;
|
||||
@ -19,21 +21,22 @@ use App\Models\PaasAccount;
|
||||
use App\Models\Live\Asset;
|
||||
use App\Http\Response\ResponseJson;
|
||||
use App\Models\Live\AssetLog;
|
||||
use Log;
|
||||
use PhpParser\Node\Expr\Cast\Bool_;
|
||||
class OrderService implements OrderContract
|
||||
|
||||
{
|
||||
use ResponseJson;
|
||||
//充值会员
|
||||
public function officialMemberCharge($request, $rank_name, $rank_month, $discount_price, $score, $trade_type="h5")
|
||||
//充值会员
|
||||
public function officialMemberCharge($request, $rank_name, $rank_month, $discount_price, $score, $trade_type = "h5")
|
||||
{
|
||||
$user = auth()->user();
|
||||
//购买的会员等级
|
||||
$sub_rank_id = $request->input('sub_rank_id');
|
||||
$goods = '购买'.$rank_month.'个月'.$rank_name.'VIP';
|
||||
$goods = '购买' . $rank_month . '个月' . $rank_name . 'VIP';
|
||||
//订单号
|
||||
if ($trade_type == 'alipay') {
|
||||
$trade_no = \CommonUtilsService::getAliTradeNo();
|
||||
}else{
|
||||
} else {
|
||||
$trade_no = \CommonUtilsService::getTradeNO();
|
||||
}
|
||||
//如果购买的会员是市级会员
|
||||
@ -44,31 +47,31 @@ class OrderService implements OrderContract
|
||||
'user_id' => $user->id,
|
||||
'trade_no' => $trade_no,
|
||||
'pay_status' => 'PAID',
|
||||
'is_hooked' =>1,
|
||||
'is_hooked' => 1,
|
||||
'cash' => 0,
|
||||
'score' => 0,
|
||||
);
|
||||
$order = array(
|
||||
'user_id'=>$user->id,
|
||||
'type_id'=>$sub_rank_id,
|
||||
'goods'=>$goods,
|
||||
'price'=>0,
|
||||
'num'=>1,
|
||||
'type'=>'rank',
|
||||
'trade_no'=>$trade_no,
|
||||
'pay_status'=>'PAID',
|
||||
'user_id' => $user->id,
|
||||
'type_id' => $sub_rank_id,
|
||||
'goods' => $goods,
|
||||
'price' => 0,
|
||||
'num' => 1,
|
||||
'type' => 'rank',
|
||||
'trade_no' => $trade_no,
|
||||
'pay_status' => 'PAID',
|
||||
);
|
||||
$order_pay = PayOrder::create($pay_order);
|
||||
$order = Order::create($order);
|
||||
}else{
|
||||
} else {
|
||||
$order_pay = PayOrder::where('trade_no', $order->trade_no)->first();
|
||||
}
|
||||
$order_pay->wx_pay = [];
|
||||
$h = RankHistory::where('user_id', $user->id)->where('rank_id', 1)->first();
|
||||
if (empty($h)) {
|
||||
RankHistory::create([
|
||||
'user_id'=>$user->id,
|
||||
'rank_id'=>1,
|
||||
'user_id' => $user->id,
|
||||
'rank_id' => 1,
|
||||
]);
|
||||
}
|
||||
return $order_pay;
|
||||
@ -79,14 +82,14 @@ class OrderService implements OrderContract
|
||||
if ($score->remain_amount >= $discount_price) {
|
||||
$cash = 0;
|
||||
$score = $discount_price;
|
||||
}else{
|
||||
$discount_price = (int)number_format($discount_price, 2, '', '');
|
||||
$remain_amount = (int)number_format($score->remain_amount, 2, '', '');
|
||||
} else {
|
||||
$discount_price = (int) number_format($discount_price, 2, '', '');
|
||||
$remain_amount = (int) number_format($score->remain_amount, 2, '', '');
|
||||
$cash = ($discount_price - $remain_amount) / 100;
|
||||
$score = $score->remain_amount;
|
||||
$discount_price = $discount_price / 100;
|
||||
}
|
||||
}else{
|
||||
} else {
|
||||
$cash = $discount_price;
|
||||
$score = 0;
|
||||
}
|
||||
@ -104,34 +107,34 @@ class OrderService implements OrderContract
|
||||
'score' => $score,
|
||||
);
|
||||
$order = array(
|
||||
'user_id'=>$user->id,
|
||||
'type_id'=>$sub_rank_id,
|
||||
'goods'=>$goods,
|
||||
'price'=>$discount_price,
|
||||
'num'=>1,
|
||||
'type'=>'rank',
|
||||
'trade_no'=>$trade_no,
|
||||
'user_id' => $user->id,
|
||||
'type_id' => $sub_rank_id,
|
||||
'goods' => $goods,
|
||||
'price' => $discount_price,
|
||||
'num' => 1,
|
||||
'type' => 'rank',
|
||||
'trade_no' => $trade_no,
|
||||
);
|
||||
|
||||
//支付订单
|
||||
$order_pay = PayOrder::create($pay_order);
|
||||
$order = Order::create($order);
|
||||
$wx_pay = [];
|
||||
if ($cash>0) {
|
||||
if ($cash > 0) {
|
||||
if ($trade_type == 'h5') {//h5支付
|
||||
if (strstr($_SERVER['HTTP_USER_AGENT'], 'MicroMessenger')) {
|
||||
$wx_pay = \WechatService::constructWXPay($pay_order, $user->id, $goods);
|
||||
}else{
|
||||
} else {
|
||||
$wx_pay = \WechatService::constructWXH5Pay($pay_order, $user->id, $goods);
|
||||
}
|
||||
}elseif ($trade_type == 'wechat_app') {
|
||||
} elseif ($trade_type == 'wechat_app') {
|
||||
$wx_pay = \WechatService::constructWXAppPay($pay_order, $user->id, $goods);
|
||||
}elseif ($trade_type == 'alipay_app') {
|
||||
} elseif ($trade_type == 'alipay_app') {
|
||||
$subject = 'rank';
|
||||
$wx_pay = \AlipayService::purchase($subject, $trade_no, $cash);
|
||||
}
|
||||
|
||||
}else{
|
||||
} else {
|
||||
$order_pay->pay_status = 'PAID';
|
||||
$order_pay->is_hooked = 1;
|
||||
$order->pay_status = 'PAID';
|
||||
@ -157,9 +160,9 @@ class OrderService implements OrderContract
|
||||
$pay_order = PayOrder::where('trade_no', $order->trade_no)->first();
|
||||
if ($pay_order->score > 0) {
|
||||
//扣除对应积分
|
||||
$result = $this->changeScore($order->user_id, $pay_order->score, 'used', $message='升级VIP');
|
||||
$result = $this->changeScore($order->user_id, $pay_order->score, 'used', $message = '升级VIP');
|
||||
if (!$result) {
|
||||
\Log::debug($order->trade_no.'订单查询异常: 支付回调失败, 福分溢出');
|
||||
\Log::debug($order->trade_no . '订单查询异常: 支付回调失败, 福分溢出');
|
||||
// $this->sms->sentMessage('15872844805', '订单号:'.$order->trade_no.' 福分溢出');
|
||||
// return $this->failure('支付失败福分溢出');
|
||||
return false;
|
||||
@ -188,43 +191,43 @@ class OrderService implements OrderContract
|
||||
* @param inte $other_user_id 其他人ID
|
||||
* @return bool 是否成功
|
||||
*/
|
||||
public function changeScore($user_id, $score, $type, $message='', $other_user_id=null)
|
||||
public function changeScore($user_id, $score, $type, $message = '', $other_user_id = null)
|
||||
{
|
||||
$score_obj = Score::where('user_id', $user_id)->first();
|
||||
if (empty($score_obj)) {
|
||||
$score_obj = Score::create([
|
||||
'user_id'=>$user_id,
|
||||
]);
|
||||
}
|
||||
if ($type == 'gained') {
|
||||
//更新积分
|
||||
$score_obj = Score::where('user_id', $user_id)->first();
|
||||
if (empty($score_obj)) {
|
||||
$score_obj = Score::create([
|
||||
'user_id' => $user_id,
|
||||
]);
|
||||
}
|
||||
if ($type == 'gained') {
|
||||
//更新积分
|
||||
// $score_obj->increment('remain_amount', $score);
|
||||
}else{
|
||||
} else {
|
||||
if ($score_obj->remain_amount >= $score) {
|
||||
$score_obj->decrement('remain_amount', $score);
|
||||
}else{
|
||||
} else {
|
||||
// $score_obj->decrement('remain_amount', $score_obj->remain_amount);
|
||||
$this->sms->sentMessage('15872844805', '用户id:'.$user_id.', 福分超额.'.$message);
|
||||
$this->sms->sentMessage('15872844805', '用户id:' . $user_id . ', 福分超额.' . $message);
|
||||
return false;
|
||||
}
|
||||
$score_obj->increment('used_amount', $score);
|
||||
}
|
||||
//生成积分记录
|
||||
ScoreHistory::create([
|
||||
'user_id'=>$user_id,
|
||||
'other_user_id'=>$other_user_id,
|
||||
'type'=>$type,
|
||||
'amount'=>$score,
|
||||
'value'=>$score_obj->remain_amount,
|
||||
'message'=>$message,
|
||||
]);
|
||||
}
|
||||
//生成积分记录
|
||||
ScoreHistory::create([
|
||||
'user_id' => $user_id,
|
||||
'other_user_id' => $other_user_id,
|
||||
'type' => $type,
|
||||
'amount' => $score,
|
||||
'value' => $score_obj->remain_amount,
|
||||
'message' => $message,
|
||||
]);
|
||||
// $array['message'] = $message;
|
||||
// $array['user_id'] = $user_id;
|
||||
// $array['other_user_id'] = $other_user_id;
|
||||
// $array['type'] = $type;
|
||||
// $array['score'] = $score;
|
||||
// SyncScore::dispatch($array)->onQueue('love');
|
||||
return true;
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
@ -241,7 +244,7 @@ class OrderService implements OrderContract
|
||||
return;
|
||||
}
|
||||
|
||||
/**
|
||||
/**
|
||||
* 修改会员
|
||||
* @return [type] [description]
|
||||
*/
|
||||
@ -256,71 +259,71 @@ class OrderService implements OrderContract
|
||||
//购买月数
|
||||
$rank_month = $sub_rank->month;
|
||||
if ($user->rank_id === 0) {
|
||||
//创建对应会员
|
||||
//创建对应会员
|
||||
RankHistory::create([
|
||||
'user_id'=>$user_id,
|
||||
'rank_id'=>$sub_rank->rank_id,
|
||||
'deadline'=>date('Y-m-d H:i:s', strtotime('+'.$rank_month.' month')),
|
||||
'user_id' => $user_id,
|
||||
'rank_id' => $sub_rank->rank_id,
|
||||
'deadline' => date('Y-m-d H:i:s', strtotime('+' . $rank_month . ' month')),
|
||||
]);
|
||||
|
||||
$user->rank_id = $sub_rank->rank_id;
|
||||
$user->save();
|
||||
}elseif ($user->rank_id === 1) {//当前市级
|
||||
} elseif ($user->rank_id === 1) {//当前市级
|
||||
if ($rank_history && $rank_history->deadline) {//期限内
|
||||
//更新市级会员
|
||||
$rank_history->deadline = date('Y-m-d H:i:s', strtotime('+'.$rank_month.' month', strtotime($rank_history->deadline)));
|
||||
$rank_history->deadline = date('Y-m-d H:i:s', strtotime('+' . $rank_month . ' month', strtotime($rank_history->deadline)));
|
||||
$rank_history->save();
|
||||
}
|
||||
//创建对应会员
|
||||
RankHistory::create([
|
||||
'user_id'=>$user_id,
|
||||
'rank_id'=>$sub_rank->rank_id,
|
||||
'deadline'=>date('Y-m-d H:i:s', strtotime('+'.$rank_month.' month')),
|
||||
'user_id' => $user_id,
|
||||
'rank_id' => $sub_rank->rank_id,
|
||||
'deadline' => date('Y-m-d H:i:s', strtotime('+' . $rank_month . ' month')),
|
||||
]);
|
||||
|
||||
$user->rank_id = $sub_rank->rank_id;
|
||||
$user->save();
|
||||
|
||||
}elseif ($user->rank_id === 2) {//当前黄金
|
||||
} elseif ($user->rank_id === 2) {//当前黄金
|
||||
//市级会员记录
|
||||
$city_rank_history = RankHistory::where('user_id', $user_id)->where('rank_id', 1)->orderBy('id', 'desc')->first();
|
||||
if (!empty($city_rank_history) && !empty($city_rank_history->deadline)) {//市级会员在期限内
|
||||
//更新市级会员
|
||||
$city_rank_history->deadline = date('Y-m-d H:i:s', strtotime('+'.$rank_month.' month', strtotime($city_rank_history->deadline)));
|
||||
$city_rank_history->deadline = date('Y-m-d H:i:s', strtotime('+' . $rank_month . ' month', strtotime($city_rank_history->deadline)));
|
||||
$city_rank_history->save();
|
||||
|
||||
}
|
||||
|
||||
if ($sub_rank->rank_id === 2) {
|
||||
if (!empty($rank_history)) {
|
||||
//更新黄金会员
|
||||
$rank_history->deadline = date('Y-m-d H:i:s', strtotime('+'.$rank_month.' month', strtotime($rank_history->deadline)));
|
||||
//更新黄金会员
|
||||
$rank_history->deadline = date('Y-m-d H:i:s', strtotime('+' . $rank_month . ' month', strtotime($rank_history->deadline)));
|
||||
$rank_history->save();
|
||||
}else{
|
||||
} else {
|
||||
RankHistory::create([
|
||||
'user_id'=>$user_id,
|
||||
'rank_id'=>$sub_rank->rank_id,
|
||||
'deadline'=>date('Y-m-d H:i:s', strtotime('+'.$rank_month.' month')),
|
||||
'user_id' => $user_id,
|
||||
'rank_id' => $sub_rank->rank_id,
|
||||
'deadline' => date('Y-m-d H:i:s', strtotime('+' . $rank_month . ' month')),
|
||||
]);
|
||||
}
|
||||
}
|
||||
if ($sub_rank->rank_id === 3) {
|
||||
//创建对应会员
|
||||
RankHistory::create([
|
||||
'user_id'=>$user_id,
|
||||
'rank_id'=>$sub_rank->rank_id,
|
||||
'deadline'=>date('Y-m-d H:i:s', strtotime('+'.$rank_month.' month')),
|
||||
'user_id' => $user_id,
|
||||
'rank_id' => $sub_rank->rank_id,
|
||||
'deadline' => date('Y-m-d H:i:s', strtotime('+' . $rank_month . ' month')),
|
||||
]);
|
||||
$user->rank_id = $sub_rank->rank_id;
|
||||
$user->save();
|
||||
}
|
||||
|
||||
}elseif ($user->rank_id === 3) {//当前钻石
|
||||
} elseif ($user->rank_id === 3) {//当前钻石
|
||||
//市级会员记录
|
||||
$city_rank_history = RankHistory::where('user_id', $user_id)->where('rank_id', 1)->orderBy('id', 'desc')->first();
|
||||
if (!empty($city_rank_history) && !empty($city_rank_history->deadline)) {//市级会员在期限内
|
||||
//更新市级会员
|
||||
$city_rank_history->deadline = date('Y-m-d H:i:s', strtotime('+'.$rank_month.' month', strtotime($city_rank_history->deadline)));
|
||||
$city_rank_history->deadline = date('Y-m-d H:i:s', strtotime('+' . $rank_month . ' month', strtotime($city_rank_history->deadline)));
|
||||
$city_rank_history->save();
|
||||
|
||||
}
|
||||
@ -328,13 +331,13 @@ class OrderService implements OrderContract
|
||||
$gold_rank_history = RankHistory::where('user_id', $user_id)->where('rank_id', 2)->orderBy('id', 'desc')->first();
|
||||
if (!empty($gold_rank_history) && !empty($gold_rank_history->deadline)) {//黄金会员在期限内
|
||||
//更新市级会员
|
||||
$gold_rank_history->deadline = date('Y-m-d H:i:s', strtotime('+'.$rank_month.' month', strtotime($gold_rank_history->deadline)));
|
||||
$gold_rank_history->deadline = date('Y-m-d H:i:s', strtotime('+' . $rank_month . ' month', strtotime($gold_rank_history->deadline)));
|
||||
$gold_rank_history->save();
|
||||
}
|
||||
//更新钻石会员
|
||||
$rank_history->deadline = date('Y-m-d H:i:s', strtotime('+'.$rank_month.' month', strtotime($rank_history->deadline)));
|
||||
$rank_history->deadline = date('Y-m-d H:i:s', strtotime('+' . $rank_month . ' month', strtotime($rank_history->deadline)));
|
||||
$rank_history->save();
|
||||
}elseif ($user->rank_id === 9) {//当前超级会员
|
||||
} elseif ($user->rank_id === 9) {//当前超级会员
|
||||
// $history = RankHistory::where('user_id', $user_id)->where('rank_id', $sub_rank->rank_id)->where('deadline', ">", date('Y-m-d H:i:s'))->first();
|
||||
// if ($history) {
|
||||
// $history->deadline = date('Y-m-d H:i:s', strtotime('+'.$rank_month.' month', strtotime($history->deadline)));
|
||||
@ -360,31 +363,31 @@ class OrderService implements OrderContract
|
||||
//推荐人
|
||||
$user_id = Wechat::where('openid', $from_openid)->value('user_id');
|
||||
if (empty($user_id)) {
|
||||
return ;
|
||||
return;
|
||||
}
|
||||
//是否交认证费
|
||||
$approve_order = Order::where('user_id', $user_id)->where('type', 'approve')->where('pay_status', 'PAID')->first();
|
||||
if (empty($approve_order)) {
|
||||
return ;
|
||||
return;
|
||||
}
|
||||
$approve_pay_order = PayOrder::where('user_id', $user_id)->where('trade_no', $approve_order->trade_no)->where('is_hooked', 1)->first();
|
||||
if (empty($approve_pay_order)) {
|
||||
return ;
|
||||
return;
|
||||
}
|
||||
//是否已退
|
||||
$refund_order = RefundOrder::where('user_id', $user_id)->where('type','approve')->first();
|
||||
$refund_order = RefundOrder::where('user_id', $user_id)->where('type', 'approve')->first();
|
||||
//生成退款记录
|
||||
if (empty($refund_order)) {
|
||||
$refund_order = RefundOrder::create([
|
||||
'user_id'=>$user_id,
|
||||
'type'=>'approve',
|
||||
'trade_no'=>$approve_order->trade_no,
|
||||
'refund_trade_no'=>\CommonUtilsService::getRefundTradeNo(),
|
||||
'total_fee'=>$approve_pay_order->cash,
|
||||
'refund_fee'=>$approve_pay_order->cash,
|
||||
'user_id' => $user_id,
|
||||
'type' => 'approve',
|
||||
'trade_no' => $approve_order->trade_no,
|
||||
'refund_trade_no' => \CommonUtilsService::getRefundTradeNo(),
|
||||
'total_fee' => $approve_pay_order->cash,
|
||||
'refund_fee' => $approve_pay_order->cash,
|
||||
]);
|
||||
}else{
|
||||
return ;
|
||||
} else {
|
||||
return;
|
||||
}
|
||||
$total = $refund_order->total_fee * 100;
|
||||
$desc = '用户实名认证费退款';
|
||||
@ -400,15 +403,15 @@ class OrderService implements OrderContract
|
||||
{
|
||||
// $order = Order::where('user_id', $user_id)->where('type', 'approve')->where('pay_status','PAID')->first();
|
||||
// if (empty($order)) {
|
||||
// $order = Order::create([
|
||||
// 'user_id'=>$user_id,
|
||||
// 'type_id'=>0,
|
||||
// 'type'=>"approve",
|
||||
// 'goods'=>'赠送认证',
|
||||
// 'pay_status'=>'PAID',
|
||||
// 'price'=>10,
|
||||
// 'trade_no'=>'123',
|
||||
// ]);
|
||||
// $order = Order::create([
|
||||
// 'user_id'=>$user_id,
|
||||
// 'type_id'=>0,
|
||||
// 'type'=>"approve",
|
||||
// 'goods'=>'赠送认证',
|
||||
// 'pay_status'=>'PAID',
|
||||
// 'price'=>10,
|
||||
// 'trade_no'=>'123',
|
||||
// ]);
|
||||
// }
|
||||
|
||||
return;
|
||||
@ -417,7 +420,7 @@ class OrderService implements OrderContract
|
||||
/**
|
||||
* app支付生成订单
|
||||
*/
|
||||
public function makeAppOrder($request, $price, $type, $type_id=0, $goods, $linkmen=[], $detail='')
|
||||
public function makeAppOrder($request, $price, $type, $type_id = 0, $goods, $linkmen = [], $detail = '')
|
||||
{
|
||||
try {
|
||||
$user = auth()->user();
|
||||
@ -435,21 +438,21 @@ class OrderService implements OrderContract
|
||||
$score = 0;
|
||||
$cash = $price;
|
||||
$order = array(
|
||||
'user_id'=>auth()->id(),
|
||||
'type_id'=>$type_id,
|
||||
'goods'=>$goods,
|
||||
'price'=>$price,
|
||||
'num'=>1,
|
||||
'type'=>$type,
|
||||
'trade_no'=>$trade_no,
|
||||
'pay_type'=>$pay_type,
|
||||
'linkmen'=>json_encode($request->input('linkmen', [])),
|
||||
'user_id' => auth()->id(),
|
||||
'type_id' => $type_id,
|
||||
'goods' => $goods,
|
||||
'price' => $price,
|
||||
'num' => 1,
|
||||
'type' => $type,
|
||||
'trade_no' => $trade_no,
|
||||
'pay_type' => $pay_type,
|
||||
'linkmen' => json_encode($request->input('linkmen', [])),
|
||||
);
|
||||
if ($price == 0) {
|
||||
$order['pay_status'] = 'PAID';
|
||||
$score = 0;
|
||||
$cash = 0;
|
||||
}else{
|
||||
$order['pay_status'] = 'PAID';
|
||||
$score = 0;
|
||||
$cash = 0;
|
||||
} else {
|
||||
//计算支付金额
|
||||
if ($use_score) {
|
||||
//福气
|
||||
@ -457,12 +460,12 @@ class OrderService implements OrderContract
|
||||
$remain_score = 0;
|
||||
if (!empty($viewer_id)) {
|
||||
$asset = Asset::where('viewer_id', $viewer_id)->first();
|
||||
$remain_score = $asset?bcadd($asset->share_cash,$asset->cash,2):0;
|
||||
$remain_score = $asset ? bcadd($asset->share_cash, $asset->cash, 2) : 0;
|
||||
}
|
||||
if (bccomp($price, $remain_score) > 0) {
|
||||
$cash = bcsub($price, $remain_score, 2);
|
||||
$score = $remain_score;
|
||||
}else{
|
||||
} else {
|
||||
$cash = 0;
|
||||
$score = $price;
|
||||
}
|
||||
@ -470,15 +473,16 @@ class OrderService implements OrderContract
|
||||
}
|
||||
$receipt = request()->input('apple_receipt');
|
||||
$ios_version = $request->header('app-version', '1.0.0');
|
||||
// $result = \CommonUtilsService::contrastVersion($ios_version, '1.3.16');
|
||||
// $result = \CommonUtilsService::contrastVersion($ios_version, '1.3.16');
|
||||
|
||||
$result = $ios_version == '1.3.17'?true:false;
|
||||
if ($result && $pay_type == 'ios' and empty($receipt)) throw new \Exception("没有支付凭证", 1);
|
||||
$result = $ios_version == '1.3.17' ? true : false;
|
||||
if ($result && $pay_type == 'ios' and empty($receipt))
|
||||
throw new \Exception("没有支付凭证", 1);
|
||||
//生成支付订单
|
||||
$pay_order = array(
|
||||
'user_id' => auth()->id(),
|
||||
'trade_no' => $trade_no,
|
||||
'pay_status' => $price == 0?'PAID':'UNPAID',
|
||||
'pay_status' => $price == 0 ? 'PAID' : 'UNPAID',
|
||||
'cash' => $cash,
|
||||
'score' => $score,
|
||||
'pay_type' => $pay_type,
|
||||
@ -498,14 +502,14 @@ class OrderService implements OrderContract
|
||||
$order_pay = PayOrder::create($pay_order);
|
||||
//支付订单
|
||||
$order = Order::create($order);
|
||||
if ($cash>0) {
|
||||
if ($cash > 0) {
|
||||
if ($pay_type == 'wechat') {
|
||||
$ios_version = request()->header('app-version');
|
||||
$and_version = request()->header('version-name');
|
||||
$callback = config('app.url').'/api/app/callback/orders/'.$pay_order['trade_no'].'?ios_version='.$ios_version.'&and_version='.$and_version;
|
||||
$callback = config('app.url') . '/api/app/callback/orders/' . $pay_order['trade_no'] . '?ios_version=' . $ios_version . '&and_version=' . $and_version;
|
||||
$pay_config = \WechatService::constructWXAppPay($pay_order, auth()->id(), $detail, $callback);
|
||||
$order_pay->pay_config = $pay_config;
|
||||
}elseif ($pay_type == 'alipay') {
|
||||
} elseif ($pay_type == 'alipay') {
|
||||
$pay_config = \AlipayService::purchase($detail, $trade_no, $cash);
|
||||
$order_pay->pay_config = $pay_config;
|
||||
}
|
||||
@ -519,7 +523,7 @@ class OrderService implements OrderContract
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
/**
|
||||
* 修改福气
|
||||
* @param Request $request [description]
|
||||
* @return [type] [description]
|
||||
@ -531,20 +535,20 @@ class OrderService implements OrderContract
|
||||
//福气
|
||||
$asset = $user->userAsset();
|
||||
if (!empty($asset)) {
|
||||
$remain_score = $asset?bcadd($asset->share_cash,$asset->cash,2):0;
|
||||
$remain_score = $asset ? bcadd($asset->share_cash, $asset->cash, 2) : 0;
|
||||
if ($remain_score < $score) {//总福气小于消耗福气
|
||||
\DB::rollback();
|
||||
throw new \Exception("福气溢出 用户id:".$user->id, 1);
|
||||
throw new \Exception("福气溢出 用户id:" . $user->id, 1);
|
||||
}
|
||||
//先扣除cash
|
||||
$cash = $asset->cash;
|
||||
$share_cash = $asset->share_cash;
|
||||
if ($cash >= $score) {
|
||||
$asset->decrement('cash', $score);
|
||||
}else{
|
||||
} else {
|
||||
$asset->decrement('cash', $cash);
|
||||
//再扣除share_cash
|
||||
$asset->decrement('share_cash', bcsub($score,$cash,2));
|
||||
$asset->decrement('share_cash', bcsub($score, $cash, 2));
|
||||
}
|
||||
//生成消费记录
|
||||
$log = new AssetLog;
|
||||
@ -553,11 +557,11 @@ class OrderService implements OrderContract
|
||||
$log->real_num = $score;
|
||||
$log->type = 6;
|
||||
$log->is_hooked = 1;
|
||||
$log->score = bcadd($asset->share_cash,$asset->cash,2);
|
||||
$log->score = bcadd($asset->share_cash, $asset->cash, 2);
|
||||
$log->save();
|
||||
}else{
|
||||
} else {
|
||||
\DB::rollback();
|
||||
throw new \Exception("未查询到福气账号 用户id:".$user->id, 1);
|
||||
throw new \Exception("未查询到福气账号 用户id:" . $user->id, 1);
|
||||
}
|
||||
\DB::commit();
|
||||
return true;
|
||||
@ -571,7 +575,8 @@ class OrderService implements OrderContract
|
||||
|
||||
|
||||
/**订单类型转换 代码转成中文*/
|
||||
public function orderTypeCodeSwitchChinese($type){
|
||||
public function orderTypeCodeSwitchChinese($type)
|
||||
{
|
||||
if ($type === 'score') {
|
||||
return '福分充值';
|
||||
} else if ($type === 'rank') {
|
||||
@ -600,10 +605,95 @@ class OrderService implements OrderContract
|
||||
return '赠送礼物';
|
||||
} else if ($type === 'course') {
|
||||
return '购买课程';
|
||||
}else{
|
||||
} else {
|
||||
return '其他';
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
public function storeUftxCustomer($order): bool
|
||||
{
|
||||
try {
|
||||
// 判断订单是否是uftx
|
||||
if ($order->merchant_id != 44) {
|
||||
Log::error("不是友福商户");
|
||||
return false;
|
||||
}
|
||||
|
||||
// 判断订单是否有分享人
|
||||
if (!$order->from_openid) {
|
||||
Log::error("没有from_openid");
|
||||
return false;
|
||||
}
|
||||
// 判断下单人和分享人是否一致
|
||||
if ($order->openid == $order->from_openid) {
|
||||
Log::error("分享人和下单人一致");
|
||||
return false;
|
||||
}
|
||||
|
||||
// 查询订单用户手机号和分享人用户手机号
|
||||
$wechat = Wechat::where("official_openid", $order->open_id)->first();
|
||||
if (empty($wechat)) {
|
||||
Log::error("没有下单人wechat");
|
||||
return false;
|
||||
}
|
||||
$from_wechat = Wechat::where("official_openid", $order->from_openid)->first();
|
||||
if (empty($from_wechat)) {
|
||||
Log::error("没有分享人wechat");
|
||||
return false;
|
||||
}
|
||||
$user = User::Where("id", $wechat->user_id)->first();
|
||||
if (empty($user)) {
|
||||
Log::error("没有下单人user");
|
||||
return false;
|
||||
}
|
||||
$from_user = User::Where("id", $from_wechat->user_id)->first();
|
||||
if (empty($from_user)) {
|
||||
Log::error("没有分享人user");
|
||||
return false;
|
||||
}
|
||||
$mobile = $user->mobile;
|
||||
if (empty($mobile)) {
|
||||
Log::error("没有下单人手机号");
|
||||
return false;
|
||||
}
|
||||
$from_mobile = $from_user->mobile;
|
||||
if (empty($from_mobile)) {
|
||||
Log::error("没有分享人手机号");
|
||||
return false;
|
||||
}
|
||||
|
||||
// 判断分享人是否在友福同享有服务端账号
|
||||
$serviceUser = DmaServiceUserRole::where("mobile", $from_mobile)->first();
|
||||
if (empty($serviceUser)) {
|
||||
Log::error("分享人不是商户端用户");
|
||||
return false;
|
||||
}
|
||||
|
||||
// 判断是否已经是客户
|
||||
$customer = S2Customer::where(["user_id" => $serviceUser->user_id, "contacts_mobile" => $mobile])->first();
|
||||
if ($customer) {
|
||||
Log::error("已成为客户");
|
||||
return false;
|
||||
}
|
||||
|
||||
// 创建客户
|
||||
S2Customer::create([
|
||||
"user_id" => $serviceUser->user_id,
|
||||
"customer_name" => "",
|
||||
"customer_type" => 101,
|
||||
"contacts_name" => $user->nickname,
|
||||
"contacts_mobile" => $mobile,
|
||||
"intention" => 1,
|
||||
"status" => 2
|
||||
]);
|
||||
Log::info("创建客户成功");
|
||||
return true;
|
||||
} catch (\Throwable $th) {
|
||||
$this->getError($th);
|
||||
return false;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@ -46,7 +46,7 @@ return [
|
||||
],
|
||||
'write' => [
|
||||
'host' => env('DB_HOST_WRITE', '127.0.0.1'),
|
||||
],*/
|
||||
],*/
|
||||
'host' => env('DB_HOST', '10.10.10.2'),
|
||||
'port' => env('DB_PORT', '3306'),
|
||||
'database' => env('DB_DATABASE', 'forge'),
|
||||
@ -60,6 +60,22 @@ return [
|
||||
'engine' => null,
|
||||
],
|
||||
|
||||
'dma' => [
|
||||
'driver' => 'mysql',
|
||||
'host' => env('DMA_DB_HOST', '192.168.6..10'),
|
||||
'port' => env('DMA_DB_PORT', '3306'),
|
||||
'database' => env('DMA_DB_DATABASE', 'health'),
|
||||
'username' => env('DMA_DB_USERNAME', 'root'),
|
||||
'password' => env('DMA_DB_PASSWORD', 'root'),
|
||||
'unix_socket' => env('DB_SOCKET', ''),
|
||||
'charset' => 'utf8mb4',
|
||||
'collation' => 'utf8mb4_unicode_ci',
|
||||
'prefix' => env('DB_PREFIX', ''),
|
||||
'strict' => false,
|
||||
'engine' => null,
|
||||
],
|
||||
|
||||
|
||||
'pgsql' => [
|
||||
'driver' => 'pgsql',
|
||||
'host' => env('DB_HOST', '127.0.0.1'),
|
||||
|
||||
Loading…
Reference in New Issue
Block a user