Quellcode durchsuchen

聊天送礼物

lizhen_gitee vor 9 Monaten
Ursprung
Commit
8ac8cb3d64

+ 58 - 39
application/api/controller/Gift.php

@@ -75,12 +75,21 @@ class Gift extends Api
         //需要走计费的规则:男的 || 女的 需要收费的
         if ($this->auth->gender == 1 || ($this->auth->gender == 0 && $this->auth->is_cost == 1)) {
             // 判断当前用户余额
-            $user_gold = model('wallet')->getWallet($this->auth->id,'gold');
-            if($user_gold < $giftvalue)
-            {
-                $this->error("您的金币余额不足");
+            if($giftinfo['wallettype'] == 1){
+                $user_gold = model('wallet')->getWallet($this->auth->id,'gold');
+                if($user_gold < $giftvalue)
+                {
+                    $this->error("您的金币不足");
+                }
+            }else{
+                $user_jewel = model('wallet')->getWallet($this->auth->id,'jewel');
+                if($user_jewel < $giftvalue)
+                {
+                    $this->error("您的钻石不足");
+                }
             }
 
+
             // 添加礼物赠送记录表
             $data = [
                 'user_id' => $this->auth->id,
@@ -100,50 +109,60 @@ class Gift extends Api
             if($giftvalue > 0){
 
                 // 扣除当前用户余额
-                $wallet_rs = model('wallet')->lockChangeAccountRemain($this->auth->id,$user_id,'gold',-$giftvalue,53,'赠送礼物:'.$giftinfo["name"] . '*' . $number,'gift_user_typing',$log_id);
-                if($wallet_rs['status'] === false){
-                    Db::rollback();
-                    $this->error($wallet_rs['msg']);
-                }
+                if($giftinfo['wallettype'] == 1){
 
-                // 添加赠送用户余额
-                $money_to_gold = config('site.money_to_gold');
-                $gift_plat_scale = config('site.gift_plat_scale');
+    
+                    $wallet_rs = model('wallet')->lockChangeAccountRemain($this->auth->id,$user_id,'gold',-$giftvalue,53,'赠送礼物:'.$giftinfo["name"] . '*' . $number,'gift_user_typing',$log_id);
+                    if($wallet_rs['status'] === false){
+                        Db::rollback();
+                        $this->error($wallet_rs['msg']);
+                    }
 
-                $giftmoney = bcdiv($giftvalue,$money_to_gold,2);
+                    // 添加赠送用户余额
+                    $money_to_gold = config('site.money_to_gold');
+                    $gift_plat_scale = config('site.gift_plat_scale');
 
-                $money = bcdiv(bcmul($giftmoney,100 - $gift_plat_scale,2),100,2);
-                $wallet_rs = model('wallet')->lockChangeAccountRemain($user_id,$this->auth->id,'money',$money,54,'获得礼物:'.$giftinfo["name"] . '*' . $number,'gift_user_typing',$log_id,2);
-                if($wallet_rs['status'] === false){
-                    Db::rollback();
-                    $this->error($wallet_rs['msg']);
-                }
+                    $giftmoney = bcdiv($giftvalue,$money_to_gold,2);
 
-                //增加赠送用户上级余额
-                if ($touserinfo['intro_uid']) {
-                    //获取返利比率
-                    $is_agent = Db::name('user')->where(['id' => $touserinfo['intro_uid']])->value('is_agent');
-                    $intro_income_rebate_rate = $is_agent ? (int)config('site.h_intro_income_rebate_rate') : (int)config('site.intro_income_rebate_rate'); //邀请人收礼物返利比率
-                    if ($intro_income_rebate_rate > 0 && $intro_income_rebate_rate <= 100) {
-                        //上级获得金额
-                        $intro_uid_money = number_format($money * $intro_income_rebate_rate / 100, 2, '.', '');
-                        if ($intro_uid_money > 0) {
-                            $intro_result = model('Wallet')->lockChangeAccountRemain($touserinfo['intro_uid'],$user_id,'money',$intro_uid_money,68, '邀请人聊天礼物获赠奖励','gift_user_typing',$log_id);
-                            if($intro_result['status']===false)
-                            {
-                                Db::rollback();
-                                $this->error($intro_result['msg']);
+                    $money = bcdiv(bcmul($giftmoney,100 - $gift_plat_scale,2),100,2);
+                    $wallet_rs = model('wallet')->lockChangeAccountRemain($user_id,$this->auth->id,'money',$money,54,'获得礼物:'.$giftinfo["name"] . '*' . $number,'gift_user_typing',$log_id,2);
+                    if($wallet_rs['status'] === false){
+                        Db::rollback();
+                        $this->error($wallet_rs['msg']);
+                    }
+
+                    //增加赠送用户上级余额
+                    if ($touserinfo['intro_uid']) {
+                        //获取返利比率
+                        $is_agent = Db::name('user')->where(['id' => $touserinfo['intro_uid']])->value('is_agent');
+                        $intro_income_rebate_rate = $is_agent ? (int)config('site.h_intro_income_rebate_rate') : (int)config('site.intro_income_rebate_rate'); //邀请人收礼物返利比率
+                        if ($intro_income_rebate_rate > 0 && $intro_income_rebate_rate <= 100) {
+                            //上级获得金额
+                            $intro_uid_money = number_format($money * $intro_income_rebate_rate / 100, 2, '.', '');
+                            if ($intro_uid_money > 0) {
+                                $intro_result = model('Wallet')->lockChangeAccountRemain($touserinfo['intro_uid'],$user_id,'money',$intro_uid_money,68, '邀请人聊天礼物获赠奖励','gift_user_typing',$log_id);
+                                if($intro_result['status']===false)
+                                {
+                                    Db::rollback();
+                                    $this->error($intro_result['msg']);
+                                }
                             }
                         }
                     }
-                }
 
-                if ($this->auth->gender == 1 && $touserinfo['gender'] == 0) {
-                    //增加亲密度
-                    $user_intimacy_rs = addintimacy($this->auth->id, $user_id, $giftvalue);
-                    if (!$user_intimacy_rs['status']) {
+                    if ($this->auth->gender == 1 && $touserinfo['gender'] == 0) {
+                        //增加亲密度
+                        $user_intimacy_rs = addintimacy($this->auth->id, $user_id, $giftvalue);
+                        if (!$user_intimacy_rs['status']) {
+                            Db::rollback();
+                            $this->error('您的网络开小差啦~');
+                        }
+                    }
+                }else{
+                    $wallet_rs = model('wallet')->lockChangeAccountRemain($this->auth->id,$user_id,'jewel',-$giftvalue,33,'赠送礼物:'.$giftinfo["name"] . '*' . $number,'gift_user_typing',$log_id);
+                    if($wallet_rs['status'] === false){
                         Db::rollback();
-                        $this->error('您的网络开小差啦~');
+                        $this->error($wallet_rs['msg']);
                     }
                 }
             }

+ 2 - 1
application/common/model/Wallet.php

@@ -81,7 +81,8 @@ class Wallet extends Model
         );
 
         //获取小数点
-        $point = in_array($accountType,['money']) ? 2 : 0;
+//        $point = in_array($accountType,['money']) ? 2 : 0;
+        $point = 0;
         bcscale($point);
 
         //钱包名称

+ 3 - 2
application/extra/wallet.php

@@ -25,13 +25,14 @@ return [
 
 
         31 => '购买装扮消费',
+        33 => '聊天赠送礼物',//jewel 减少
         41 => '签到赠送金币',
 
         51 => '语聊间赠送礼物',
         52 => '语聊间获得礼物',//money
 
-        53 => '聊天赠送礼物',
-        54 => '聊天获得礼物',//money
+        53 => '聊天赠送礼物',// gold 减少
+        54 => '聊天获得礼物',//money 增加
 
         55 => '直播赠送礼物',
         56 => '直播获得礼物',//money