<?php

namespace app\api\controller;


use app\common\controller\Api;
use think\Db;
require_once __DIR__.'/../../../vendor/workerman/gatewayclient/Gateway.php';
use GatewayClient\Gateway;
/**
 * 贵族接口
 */
class Noble extends Api
{
    protected $noNeedLogin = ['getNobleLevelList','getNobleLevelPrivilegeInfo','onNoble'];
    protected $noNeedRight = ['*'];

    /**
     * 获取贵族等级列表
     */
    public function getNobleLevelList() {
        $noblelevelModel = new \app\common\model\NobleLevel();
        $where = [];
        $where["is_show"] = 1;
        $noblelevelList = $noblelevelModel->where($where)->select();
        return $this->success("获取成功!",$noblelevelList);
    }

    /**
     * 根据贵族等级ID获取贵族等级特权
     */
    public function getNobleLevelPrivilegeInfo() {
        $level_id = $this->request->request("level_id");
        if (!$level_id) {
            $this->error(__('Invalid parameters'));
        }
        $nplModel = new \app\common\model\NobleLevelPrivilege();
        $where = [];
        $where["level_id"] = $level_id;
        $where["is_show"] = 1;
        $nplInfo = $nplModel->where($where)->select();

        if($nplInfo) {
            return $this->success("获取成功!",$nplInfo);
        } else {
            return $this->success("数据为空!",[]);
        }

    }

    /**
     * 获取贵族等级以及到期时间
     */
    public function getNobleDuetime() {
        $level_id = $this->request->request("level_id");
        if (!$level_id) {
            $this->error(__('Invalid parameters'));
        }
        $userModel = new \app\common\model\User();
        $info = $userModel->getUserNobleInfo($level_id,$this->auth->id);
        return $this->success("获取成功!",$info);
    }

    /**
     * 获取贵族等级所需金额
     */
    public function getNobleLogInfo() {
        $level_id = $this->request->request("level_id");
        if (!$level_id) {
            $this->error(__('Invalid parameters'));
        }
        $nldlModel = new \app\common\model\NobleDredgeLog();
        $noblelevelModel = new \app\common\model\NobleLevel();
        $noblelevelInfo = $noblelevelModel->where(["id"=>$level_id])->find();

        // 获取贵族等级开通信息
        $where = [];
        $where["user_id"] = $this->auth->id;
        $where["level_no"] = $noblelevelInfo["level_no"];
        $nldlCount = 0;
        $nldlInfo = $nldlModel->where($where)->limit(1)->order("dredge_num","desc")->select();
        $nldlInfo && $nldlInfo = $nldlInfo[0];
        // 判断是否是首月开通
        if($nldlInfo) {
            $nldlCount = $nldlInfo["dredge_num"];
        }
        $money = $nldlCount>0?$noblelevelInfo["renew"]:$noblelevelInfo["first"];
        $data["money"] = $money;
        return $this->success("获取成功!",$data);
    }

    /**
     * 开通贵族
     */
    public function beNoble() {
        $level_id = $this->request->request("level_id"); // 贵族等级ID
        if (!$level_id) {
            $this->error(__('Invalid parameters'));
        }
        if ($this->auth->power->noble == 1) {
            $this->error('您已被禁止开通贵族');
        }
        $time = time();
        // 获取贵族信息
        $noblelevelModel = new \app\common\model\NobleLevel();
        $nldlModel = new \app\common\model\NobleDredgeLog();
        $noblelevelInfo = $noblelevelModel->where(["id"=>$level_id])->find();

        // 获取贵族等级开通信息
        $where = [];
        $where["user_id"] = $this->auth->id;
        $where["level_no"] = $noblelevelInfo["level_no"];
        $nldlCount = 0;
        $nldlInfo = $nldlModel->where($where)->limit(1)->order("dredge_num","desc")->select();
        $nldlInfo && $nldlInfo = $nldlInfo[0];
        // 判断是否是首月开通
        if($nldlInfo) {
            $nldlCount = $nldlInfo["dredge_num"];
//            if(time() - $nldlInfo["createtime"] < 60) { // 同一个人,同一等级,一分钟之内重复开通,鉴定为系统bug
//                $this->error("您刚刚开通过此贵族特权");
//            }
        }
        $money = $nldlCount>0?$noblelevelInfo["renew"]:$noblelevelInfo["first"];

        if(!$noblelevelInfo || $money <= 0) {
            $this->error(__('贵族等级信息有误!'));
        }
        $userModel = new \app\common\model\User();
        $userjewellogModel = new \app\common\model\UserJewelLog();
        $where = [];
        $where["id"] = $this->auth->id;
        $userInfo = $userModel->where($where)->find();
        // 判断用户余额
        if($userInfo["jewel"]-$money < 0) {
            $this->error("您的钻石余额不足,请先充值");
        }

        // 获取当前用户贵族等级
        if($userInfo["noble"] == $level_id) {
            $duetime = $userInfo["noble_duetime"];
        } else {
            $duetime = $time;
        }

        Db::startTrans();
        try{
            // 扣除当前用户钻石余额 更新用户贵族信息
            $where = [];
            $where["id"] = $this->auth->id;
            $duetime = strtotime("+1 month",$duetime);
            $nextMonth = strtotime("+1 month",$time);
            $data = [];
            $data["noble"] = $level_id;
            $data["noble_duetime"] = $duetime;
            $submoney = bcsub($userInfo["jewel"],$money);
            // 开通返现
            $return = $nldlCount>0?$noblelevelInfo["give"]:$noblelevelInfo["firstgive"];
            $data["jewel"] = bcadd($submoney,$return);

            $res1 = $userModel->update($data,$where);
            // 添加当前用户钻石流水记录
            $res2 = $userjewellogModel->addUserJewelLog($this->auth->id, $money, "-", $userInfo["jewel"], "开通贵族:'" . $noblelevelInfo["name"] . "',扣除" . $money . "钻石!", 5);

            // 添加贵族等级开通明细
            $data = [];
            $data["user_id"] = $this->auth->id;
            $data["level_no"] = $noblelevelInfo["level_no"];
            $data["dredge_num"] = $nldlCount+1;
            $data["createtime"] = $time;
            $res3 = $nldlModel->insertGetId($data);

            // 添加当前用户钻石流水记录
            $res4 = $userjewellogModel->addUserJewelLog($this->auth->id, $return, "+", $userInfo["jewel"] - $money, "开通贵族:'" . $noblelevelInfo["name"] . "',赠送" . $return . "钻石!", 15);


            if($res1 && $res2 && $res3 && $res4) {
                Db::commit();
                $this->onNobleEffect($noblelevelInfo,$this->auth->id,$this->auth->nickname);
                $this->onNobleAttire($noblelevelInfo,$this->auth->id,$nextMonth,$time);

                // +exp
                $nobleArr = ['1'=>'entymIFE3J'];
                isset($nobleArr[$level_id]) && \app\common\model\TaskLog::tofinish($this->auth->id,$nobleArr[$level_id],1);

                // +message
                \app\common\model\Message::addMessage($this->auth->id,"贵族开通通知","恭喜,您已成功开通!".$noblelevelInfo["name"]." 贵族特权!");

                // 赠送消息尾灯
                //\app\common\model\AttireBack::addToMyBack(15,$this->auth->id);

                // 赠送聊天气泡
                if($noblelevelInfo->tqgq) {
                    $params_from = $this->request->request("params_from"); // 贵族等级ID
                    $attireInfo = \app\common\model\Attire::where(["use"=>1,"use_id"=>$level_id])->select();
                    if (!empty($attireInfo)) {
                        foreach ($attireInfo as $attireInfoKey => $attireInfoVal) {
                            \app\common\model\AttireBack::addToMyBack($attireInfoVal->id,$this->auth->id,$params_from);
                        }
                    }
                }


                $this->success("开通成功!");
            }

        }catch (ValidateException $e) {
            Db::rollback();
            $this->error($e->getMessage());
        } catch (PDOException $e) {
            Db::rollback();
            $this->error($e->getMessage());
        } catch (Exception $e) {
            Db::rollback();
            $this->error($e->getMessage());
        }
    }

