<?php /** * 用户账户管理 */ namespace app\Admin\controller; use think\Db; class Account extends Base { public function __construct() { parent::__construct(); } /** * @param status * @param username * @param mobile * @param nickname * @param page * @param size */ public function List() { $page = isset($this->post['page']) && $this->post['page'] != "" ? intval($this->post['page']) : 1; $size = isset($this->post['size']) && $this->post['size'] != "" ? intval($this->post['size']) : 10; $status = isset($this->post['status']) && $this->post['status'] !== "" ? intval($this->post['status']) : ""; $where = ['a.is_del'=>0]; if ($status !== "") { $where['a.status'] = $status; } $username = isset($this->post['username']) && $this->post['username'] !== "" ? trim($this->post['username']) : ""; if ($username != "") { $where['username'] = ["like", "%{$username}%"]; } $nickname = isset($this->post['nickname']) && $this->post['nickname'] !== "" ? trim($this->post['nickname']) : ""; if ($nickname != "") { $where['nickname'] = ["like" => "%{$nickname}%"]; } $mobile = isset($this->post['mobile']) && $this->post['mobile'] !== "" ? trim($this->post['mobile']) : ""; if ($mobile != "") { $where['c.mobile'] = ["like" => "%{$mobile}%"]; } $account_type = isset($this->post['type']) && $this->post['type'] !== "" ? intval($this->post['type']) : ""; if ($account_type !== "") { $where['a.account_type'] =$account_type; } $count = Db::name("account")->alias('a') ->join("fc_rela_account b", "a.id = b.accountid", "left") ->join("fc_account_info c", "b.account_info= c.id", "left") ->where($where)->count(); $total = ceil($count / $size); $page = $page >= $total ? $total : $page; $list = Db::name("account")->alias('a')->where($where)->page($page, $size) ->join("fc_rela_account b", "a.id = b.accountid", "left") ->join("fc_account_info c", "b.account_info= c.id", "left") ->field("`a`.`id` AS `id`, `a`.`username` AS `username`, `a`.`password` AS `password`, `a`.`salt` AS `salt`, `a`.`status` AS `status`, `a`.`is_del` AS `is_del`, `a`.`starttime` AS `starttime`, `a`.`expiretime` AS `expiretime`, `a`.`activetime` AS `activetime`, `a`.`addtime` AS `addtime`, `c`.`nickname` AS `nickname`, `c`.`avatar` AS `avatar`, `c`.`mobile` AS `mobile`, `c`.`remark` AS `remark`, `c`.`sex` AS `sex`") ->order("a.id desc")->select(); $i = []; foreach ($list as $vus) { $vi = Db::name('rela_video')->join('fc_video a', 'a.id=fc_rela_video.video_id', 'left')->field('a.video_sn,a.video_name,a.video_url,a.video_img')->where(['accountid' => $vus['id'], 'a.is_del' => 0,])->select(); if (empty($vi)) { $vi = []; } $vus['info'] = $vi; $i[] = $vus; } return app_show(0, "获取成功", ["list" => $i, "count" => $count]); } /** * @param username * @param password * @param starttime * @param expiretime * @param nickname * @param remark * @param video */ public function Create() { $username = isset($this->post['username']) && $this->post['username'] !== "" ? trim($this->post['username']) : ""; if ($username == "") { return error_show(1004, "参数username 不能为空"); } if (!checkAccount($username)) { return error_show(1004, "账户格式不正确"); } $isT = Db::name("account")->where(["is_del" => 0, "username" => $username])->find(); if ($isT) { return error_show(1004, "账户名已存在"); } $pasword = isset($this->post['password']) && $this->post['password'] !== "" ? trim($this->post['password']) : ""; if ($pasword == "") { return error_show(1004, "参数password 不能为空"); } if (!checkPasswd($pasword)) { return error_show(1004, "密码格式不正确"); } $starttime = isset($this->post['starttime']) && $this->post['starttime'] !== "" ? $this->post['starttime'] : ""; if ($starttime == "") { return error_show(1004, "参数starttime 不能为空"); } $expiretime = isset($this->post['expiretime']) && $this->post['expiretime'] !== "" ? $this->post['expiretime'] : ""; if ($expiretime == "") { return error_show(1004, "参数expiretime 不能为空"); } $nickname = isset($this->post['nickname']) && $this->post['nickname'] !== "" ? trim($this->post['nickname']) : ""; // if($nickname==""){ // return error_show(1004,"参数nickname 不能为空"); // } $mobile = isset($this->post['mobile']) && $this->post['mobile'] !== "" ? trim($this->post['mobile']) : ""; $type = isset($this->post['type']) && $this->post['type'] !== "" ? intval($this->post['type']) : "0"; // if($mobile==""){ // return error_show(1004,"参数mobile 不能为空"); // } $remark = isset($this->post['remark']) && $this->post['remark'] !== "" ? trim($this->post['remark']) : ""; $video = isset($this->post['video']) && $this->post['video'] !== "" ? $this->post['video'] : ""; if ($video == "") { return error_show(1004, "参数video 不能为空"); } Db::startTrans(); try { $salt = makeSalt(); $pas = sha1($pasword . $salt); $data = [ "username" => $username, "password" => $pas, "pwd" => $pasword, "salt" => $salt, "account_type" => $type, "status" => 0, "is_del" => 0, "starttime" => $starttime, "expiretime" => $expiretime, "addtime" => date("Y-m-d H:i:s"), "updatetime" => date("Y-m-d H:i:s") ]; $acccount = Db::name("account")->insert($data, false, true); if ($acccount > 0) { $user = [ "nickname" => $nickname, "mobile" => $mobile, "avatar" => "", "remark" => $remark, "sex" => "", "addtime" => date("Y-m-d H:i:s"), "updatetime" => date("Y-m-d H:i:s") ]; $info = Db::name("account_info")->insert($user, false, true); if ($info > 0) { $rela = ["accountid" => $acccount, "account_info" => $info]; $rela_acc = Db::name("rela_account")->insert($rela); // $rele = [["video_id"=>$video,"accountid"=>$video,"addtime"=>$video]]; $l = []; foreach ($video as $value) { $temp = ["video_id" => $value, "accountid" => $acccount, "addtime" => date("Y-m-d H:i:s")]; $l[] = $temp; } $rele_a = Db::name("rela_video")->insertAll($l); if ($rele_a == false) { Db::rollback(); return error_show(1002, "绑定失败"); } else { write_log("视频绑定成功", $this->userinfo, "account", "add"); } if ($rela_acc) { write_log("账户{$username}新建成功", $this->userinfo, "account", "add"); Db::commit(); return app_show(0, "账户新建成功"); } } } Db::rollback(); return error_show(1005, "账户新建失败"); } catch (\Exception $e) { Db::rollback(); return error_show(1003, $e->getMessage()); } } /**@param id 账户id * @return \think\response\Json|void * @throws \think\db\exception\DataNotFoundException * @throws \think\db\exception\DbException * @throws \think\db\exception\ModelNotFoundException * @throws \think\exception\DbException */ public function Read() { $id = isset($this->post['id']) && $this->post["id"] != "" ? intval($this->post['id']) : ""; if ($id == "") { return error_show(1004, "参数id 不能为空"); } $info = Db::name("account")->alias('a')->where(["a.id" => $id,'a.is_del'=>0]) ->join("fc_rela_account b", "a.id = b.accountid", "left") ->join("fc_account_info c", "b.account_info= c.id", "left") ->field("`a`.`id` AS `id`, `a`.`username` AS `username`, `a`.`password` AS `password`, `a`.`salt` AS `salt`, `a`.`status` AS `status`, `a`.`account_type` AS `type`, `a`.`is_del` AS `is_del`, `a`.`starttime` AS `starttime`, `a`.`expiretime` AS `expiretime`, `a`.`activetime` AS `activetime`, `a`.`addtime` AS `addtime`, `c`.`nickname` AS `nickname`, `c`.`avatar` AS `avatar`, `c`.`mobile` AS `mobile`, `c`.`remark` AS `remark`, `c`.`sex` AS `sex`") ->find(); if (empty($info)) { return error_show(1005, "未找到数据"); } if ($info["is_del"] == 1) { return error_show(1005, "账户已被删除"); } $info['status_n'] = $info['status'] == 0 ? "未激活" : $info['status'] == 1 ? "已激活" : "已失效"; $vi = Db::name('rela_video')->join('fc_video a', 'a.id=fc_rela_video.video_id', 'left') ->field('a.video_sn,a.video_name,a.video_url,a.video_img,fc_rela_video.video_id,a.status') ->where(['accountid' => $id, 'a.is_del' => 0, 'fc_rela_video.is_del' => 0])->select(); //var_dump(Db::name('rela_video')->getLastSql()); $info['info'] = $vi; return app_show(0, "获取成功", $info); } /** * @param id * @param username * @param password * @param starttime * @param expiretime * @param nickname * @param remark * @param video */ public function Save() { $id = isset($this->post['id']) && $this->post['id'] != "" ? intval($this->post['id']) : ""; if ($id == "") { return error_show(1004, "参数id 不能为空"); } $info = Db::name("account")->where(["is_del" => 0, "id" => $id])->find(); if (empty($info)) { return error_show(1004, "未找到数据"); } $username = isset($this->post['username']) && $this->post['username'] !== "" ? trim($this->post['username']) : ""; if ($username != "") { $isT = Db::name("account")->where(["is_del" => 0, "username" => $username, "id" => ["<>", $id]])->find(); if ($isT) { return error_show(1004, "账户名已存在"); } $info['username'] = $username; } // // $pasword = isset($this->post['password']) && $this->post['password'] !== "" ? trim($this->post['password']) : ""; // if ($pasword != "" && $info['password'] != sha1($pasword.$info['salt'])) { // $salt = makeSalt(); // $info['password'] = sha1($pasword . $salt); // $info['pwd'] = $pasword; // } $starttime = isset($this->post['starttime']) && $this->post['starttime'] !== "" ? $this->post['starttime'] : ""; if ($starttime != "") { $info['starttime'] = $starttime; } $expiretime = isset($this->post['expiretime']) && $this->post['expiretime'] !== "" ? $this->post['expiretime'] : ""; if ($expiretime != "") { $expire = strtotime($expiretime); if ($expire > time()) { $info['status'] = $info['activetime'] == "" ? 0 : 1; } else { $info['status'] = 2; } $info['expiretime'] = $expiretime; } $info['updatetime'] = date("Y-m-d H:i:s"); $rela = Db::name("account_info")->alias("a")->Join("fc_rela_account b", "b.account_info=a.id", "left")->where(["b.accountid" => $id])->field("a.*")->find(); $nickname = isset($this->post['nickname']) && $this->post['nickname'] !== "" ? trim($this->post['nickname']) : ""; $rela['nickname'] = $nickname; $mobile = isset($this->post['mobile']) && $this->post['mobile'] !== "" ? trim($this->post['mobile']) : ""; if ($mobile != "") { $rela['mobile'] = $mobile; } $type = isset($this->post['type']) && $this->post['type'] !== "" ? intval($this->post['type']) : ""; if($type!==""){ $info['account_type']=$type; } $rela['remark'] = isset($this->post['remark']) && $this->post['remark'] !== "" ? trim($this->post['remark']) : ""; $video = isset($this->post['video']) && $this->post['video'] !== "" ? $this->post['video'] : ""; if ($video == "") { return error_show(1004, "参数video 不能为空"); } $rela['updatetime'] = date("Y-m-d H:i:s"); Db::startTrans(); try { $acccount = Db::name("account")->update($info); if ($acccount) { $infoacc = Db::name("account_info")->update($rela); $del = Db::name('rela_video')->where(["is_del" => 0, "accountid" => $id])->select(); if ($del == true) { $dl = Db::name('rela_video')->where(["is_del" => 0, "accountid" => $id])->update(["addtime" => date("Y-m-d H:i:s"), "is_del" => 1]); } $k = []; $vb = Db::name('video')->where(['status' => 0, 'id' => ["in", $video]])->select(); if (!empty($vb)) { return error_show(1004, "存在已禁用的视频"); } foreach ($video as $valu) { $temp = ["video_id" => $valu, "accountid" => $id, "addtime" => date("Y-m-d H:i:s")]; $k[] = $temp; } $rele_a = Db::name("rela_video")->insertAll($k); if ($rele_a == false) { Db::rollback(); return error_show(1002, "绑定失败"); } else { write_log("视频绑定成功", $this->userinfo, "account", "edit"); } if ($infoacc) { write_log("账户{$username}新建成功", $this->userinfo, "account", "edit"); Db::commit(); return app_show(0, "账户编辑成功"); } else { Db::rollback(); return error_show(1005, "账户编辑失败"); } } Db::rollback(); return error_show(1005, "账户编辑失败"); } catch (\Exception $e) { Db::rollback(); return error_show(1003, $e->getMessage()); } } public function checkPwd(){ $id= isset($this->post['id']) && $this->post['id'] !== "" ? intval($this->post['id']) : ""; if($id===''){ return error_show(1004, "参数id 不能为空"); } $info = Db::name("account")->where(["is_del" => 0, "id" => $id])->find(); if (empty($info)) { return error_show(1004, "未找到数据"); } $pasword = isset($this->post['password']) && $this->post['password'] !== "" ? trim($this->post['password']) : ""; if($pasword===''){ return error_show(1004, "参数password 不能为空"); } if ($info['pwd']==$pasword) { return error_show(1004, "新密码不能与原密码相同"); } // if (!checkPasswd($pasword)) { // return error_show(1004, "密码格式不正确"); // } $salt = makeSalt(); $info['password'] = sha1($pasword . $salt); $info['pwd'] = $pasword; $info['salt'] = $salt; $info['updatetime'] = date("Y-m-d H:i:s"); $acc= Db::name("account")->update($info); return $acc ?app_show(0,"账户密码修改成功"): error_show(1005, "账户密码修改失败"); } }