<?php

namespace app\admin\controller;

use app\common\controller\Backend;
use think\Db;
use Overtrue\Pinyin\Pinyin;

/**
 * 视频专区
 *
 * @icon fa fa-circle-o
 */
class Video extends Backend
{

    /**
     * Video模型对象
     * @var \app\admin\model\Video
     */
    protected $model = null;

    public function _initialize()
    {
        parent::_initialize();
        $this->model = new \app\admin\model\Video;
        $this->view->assign("isPayList", $this->model->getIsPayList());
        $this->view->assign("statusList", $this->model->getStatusList());
    }



    /**
     * 默认生成的控制器所继承的父类中有index/add/edit/del/multi五个基础方法、destroy/restore/recyclebin三个回收站方法
     * 因此在当前控制器中可不用编写增删改查的代码,除非需要自己控制这部分逻辑
     * 需要将application/admin/library/traits/Backend.php中对应的方法复制到当前控制器,然后进行修改
     */


    /**
     * 查看
     */
    public function index()
    {
        //当前是否为关联查询
        $this->relationSearch = true;
        //设置过滤方法
        $this->request->filter(['strip_tags', 'trim']);
        if ($this->request->isAjax()) {
            //如果发送的来源是Selectpage,则转发到Selectpage
            if ($this->request->request('keyField')) {
                return $this->selectpage();
            }
            list($where, $sort, $order, $offset, $limit) = $this->buildparams();

            $list = $this->model
                    ->with(['type','cate','childcate'])
                    ->where($where)
                    ->order($sort, $order)
                    ->paginate($limit);

            foreach ($list as $row) {
                
                $row->getRelation('type')->visible(['type','name']);
                $row->getRelation('cate')->visible(['name']);
                $row->getRelation('childcate')->visible(['name']);
            }

            $result = array("total" => $list->total(), "rows" => $list->items());

            return json($result);
        }
        return $this->view->fetch();
    }

