|
@@ -14,7 +14,8 @@ class XiyueController extends Controller
|
|
public function xiyuePayNotity(Request $request){
|
|
public function xiyuePayNotity(Request $request){
|
|
$openid = $request->post('openid');
|
|
$openid = $request->post('openid');
|
|
$sign = $request->post('sign');
|
|
$sign = $request->post('sign');
|
|
- $mySign = _sign(compact('openid'),'8T5MJy4FsJoZspq8');
|
|
|
|
|
|
+ $amount = $request->post('amount');
|
|
|
|
+ $mySign = _sign(compact('openid','amount'),'8T5MJy4FsJoZspq8');
|
|
if($sign != $mySign){
|
|
if($sign != $mySign){
|
|
return response()->error('PARAM_ERROR');
|
|
return response()->error('PARAM_ERROR');
|
|
}
|
|
}
|
|
@@ -35,6 +36,8 @@ class XiyueController extends Controller
|
|
'created_at'=>date('Y-m-d H:i:s'),
|
|
'created_at'=>date('Y-m-d H:i:s'),
|
|
'updated_at'=>date('Y-m-d H:i:s')
|
|
'updated_at'=>date('Y-m-d H:i:s')
|
|
]);
|
|
]);
|
|
|
|
+ }else{
|
|
|
|
+ $this->_xiyueConsume($openid,$amount);
|
|
}
|
|
}
|
|
YearOrderService::save_year_order([
|
|
YearOrderService::save_year_order([
|
|
'uid'=>$user->id,
|
|
'uid'=>$user->id,
|
|
@@ -57,6 +60,45 @@ class XiyueController extends Controller
|
|
return response()->success($user);
|
|
return response()->success($user);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ private function _xiyueConsume($openid,$amount){
|
|
|
|
+ $user = UserService::getUserByOpenidAndChannelId($openid,6985);
|
|
|
|
+ if(!$user) return false;
|
|
|
|
+ if($amount <= 0){
|
|
|
|
+ return false;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if($amount > $user->balance || $amount > $user->charge_balance){
|
|
|
|
+ return false;
|
|
|
|
+ }
|
|
|
|
+ $data = [];
|
|
|
|
+ $data['uid'] = $user->id;
|
|
|
|
+ $data['type'] = 'xiyueconsume';
|
|
|
|
+ $data['attach'] = '';
|
|
|
|
+ $data['created_at'] = date('Y-m-d H:i:s');
|
|
|
|
+ $data['updated_at'] = date('Y-m-d H:i:s');
|
|
|
|
+ $data['balance'] = $amount;
|
|
|
|
+ if ($user->charge_balance >= $amount) {
|
|
|
|
+ $data['charge_balance'] = $amount;
|
|
|
|
+ $data['reward_balance'] = 0;
|
|
|
|
+ $user->balance -= $amount;
|
|
|
|
+ $user->charge_balance -= $amount;
|
|
|
|
+ } elseif ($user->charge_balance > 0) {
|
|
|
|
+ $data['charge_balance'] = $user->charge_balance;
|
|
|
|
+ $data['reward_balance'] = $amount - $user->charge_balance;
|
|
|
|
+ $reward = $amount - $user->charge_balance;
|
|
|
|
+ $user->balance -= $amount;
|
|
|
|
+ $user->charge_balance = 0;
|
|
|
|
+ $user->reward_balance -= $reward;
|
|
|
|
+ } else {
|
|
|
|
+ $data['charge_balance'] = 0;
|
|
|
|
+ $data['reward_balance'] = $amount;
|
|
|
|
+ $user->balance -= $amount;
|
|
|
|
+ $user->reward_balance -= $amount;
|
|
|
|
+ }
|
|
|
|
+ $user->save();
|
|
|
|
+ DB::table('user_other_consume_record')->insert($data);
|
|
|
|
+ return true;
|
|
|
|
+ }
|
|
public function xiyueConsume(Request $request){
|
|
public function xiyueConsume(Request $request){
|
|
$openid = $request->post('openid');
|
|
$openid = $request->post('openid');
|
|
$sign = $request->post('sign');
|
|
$sign = $request->post('sign');
|