    /**
     * 开通贵族后效果
     */
    private function onNobleEffect($noblelevelInfo,$user_id,$user_nickname) {

        $serviceNotice = "";
        $serviceSvga = "";
        $partyNotice = "";
        // 全服通知
        if($noblelevelInfo["qftz"] == 1) {
            $serviceNotice = "恭喜,玩家:".$user_nickname." 成功开通:".$noblelevelInfo["name"]."贵族特权!";
        }
        //全服动画
        if($noblelevelInfo["qfdh"]) {
            $serviceSvga = $noblelevelInfo["qfdh"];
        }
        // 公屏通知
        if($noblelevelInfo["gptz"] == 1) {
            $partyNotice = "恭喜,玩家:".$user_nickname." 成功开通:".$noblelevelInfo["name"]."贵族特权!";
        }

        $tcpArr = [];
        $tcpArr['type'] = "userBeNoble";
        $tcpArr['data'] = [
            'user_id' => $user_id,
            'nickname' => $user_nickname,
            'serviceNotice' => $serviceNotice,
            'serviceSvga' => $serviceSvga,
            'partyNotice' => $partyNotice,
        ];
        $tcpJson = json_encode($tcpArr);
        $Gateway = new Gateway();
        $Gateway::$registerAddress = '127.0.0.1:2345';
        $Gateway::sendToAll($tcpJson);//暂时注释

    }

    /**
     * 开通贵族后获得专属座驾
     */
    private function onNobleAttire($noblelevelInfo,$user_id,$nextMonth,$time) {
        // 获取贵族专属座驾信息
        $nobleAttireInfo = \app\common\model\NobleAttire::where(["noble_id"=>$noblelevelInfo["id"]])->find();
        if($nobleAttireInfo) {
            Db::startTrans();
            try{
                // 更新当前用户背包使用状态
                $res1 = \app\common\model\AttireBack::update(["is_using"=>0],["user_id"=>$user_id]);
                // 保存用户背包信息
                $data = [];
                $data["user_id"] = $user_id;
                $data["attire_id"] = 0;
                $data["type"] = 1;
                $data["attire_name"] = $nobleAttireInfo["attire_name"];
                $data["price"] = $nobleAttireInfo["price"];
                $data["file_image"] = $nobleAttireInfo["file_image"];
                $data["gif_image"] = $nobleAttireInfo["gif_image"];
                $data["limit_day"] = round(($nextMonth-$time)/86400);
                $data["duetime"] = $nextMonth;
                $data["is_use"] = 1;
                $data["is_using"] = 1;
                $data["createtime"] = time();
                $res2 = \app\common\model\AttireBack::insert($data);
                if($res1 && $res2) {
                    Db::commit();
                }

            }catch (ValidateException $e) {
                Db::rollback();
                $this->error($e->getMessage());
            } catch (PDOException $e) {
                Db::rollback();
                $this->error($e->getMessage());
            } catch (Exception $e) {
                Db::rollback();
                $this->error($e->getMessage());
            }
        }
    }

    public function aa() {
        Gateway::sendToAll("aaaaaa");
    }
}