    /**
     * 添加
     */
    public function add()
    {
        if ($this->request->isPost()) {
            $params = $this->request->post("row/a");
            if ($params) {
                $params = $this->preExcludeFields($params);

                if ($this->dataLimit && $this->dataLimitFieldAutoFill) {
                    $params[$this->dataLimitField] = $this->auth->id;
                }
                $result = false;
                Db::startTrans();
                try {
                    //是否采用模型验证
                    if ($this->modelValidate) {
                        $name = str_replace("\\model\\", "\\validate\\", get_class($this->model));
                        $validate = is_bool($this->modelValidate) ? ($this->modelSceneValidate ? $name . '.add' : $name) : $this->modelValidate;
                        $this->model->validateFailException(true)->validate($validate);
                    }

                    //首字母
                    if(empty($params['search_title'])){
                        $params['search_title'] = $this->shouzimu($params['title']);
                    }

                    $result = $this->model->allowField(true)->save($params);

                    $id = $this->model->id;
                    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());
                }
                if ($result !== false) {
                    //内容同步
                    $cspid = config('cspid');
//                    $url = 'http://'.config('inject_ip').':'.config('inject_port').'/epgDataSync/v1/' . $cspid;
                    $url = 'http://jscp.agency.gitv.tv/epgDataSync/v1/' . $cspid . '/';
                    $videofile = $params['videofile'];
                    $videofile = explode('/', $videofile);
                    $video_url = $videofile[3];
                    $data = [
//                        'cspId' => $cspid,
                        'cpAlbumId' => $id,
                        'albumName' => $params['title'],
                        'tvSets' => 1,
                        'updateToSet' => 1,
                        'isPurchase' => $params['is_pay'],
                        'isEffective' => $params['status'],
                        'isOnline' => $params['status'],
                        'albumTypes' => '健康',
                        'picBox' => config('upload.cdnurl') . $params['image'],
                        'albumUpdateTime' => date('YmdHis', time()),
                        'albumCreateTime' => date('YmdHis', time()),
                        'tvlist' => [
                            [
                                'cpAlbumId' => $id,
                                'cpTvId' => $id,
                                'tvName' => $params['title'],
                                'tvIsEffective' => $params['status'],
                                'tvIsOnline' => $params['status'],
                                'isPurchase' => $params['is_pay'],
                                'playOrder' => 1,
                                'tvUrl' => 'ftp://'.config('ftp_user').':'.config('ftp_pwd').'@'.config('ftp_ip').':'.config('ftp_port').'/inject/'.$video_url
                            ]
                        ]
                    ];

                    $data = json_encode($data, 320);
                    $header = [
                        'Content-Type: application/json'
                    ];
                    $rs = httpRequest($url, 'POST', $data, $header);
                    if ($rs) {
                        $rs = json_decode($rs, true);
                        if ($rs['code'] == 'A000000') {
                            //注入中兴
                            $url2 = 'http://jscp.agency.gitv.tv/epgDataSync/v1/' . config('cspid_zx') . '/';
                            $rs2 = httpRequest($url2, 'POST', $data, $header);
                            if ($rs2) {
                                $rs2 = json_decode($rs2, true);
                                if ($rs2['code'] == 'A000000') {
                                    Db::name('video')->where(['id' => $id])->setField('inject_status', 1);
                                }
                            }
                        }
                    }

                    $this->success();
                } else {
                    $this->error(__('No rows were inserted'));
                }
            }
            $this->error(__('Parameter %s can not be empty', ''));
        }
        return $this->view->fetch();
    }

    /**
     * 编辑
     */
    public function edit($ids = null)
    {
        $row = $this->model->get($ids);
        if (!$row) {
            $this->error(__('No Results were found'));
        }
        $adminIds = $this->getDataLimitAdminIds();
        if (is_array($adminIds)) {
            if (!in_array($row[$this->dataLimitField], $adminIds)) {
                $this->error(__('You have no permission'));
            }
        }
        if ($this->request->isPost()) {
            $params = $this->request->post("row/a");
            if ($params) {
                $params = $this->preExcludeFields($params);
                $result = false;
                $params['search_status'] = 0;
                Db::startTrans();
                try {
                    //是否采用模型验证
                    if ($this->modelValidate) {
                        $name = str_replace("\\model\\", "\\validate\\", get_class($this->model));
                        $validate = is_bool($this->modelValidate) ? ($this->modelSceneValidate ? $name . '.edit' : $name) : $this->modelValidate;
                        $row->validateFailException(true)->validate($validate);
                    }
                    $result = $row->allowField(true)->save($params);
                    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());
                }
                if ($result !== false) {
                    //内容同步
                    /*$cspid = config('cspid');
//                    $url = 'http://'.config('inject_ip').':'.config('inject_port').'/epgDataSync/v1/' . $cspid . '/';
                    $url = 'http://jscp.agency.gitv.tv/epgDataSync/v1/' . $cspid . '/';
                    $videofile = $row['videofile'];
                    $videofile = explode('/', $videofile);
                    $video_url = $videofile[3];
                    $data = [
//                        'cspId' => $cspid,
                        'cpAlbumId' => $ids,
                        'albumName' => $params['title'],
                        'tvSets' => 1,
                        'updateToSet' => 1,
                        'isPurchase' => $params['is_pay'],
                        'isEffective' => $params['status'],
                        'isOnline' => $params['status'],
                        'albumTypes' => '健康',
                        'picBox' => config('upload.cdnurl') . $params['image'],
                        'albumUpdateTime' => date('YmdHis', time()),
//                        'albumCreateTime' => date('YmdHis', time()),
                        'tvlist' => [
                            [
                                'cpAlbumId' => $ids,
                                'cpTvId' => $ids,
                                'tvName' => $params['title'],
                                'tvIsEffective' => $params['status'],
                                'tvIsOnline' => $params['status'],
                                'isPurchase' => $params['is_pay'],
                                'playOrder' => 1,
                                'tvUrl' => 'ftp://'.config('ftp_user').':'.config('ftp_pwd').'@'.config('ftp_ip').':'.config('ftp_port').'/inject/'.$video_url
                            ]
                        ]
                    ];
                    $data = json_encode($data, 320);
                    $header = [
                        'Content-Type: application/json'
                    ];
                    $rs = httpRequest($url, 'POST', $data, $header);
                    if ($rs) {
                        $rs = json_decode($rs, true);
                        if ($rs['code'] == 'A000000') {
                            Db::name('video')->where(['id' => $ids])->setField('inject_status', 1);
                        }
                    }*/

                    $this->success();
                } else {
                    $this->error(__('No rows were updated'));
                }
            }
            $this->error(__('Parameter %s can not be empty', ''));
        }
        $this->view->assign("row", $row);
        return $this->view->fetch();
    }

    /**
     * 删除
     */
    public function del($ids = "")
    {
        if (!$this->request->isPost()) {
            $this->error(__("Invalid parameters"));
        }
        $ids = $ids ? $ids : $this->request->post("ids");

        $params = Db::name('video')->find($ids);
        if (!$params) {
            $this->success();
        }
        if ($params['status'] != 0) {
            $this->error('请先将视频状态修改为不显示');
        }

        Db::startTrans();
        $rt = Db::name('video')->delete($ids);
        if (!$rt) {
            Db::rollback();
            $this->error('删除失败');
        }

        //内容同步
        $cspid = config('cspid');
//        $url = 'http://'.config('inject_ip').':'.config('inject_port').'/epgDeleteSync/v1/' . $cspid;
        $url = 'http://jscp.agency.gitv.tv/epgDeleteSync/v1/' . $cspid . '/';

        $videofile = $params['videofile'];
        $videofile = explode('/', $videofile);
        $video_url = $videofile[3];

        $data = [
//            'cspId' => $cspid,
            'cpAlbumId' => $ids,
            'albumName' => $params['title'],
            'tvSets' => 1,
            'updateToSet' => 1,
            'isPurchase' => $params['is_pay'],
            'isEffective' => 0,
            'isOnline' => 2,
            'albumTypes' => '健康',
            'picBox' => config('upload.cdnurl') . $params['image'],
            'albumUpdateTime' => date('YmdHis', time()),
//                'albumCreateTime' => date('YmdHis', time()),
            'tvlist' => [
                [
                    'cpAlbumId' => $ids,
                    'cpTvId' => $ids,
                    'tvName' => $params['title'],
                    'tvIsEffective' => 0,
                    'tvIsOnline' => 2,
                    'isPurchase' => $params['is_pay'],
                    'playOrder' => 1,
                    'tvUrl' => 'ftp://'.config('ftp_user').':'.config('ftp_pwd').'@'.config('ftp_ip').':'.config('ftp_port').'/inject/'.$video_url
                ]
            ]
        ];
        $data = json_encode($data, 320);
        $header = [
            'Content-Type: application/json'
        ];
        $rs = httpRequest($url, 'POST', $data, $header);
        if (!$rs) {
            Db::rollback();
            $this->error('删除失败');
        }

        $rs = json_decode($rs, true);
        if ($rs['code'] != 'A000000') {
            Db::rollback();
            $this->error('删除失败');
        }

        //删除中兴内容
        $url2 = 'http://jscp.agency.gitv.tv/epgDeleteSync/v1/' . config('cspid_zx') . '/';
        $rs2 = httpRequest($url2, 'POST', $data, $header);
        /*if (!$rs2) {
            Db::rollback();
            $this->error('删除失败');
        }

        $rs2 = json_decode($rs2, true);
        if ($rs2['code'] != 'A000000') {
            Db::rollback();
            $this->error('删除失败');
        }*/

        //生成ftp文件
        $content = [
            'cpPrvdName' => '健康e家',
            'cpPrvCode' => '41000144',
            'cpPrvType' => '1006',
            'ChnName' => '健康',
            'ChnCode' => '1000020',
            'actors' => '无',
            'directors' => '无',
            'contentYear' => date('Y'),
            'tags' => '',
            'contentTime' => date('Y-m-d H:i:s'),
            'formatType' => '超清'
        ];
        //生成ftp文件
        $content['contentId'] = $params['movieid'];
        $content['extraContentID'] = $params['movieid'];
        $content['content'] = $params['title'];
        $content['intent'] = [
            'action' => 'com.huxiu.heh.tv.ui.splash.SplashActivity',
            'package' => 'com.huxiu.heh.tv',
            'component' => [
                'pkg' => 'com.huxiu.heh.tv',
                'cls' => 'com.huxiu.heh.tv.ui.splash.SplashActivity'
            ],
            'extras' => [
//                        'cmd' => '',
//                        'from' => '',
//                        'media_id' => ''
                'type_id' => $params['video_type_id'],
                'id' => $params['id']
            ]
        ];
        $content['isEffective'] = $params['status'];
        $content['pic'] = one_domain_image($params['image']);
        $content['isPaid'] = $params['is_pay'];

        $content = json_encode($content, 320);
        $filename = 'shipin_'.date('Ymd').'_'.date('His').'_increment'.'.json';
        error_log(print_r($content, 1) . PHP_EOL, 3, './jiankang/' . $filename);

        Db::commit();
        $this->success();
    }

    //中文字符串
    //ZWZFC
    private function shouzimu($string)
    {
        // 小内存型
        $pinyin = new Pinyin(); // 默认
        $pinyin_arr = $pinyin->convert($string);

        $shouzimu = '';
        if(!empty($pinyin_arr)){
            foreach($pinyin_arr as $key => $val){
                $shouzimu .= strtoupper(substr($val,0,1));
            }
        }
        return $shouzimu;
    }

    /**
     * 同步到旧版
     */
    public function tongbu(){

        $id = input('id');

        $video = Db::name('video')->find($id);
        if (!$video) {
            $this->error('未找到视频');
        }

        unset($video['id']);

        unset($video['search_title']);
        unset($video['good_number']);
        unset($video['collect_number']);
        unset($video['childcate_id']);
        unset($video['cate_id']);

        //旧版video表检索,有就更新,没有新增
        $check = Db::connect('database_jiankang')->name('hu_video')->where('id',$id)->find();
        if($check){
            Db::connect('database_jiankang')->name('hu_video')->where('id',$id)->update($video);
        }else{
            Db::connect('database_jiankang')->name('hu_video')->insertGetId($video);
        }

        $this->success();

    }
}