| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991 |
- <?php
- /**
- * 短视频
- */
- namespace app\admin\controller;
- use cmf\controller\AdminBaseController;
- use think\facade\Db;
- use think\db\Query;
- class VideoController extends AdminbaseController {
- protected function initialize(){
- parent::initialize();
- $site_info=cmf_get_option('site_info');
- $name_coin=$site_info['name_coin'];
- $this->name_coin=$name_coin;
- }
- protected function getVideoClass($k=''){
- $key="video_class";
- $list=getcaches($key);
- if(!$list){
- $list=Db::name("user_video_class")->where("status=1")->order("orderno")->column('title','id');
- setcaches($key,$list,10);
- }
-
- if($k==''){
- return $list;
- }
-
- return isset($list[$k]) ? $list[$k]: '';
- }
- /*待审核视频列表*/
- public function index(){
- $ordertype = $this->request->param('ordertype');
-
- $orderstr="";
- if($ordertype==1){//评论数排序
- $orderstr="comments DESC";
- }else if($ordertype==2){//票房数量排序(点赞)
- $orderstr="likes DESC";
- }else if($ordertype==3){//分享数量排序
- $orderstr="shares DESC";
- }else{
- $orderstr="addtime DESC";
- }
-
- $lists = Db::name('user_video')
- ->where(function (Query $query) {
- $data = $this->request->param();
- $query->where('isdel', 0);
- $query->where('status', 0);
- $query->where('is_ad', 0);
- $query->where('is_userad', 0);
- $classid=isset($data['classid']) ? $data['classid']: '';
- $keyword=isset($data['keyword']) ? $data['keyword']: '';
- $keyword1=isset($data['keyword1']) ? $data['keyword1']: '';
- $keyword2=isset($data['keyword2']) ? $data['keyword2']: '';
-
- if (!empty($classid)) {
- $query->where('classid', '=', $classid);
- }
- if (!empty($keyword)) {
- $query->where('uid|id', 'like', "%$keyword%");
- }
-
- if (!empty($keyword1)) {
- $query->where('title', 'like', "%$keyword1%");
- }
-
- if (!empty($keyword2)) {
-
- $userlist =Db::name("user")
- ->field("id")
- ->where("user_nickname like '%".$keyword2."%'")
- ->select();
- $strids="";
- $userlist->all();
- foreach ($userlist as $k => $vu) {
- if($strids==""){
- $strids=$vu['id'];
- }else{
- $strids.=",".$vu['id'];
- }
- }
- $query->where('uid', 'in', $strids);
- }
- })
- ->order($orderstr)
- ->paginate(20);
-
- $lists->each(function($v,$k){
- if($v['uid']==0){
- $userinfo=array(
- 'user_nickname'=>'系统管理员'
- );
- }else{
- $userinfo=getUserInfo($v['uid']);
- if(!$userinfo){
- $userinfo=array(
- 'user_nickname'=>'已删除'
- );
- }
-
- }
-
- $v['userinfo']=$userinfo;
- $v['thumb']=get_upload_path($v['thumb']);
- if($v['classid']){
- $v['class_name']=$this->getVideoClass($v['classid']);
- }else{
- $v['class_name']='';
- }
- if($v['activeid']){
- $subject = Db::name('author_center_activity')
- ->where(['id'=>$v['activeid']])
- ->value('subject');
- if($subject){
- $subject_arr = json_decode($subject,true);
- $v['activity_subject'] = '#'.implode('#',$subject_arr);
- }else{
- $v['activity_subject'] = '';
- }
- }else{
- $v['activity_subject']='';
- }
- return $v;
-
- });
- //分页-->筛选条件参数
- $data = $this->request->param();
- $lists->appends($data);
- // 获取分页显示
- $page = $lists->render();
-
- $p= $this->request->param('page');
- if(!$p){
- $p=1;
- }
-
-
- $classify=$this->getClassLists();
- $this->assign("classify",$classify);
- $this->assign('lists', $lists);
- $this->assign("page", $page);
- $this->assign("p",$p);
- $this->assign("time",time());
- $this->assign("name_coin",$this->name_coin);
- return $this->fetch();
- }
- /*未通过视频列表*/
- public function nopassindex(){
-
- $ordertype = $this->request->param('ordertype');
-
- $orderstr="";
- if($ordertype==1){//评论数排序
- $orderstr="comments DESC";
- }else if($ordertype==2){//票房数量排序(点赞)
- $orderstr="likes DESC";
- }else if($ordertype==3){//分享数量排序
- $orderstr="shares DESC";
- }else{
- $orderstr="addtime DESC";
- }
- $lists = Db::name('user_video')
- ->where(function (Query $query) {
- $data = $this->request->param();
- $query->where('isdel', 0);
- $query->where('status', 2);
- $query->where('is_ad', 0);
- $query->where('is_userad', 0);
- $classid=isset($data['classid']) ? $data['classid']: '';
- $keyword=isset($data['keyword']) ? $data['keyword']: '';
- $keyword1=isset($data['keyword1']) ? $data['keyword1']: '';
- $keyword2=isset($data['keyword2']) ? $data['keyword2']: '';
-
- if (!empty($classid)) {
- $query->where('classid', '=', $classid);
- }
- if (!empty($keyword)) {
- $query->where('uid|id', 'like', "%$keyword%");
- }
-
- if (!empty($keyword1)) {
- $query->where('title', 'like', "%$keyword1%");
- }
-
- if (!empty($keyword2)) {
-
- $userlist =Db::name("user")
- ->field("id")
- ->where("user_nickname like '%".$keyword2."%'")
- ->select();
- $strids="";
- $userlist->all();
- foreach ($userlist as $k => $vu) {
- if($strids==""){
- $strids=$vu['id'];
- }else{
- $strids.=",".$vu['id'];
- }
- }
-
- $query->where('uid', 'in', $strids);
- }
- })
- ->order($orderstr)
- ->paginate(20);
-
-
- $lists->each(function($v,$k){
- if($v['uid']==0){
- $userinfo=array(
- 'user_nickname'=>'系统管理员'
- );
- }else{
- $userinfo=getUserInfo($v['uid']);
- if(!$userinfo){
- $userinfo=array(
- 'user_nickname'=>'已删除'
- );
- }
-
- }
-
- $v['userinfo']=$userinfo;
- $v['thumb']=get_upload_path($v['thumb']);
- if($v['classid']){
- $v['class_name']=$this->getVideoClass($v['classid']);
- }else{
- $v['class_name']='';
- }
- if($v['activeid']){
- $subject = Db::name('author_center_activity')
- ->where(['id'=>$v['activeid']])
- ->value('subject');
- if($subject){
- $subject_arr = json_decode($subject,true);
- $v['activity_subject'] = '#'.implode('#',$subject_arr);
- }else{
- $v['activity_subject'] = '';
- }
- }else{
- $v['activity_subject']='';
- }
- return $v;
-
- });
-
- //分页-->筛选条件参数
- $data = $this->request->param();
- $lists->appends($data);
-
- // 获取分页显示
- $page = $lists->render();
-
- $p= $this->request->param('page');
- if(!$p){
- $p=1;
- }
-
- $classify=$this->getClassLists();
- $this->assign("classify",$classify);
- $this->assign('lists', $lists);
- $this->assign("page", $page);
- $this->assign("p",$p);
- $this->assign("time",time());
- $this->assign("name_coin",$this->name_coin);
- return $this->fetch();
- }
- /*审核通过视频列表*/
- public function passindex(){
-
- $ordertype = $this->request->param('ordertype');
-
- $orderstr="";
- if($ordertype==1){//评论数排序
- $orderstr="comments DESC";
- }else if($ordertype==2){//票房数量排序(点赞)
- $orderstr="likes DESC";
- }else if($ordertype==3){//分享数量排序
- $orderstr="shares DESC";
- }else{
- $orderstr="addtime DESC";
- }
-
-
-
- $lists = Db::name('user_video')
- ->where(function (Query $query) {
- $data = $this->request->param();
- $query->where('isdel', 0);
- $query->where('status', 1);
- $query->where('is_ad', 0);
- $query->where('is_userad', 0);
- $classid=isset($data['classid']) ? $data['classid']: '';
- $keyword=isset($data['keyword']) ? $data['keyword']: '';
- $keyword1=isset($data['keyword1']) ? $data['keyword1']: '';
- $keyword2=isset($data['keyword2']) ? $data['keyword2']: '';
- if (!empty($classid)) {
- $query->where('classid', '=', $classid);
- }
-
- if (!empty($keyword)) {
- $query->where('uid|id', 'like', "%$keyword%");
- }
- if (!empty($keyword1)) {
- $query->where('title', 'like', "%$keyword1%");
- }
-
- if (!empty($keyword2)) {
-
- $userlist =Db::name("user")
- ->field("id")
- ->where("user_nickname like '%".$keyword2."%'")
- ->select();
- $strids="";
- $userlist->all();
- foreach ($userlist as $k => $vu) {
- if($strids==""){
- $strids=$vu['id'];
- }else{
- $strids.=",".$vu['id'];
- }
- }
- $query->where('uid', 'in', $strids);
- }
- })
- ->order($orderstr)
- ->paginate(20);
-
-
- $lists->each(function($v,$k){
- if($v['uid']==0){
- $userinfo=array(
- 'user_nickname'=>'系统管理员'
- );
- }else{
- $userinfo=getUserInfo($v['uid']);
- if(!$userinfo){
- $userinfo=array(
- 'user_nickname'=>'已删除'
- );
- }
-
- }
-
- $v['userinfo']=$userinfo;
- $v['thumb']=get_upload_path($v['thumb']);
- if($v['classid']){
- $v['class_name']=$this->getVideoClass($v['classid']);
- }else{
- $v['class_name']='';
- }
- if($v['activeid']){
- $subject = Db::name('author_center_activity')
- ->where(['id'=>$v['activeid']])
- ->value('subject');
- if($subject){
- $subject_arr = json_decode($subject,true);
- $v['activity_subject'] = '#'.implode('#',$subject_arr);
- }else{
- $v['activity_subject'] = '';
- }
- }else{
- $v['activity_subject']='';
- }
- return $v;
-
- });
-
-
-
- //分页-->筛选条件参数
- $data = $this->request->param();
- $lists->appends($data);
-
- // 获取分页显示
- $page = $lists->render();
-
-
-
-
- $p= $this->request->param('page');
- if(!$p){
- $p=1;
- }
- $classify=$this->getClassLists();
- $this->assign("classify",$classify);
- $this->assign('lists', $lists);
- $this->assign("page", $page);
- $this->assign("p",$p);
- $this->assign("time",time());
- $this->assign("name_coin",$this->name_coin);
- return $this->fetch();
- }
- //删除视频
- public function del(){
- $res=array("code"=>0,"msg"=>"删除成功","info"=>array());
-
- $data = $this->request->param();
- $id=$data['id'];
- $reason=$data["reason"];
- if(!$id){
- $res['code']=1001;
- $res['msg']='视频信息加载失败';
- echo json_encode($res);
- return;
- }
- //获取视频信息
- $videoInfo=Db::name("user_video")->where("id={$id}")->find();
- $result=Db::name("user_video")->where("id={$id}")->delete();
-
- //$result=Db::name("user_video")->where("id={$id}")->update(["isdel"=>"1"]);
- if($result!==false){
- Db::name("user_video_comments_at_messages")->where("videoid={$id}")->delete(); //删除视频评论@信息列表
- Db::name("user_video_comments_messages")->where("videoid={$id}")->delete(); //删除视频评论信息列表
- Db::name("praise_messages")->where("videoid={$id}")->delete(); //删除赞通知列表
- Db::name("user_video_comments")->where("videoid={$id}")->delete(); //删除视频评论
- Db::name("user_video_like")->where("videoid={$id}")->delete(); //删除视频喜欢
- Db::name("user_video_report")->where("videoid={$id}")->delete(); //删除视频举报
- Db::name("user_video_view")->where("videoid={$id}")->delete(); //删除视频观看
- Db::name("user_video_collection")->where("videoid={$id}")->delete(); //删除视频收藏
-
- /*//获取该视频的评论id
- $commentlists=Db::name("user_video_comments")->field("id")->where("videoid={$id}")->select();
- $commentids="";
- foreach($commentlists as $k=>$v){
- if($commentids==""){
- $commentids=$v['id'];
- }else{
- $commentids.=",".$v['id'];
- }
- }
- //删除视频评论喜欢
- $map['commentid']=array("in",$commentids);*/
- Db::name("user_video_comments_like")->where("videoid={$id}")->delete(); //删除视频评论喜欢
- //如果该视频有正在上热门记录,需要将用户的钻石退回并将上热门记录删除
- $popinfo=Db::name("popular_orders")->where("videoid={$id} and status=1 and refund_status=0")->find();
- if($popinfo){
- $coin=$videoInfo['p_nums']/$popinfo['nums']*$popinfo['money'];
- $coin=floor($coin);
- if($coin>=1){
- $isok=changeUserCoin($popinfo['uid'],$coin,1);
- if($isok){
- $data=array(
- 'type'=>'income',
- 'action'=>'pop_refund',
- 'uid'=>$popinfo['uid'],
- 'touid'=>$popinfo['uid'],
- 'totalcoin'=>$coin,
- 'videoid'=>$id,
- 'addtime'=>time()
- );
- //写入钻石消费记录
- setCoinRecord($data);
- //将上热门记录删除
- Db::name("popular_orders")->where("videoid={$id}")->delete();
- }
- }
- }
-
- if($videoInfo['isdel']==0){ //视频上架情况下被删除发送通知
-
- if($videoInfo['title']!=''){
- $videoTitle='上传的《'.$videoInfo['title'].'》';
- }else{
- $videoTitle='上传的';
- }
- $baseMsg='您于'.date("Y-m-d H:i:s",$videoInfo['addtime']).$videoTitle.'视频被管理员于'.date("Y-m-d H:i:s",time()).'删除';
- if(!$reason){
- $msg=$baseMsg;
- }else{
- $msg=$baseMsg.',删除原因为:'.$reason;
- }
- $uid=$videoInfo['uid'];
- $text="视频删除提醒";
- $result1=addSysytemInfo($uid,$text,$msg);
- if($result1!==false){
- //发送腾讯云IM
- txMessageIM($text,$uid);
- }
- }
- $this->changeVideoPopular($id,$videoInfo['p_nums'],0);
-
- $res['msg']='视频删除成功';
- echo json_encode($res);
- return;
-
- }else{
- $res['code']=1002;
- $res['msg']='视频删除失败';
- echo json_encode($res);
- return;
- }
-
- }
- //排序
- public function listsorders() {
-
- $ids=$this->request->param('listsorders');
- foreach ($ids as $key => $r) {
- $data['orderno'] = $r;
- Db::name("user_video")->where(array('id' => $key))->save($data);
- }
-
- $status = true;
- if ($status) {
- $this->success("排序更新成功!");
- } else {
- $this->error("排序更新失败!");
- }
- }
-
- //添加
- public function add(){
- $classify=$this->getClassLists();
-
- $this->assign("classify",$classify);
- $this->assign("name_coin",$this->name_coin);
- $this->assign("time",time());
- return $this->fetch();
- }
- public function add_post(){
- if($this->request->isPost()) {
- $data=$this->request->param();
-
- $video=Db::name("user_video");
-
- $data['addtime']=time();
- $data['uid']=0;
-
- $owner=$data['owner'];
- $owner_uid=$data['owner_uid'];
- if($owner==1){
- if($owner_uid==""||!is_numeric($owner_uid)){
- $this->error("请填写视频所有者id");
- return;
- }
- //判断用户是否存在
- $ownerInfo=Db::name("user")->where("user_type=2 and id={$owner_uid}")->find();
- if(!$ownerInfo){
- $this->error("视频所有者不存在");
- return;
- }
- $data['uid']=$owner_uid;
- }
- $url=$data['href'];
- $url_w=$data['href_w'];
-
- $title=$data['title'];
- $coin=$data['coin'];
- $thumb=$data['thumb'];
- if($title==""){
- $this->error("请填写视频标题");
- }
- if($coin<0){
- $this->error("需花费".$this->name_coin."不能小于0");
- }
- if(floor($coin)!=$coin){
- $this->error("需花费".$this->name_coin."必须为整数");
- }
- if($thumb==""){
- $this->error("请上传视频封面");
- }
-
-
- $data['thumb_s']=$thumb;
- //获取后台上传配置
- $configpri=getConfigPri();
- $show_val=$configpri['show_val'];
- $data['show_val']=$show_val;
- $uploadSetting = cmf_get_upload_setting();
- $extensions=$uploadSetting['file_types']['video']['extensions'];
- $allow=explode(",",$extensions);
- $video_upload_type=$data['video_upload_type'];
- if($video_upload_type==0){
- if($url==''){
- $this->error("请填写视频链接");
- }
- if($url_w==''){
- $this->error("请填写水印视频链接");
- }
- //判断链接地址的正确性
- if(strpos($url,'http')===false){
- $this->error("请填写正确的视频地址");
- }
- $video_type=substr(strrchr($url, '.'), 1);
- if(!in_array(strtolower($video_type), $allow)){
- $this->error("请填写正确后缀的视频地址");
- }
-
- $data['href']=$url;
-
- //判断链接地址的正确性
- if(strpos($url_w,'http')===false){
- $this->error("请填写正确的水印视频地址");
- }
- $video_type_w=substr(strrchr($url_w, '.'), 1);
- if(!in_array(strtolower($video_type_w), $allow)){
- $this->error("请填写正确后缀的水印视频地址");
- }
- $data['href_w']=$url_w;
- }else{
- if(!$_FILES){
- $this->error("请上传视频文件");
- }
- if(!isset($_FILES["file"])){
- $this->error("请上传视频");
- }
- if(!isset($_FILES["file_w"])){
- $this->error("请上传水印视频");
- }
-
- $files["file"]=$_FILES["file"];
- $type='video';
- if (!get_file_suffix($files['file']['name'],$allow)){
- $this->error("请上传正确格式的视频文件或检查上传设置中视频文件设置的文件类型");
- }
- $rs=adminUploadFiles($files,$type);
- if($rs['code']!=0){
- $this->error($rs['msg']);
- }
-
-
- $files_w["file"]=$_FILES["file_w"];
- $type_w='video';
- if (!get_file_suffix($files_w['file']['name'],$allow)){
- $this->error("请上传正确格式的水印视频文件或检查上传设置中视频文件设置的文件类型");
- }
- $rs_w=adminUploadFiles($files_w,$type_w);
-
-
- if($rs_w['code']!=0){
- $this->error($rs_w['msg']);
- }
- $data['href']=$rs['filepath'];
- $data['href_w']=$rs_w['filepath'];
- }
-
-
-
-
- //计算封面尺寸比例
- $configpub=getConfigPub(); //获取公共配置信息
- $anyway='1.1';
- //if($configpri['cloudtype']!=1){
- $thumb_url=get_upload_path($thumb);
-
- $refer=$configpub['site'];
- $option=array(
- 'http'=>array('header'=>"Referer: {$refer}"),
- "ssl" => [
- "verify_peer"=>false,
- "verify_peer_name"=>false,
- ]
- );
- $context=stream_context_create($option);//创建资源流上下文
- $file_contents = file_get_contents($thumb_url,false, $context);//将整个文件读入一个字符串
- $thumb_size = getimagesizefromstring($file_contents);//从字符串中获取图像尺寸信息
- if($thumb_size){
- $thumb_width=$thumb_size[0]; //封面-宽
- $thumb_height=$thumb_size[1]; //封面-高
- $anyway=round($thumb_height/$thumb_width);
- }
- //}
- $data['anyway']=$anyway;
- unset($data['file']);
- unset($data['file_w']);
- unset($data['owner']);
- unset($data['owner_uid']);
- unset($data['video_upload_type']);
-
- $result=$video->insert($data);
- if($result){
- $this->success('添加成功','admin/video/passindex',3);
- }else{
- $this->error('添加失败');
- }
- }
- }
-
- //编辑
- public function edit(){
- $data = $this->request->param();
- $id=intval($data['id']);
- $from=$data["from"];
-
- if($id){
- $video=Db::name("user_video")->where("id={$id}")->find();
- if($video['uid']==0){
- $userinfo=array(
- 'user_nickname'=>'系统管理员'
- );
- }else{
- $userinfo=getUserInfo($video['uid']);
- if(!$userinfo){
- $userinfo=array(
- 'user_nickname'=>'已删除'
- );
- }
- }
-
- $video['userinfo']=$userinfo;
- $video['thumb']=get_upload_path($video['thumb']);
- $video['href']=get_upload_path($video['href']);
- $video['href_w']=get_upload_path($video['href_w']);
- //获取视频绑定的商品
- $goodsinfo=[];
- $goodsinfo=Db::name("shop_goods")->where("id={$video['goodsid']}")->find();
- if($goodsinfo){
- $thumb_arr=explode(',',$goodsinfo['thumbs']);
- $goodsinfo['thumb']=get_upload_path($thumb_arr[0]);
- if($goodsinfo['type']==0){
- $goodsinfo['type_name']='站内商品';
- }else if($goodsinfo['type']==1){
- $goodsinfo['type_name']='站外商品';
- }else{
- $goodsinfo['type_name']='平台自营';
- }
- $goodsinfo['old_price']=$goodsinfo['original_price'];
- $goodsinfo['price']=$goodsinfo['present_price'];
- $goodsinfo['des']=$goodsinfo['goods_desc'];
- }
- $this->assign('video', $video);
- $this->assign('goodsinfo', $goodsinfo);
- $this->assign('name_coin', $this->name_coin);
- }else{
- $this->error('数据传入失败!');
- }
- $this->assign("from",$from);
- return $this->fetch();
- }
-
- public function edit_post(){
- if($this->request->isPost()) {
- $data = $this->request->param();
- $video=Db::name("user_video");
- $id=$data['id'];
- $title=$data['title'];
- $thumb=$data['thumb'];
- $type=isset($data['video_upload_type'])?$data['video_upload_type']:'';
- $url=$data['href_e'];
- $url_w=$data['href_e_w'];
- $status=isset($data['status'])?$data['status']:'';
- $isdel=isset($data['isdel'])?$data['isdel']:'';
- $nopasstime=$data['nopasstime'];
- $coin=$data['coin'];
-
- /*if($title==""){
- $this->error("请填写视频标题");
- }*/
- if($coin<0){
- $this->error("需花费".$this->name_coin."不能小于0");
- }
- if(floor($coin)!=$coin){
- $this->error("需花费".$this->name_coin."必须为整数");
- }
- if($thumb==""){
- $this->error("请上传视频封面");
- }
- $data['thumb_s']=$thumb;
- if($type!=''){
- $uploadSetting = cmf_get_upload_setting();
- $extensions=$uploadSetting['file_types']['video']['extensions'];
- $allow=explode(",",$extensions);
- if($type==0){ //视频链接型式
- if($url==''){
- $this->error("请填写视频链接地址");
- }
-
- if($url_w==''){
- $this->error("请填写水印视频链接地址");
- }
- //判断链接地址的正确性
- if(strpos($url,'http')===false){
- $this->error("请填写正确的视频地址");
- }
- $video_type=substr(strrchr($url, '.'), 1);
- if(!in_array(strtolower($video_type), $allow)){
- $this->error("请填写正确后缀的视频地址");
- }
-
- $data['href']=$url;
-
- //判断链接地址的正确性
- if(strpos($url_w,'http')===false){
- $this->error("请填写正确的水印视频地址");
- }
- $video_type_w=substr(strrchr($url_w, '.'), 1);
- if(!in_array(strtolower($video_type_w), $allow)){
- $this->error("请填写正确后缀的水印视频地址");
- }
-
- $data['href_w']=$url_w;
- }else if($type==1){ //文件上传型式
- if(!$_FILES["file"]){
- $this->error("请上传视频");
- }
- if(!$_FILES["file_w"]){
- $this->error("请上传水印视频");
- }
-
- $files["file"]=$_FILES["file"];
- $type='video';
- if (!get_file_suffix($files['file']['name'],$allow)){
- $this->error("请上传正确格式的水印视频文件或检查上传设置中视频文件设置的文件类型");
- }
-
- $rs=adminUploadFiles($files,$type);
- if($rs['code']!=0){
- $this->error($rs['msg']);
- }
-
-
- $file_w["file"]=$_FILES["file_w"];
- $type_w='video';
- if (!get_file_suffix($file_w['file']['name'],$allow)){
- $this->error("请上传正确格式的水印视频文件或检查上传设置中视频文件设置的文件类型");
- }
-
- $rs_w=adminUploadFiles($file_w,$type_w);
- if($rs_w['code']!=0){
- $this->error($rs_w['msg']);
- }
-
- $data['href']=$rs['filepath'];
- $data['href_w']=$rs_w['filepath'];
- }
- }
- if($status==2){
-
- $data['nopass_time']=time();
- }
- //审核通过给该视频添加曝光值(改为接口添加视频时直接添加曝光值)
- // if($status==1){
- // $data['show_val']=100;
- // }
-
-
- //计算封面尺寸比例
- $configpub=getConfigPub(); //获取公共配置信息
- //$configpri=getConfigPri(); //获取后台上传配置
- $anyway='1.1';
- //if($configpri['cloudtype']!=1){
- $thumb_url=get_upload_path($thumb);
- $refer=$configpub['site'];
- $option=array(
- 'http'=>array('header'=>"Referer: {$refer}"),
- "ssl" => [
- "verify_peer"=>false,
- "verify_peer_name"=>false,
- ]
- );
- $context=stream_context_create($option);//创建资源流上下文
- $file_contents = file_get_contents($thumb_url,false, $context);//将整个文件读入一个字符串
- $thumb_size = getimagesizefromstring($file_contents);//从字符串中获取图像尺寸信息
- if($thumb_size){
- $thumb_width=$thumb_size[0]; //封面-宽
- $thumb_height=$thumb_size[1]; //封面-高
- $anyway=round($thumb_height/$thumb_width);
- }
- //}
- $data['anyway']=$anyway;
-
-
- unset($data['file']);
- unset($data['file_w']);
- unset($data['href_e']);
- unset($data['href_e_w']);
- unset($data['video_upload_type']);
- unset($data['owner_uid']);
- unset($data['nopasstime']);
- unset($data['ckplayer_playerzmblbkjP']);
-
-
- $result=$video->update($data);
- if($result!==false){
- if($status==2||$isdel==1){ //如果该视频下架或视频状态改为不通过,需要将视频喜欢列表的状态更改
- Db::name("user_video_like")->where("videoid={$id}")->update(['status'=>0]);
- Db::name("user_video_view")->where("videoid={$id}")->update(['status'=>0]);
- }
- if($status==2&&$nopasstime==0){ //视频状态为审核不通过且为第一次审核为不通过,发送极光IM
- $videoInfo=Db::name("user_video")->where("id={$id}")->find();
- $uid=$videoInfo['uid'];
- if($videoInfo['title']!=''){
- $videoTitle='上传的《'.$videoInfo['title'].'》';
- }else{
- $videoTitle='上传的';
- }
- $baseMsg='您于'.date("Y-m-d H:i:s",$videoInfo['addtime']).$videoTitle.'视频被管理员于'.date("Y-m-d H:i:s",time()).'审核为不通过';
-
- $text="视频未审核通过提醒";
- $result1=addSysytemInfo($uid,$text,$baseMsg);
- if($result1!==false){
- //发送腾讯云IM
- txMessageIM($text,$uid);
- }
- }
- $this->success('修改成功');
- }else{
- $this->error('修改失败');
- }
- }
- }
-
- public function reportlist(){
-
- $lists=Db::name("user_video_report")
- ->where(function (Query $query) {
- $data = $this->request->param();
-
- if (!empty($data['status'])) {
- $query->where('status', $data['status']);
- }
-
- if (!empty($data['start_time'])) {
- $query->where('addtime', '>=' , strtotime($data['start_time']));
- }
-
- if (!empty($data['end_time'])) {
- $query->where('addtime', '<=' ,strtotime($data['end_time']));
- }
-
- if (!empty($data['start_time']) && !empty($data['end_time'])) {
- $query->where('addtime', 'between' , [strtotime($data['start_time']),strtotime($data['end_time'])]);
- }
-
-
- if (!empty($data['keyword'])) {
- $keyword = $data['keyword'];
- $query->where('uid', 'like', "%$keyword%");
- }
-
-
- })
- ->order("addtime DESC")
- ->paginate(20);
-
-
- $lists->all();
-
- $lists->each(function($v,$k){
- $userinfo=Db::name("user")
- ->field("user_nickname")
- ->where("id='{$v['uid']}'")
- ->find();
-
- if(!$userinfo){
- $userinfo=array(
- 'user_nickname'=>'已删除'
- );
- }
- $v['userinfo']= $userinfo;
-
-
- $touserinfo=Db::name("user")
- ->field("user_nickname")
- ->where("id='{$v['touid']}'")
- ->find();
-
- if(!$touserinfo){
- $touserinfo=array(
- 'user_nickname'=>'已删除'
- );
- }
- $v['touserinfo']= $touserinfo;
- //判断视频是否下架
- $video_isdel=Db::name("user_video")->where("id={$v['videoid']}")->value("isdel");
- $v['video_isdel']=$video_isdel;
- return $v;
-
- });
-
-
- //分页-->筛选条件参数
- $data = $this->request->param();
- $lists->appends($data);
-
-
-
- // 获取分页显示
- $page = $lists->render();
- $p= $this->request->param('page');
- if(!$p){
- $p=1;
- }
-
-
- $this->assign('lists', $lists);
- $this->assign("page", $page);
- $this->assign("p",$p);
- return $this->fetch();
- }
-
- //视频举报标记
- public function setstatus(){
- $id=$this->request->param('id');
- if($id){
- $data['status']=1;
- $data['uptime']=time();
- $result=Db::name("user_video_report")->where("id='{$id}'")->update($data);
- if($result!==false){
- $this->success('标记成功');
- }else{
- $this->error('标记失败');
- }
- }else{
- $this->error('数据传入失败!');
- }
- }
- //删除用户举报列表
- public function report_del(){
- $id=$this->request->param("id");
- if($id){
- $result=Db::name("user_video_report")->delete($id);
- if($result){
- $this->success('删除成功');
- }else{
- $this->error('删除失败');
- }
- }else{
- $this->error('数据传入失败!');
- }
- }
- //举报内容设置**************start******************
-
- //举报类型列表
-
- public function reportset(){
- $lists = Db::name("user_video_report_classify")
- ->order("orderno ASC")
- ->paginate(20);
- // 获取分页显示
- $page = $lists->render();
-
- $this->assign('lists', $lists);
- $this->assign('page', $page);
- return $this->fetch();
- }
- //添加举报理由
- public function add_report(){
-
- return $this->fetch();
- }
- public function add_reportpost(){
-
- if($this->request->isPost()) {
- $data=$this->request->param();
-
- $report=Db::name("user_video_report_classify");
-
- $name=$data['name'];//举报类型名称
- if(!trim($name)){
- $this->error('举报类型名称不能为空');
- }
- $isexit=Db::name("user_video_report_classify")
- ->where("name='{$name}'")
- ->find();
- if($isexit){
- $this->error('该举报类型名称已存在');
- }
-
- $data['addtime']=time();
- $result=$report->insert($data);
-
- if($result){
- $this->success('添加成功');
- }else{
- $this->error('添加失败');
- }
- }
- }
- //编辑举报类型名称
- public function edit_report(){
- $id = $this->request->param('id', 0, 'intval');
- if($id){
- $reportinfo=Db::name("user_video_report_classify")
- ->where("id={$id}")
- ->find();
-
- $this->assign('reportinfo', $reportinfo);
- }else{
- $this->error('数据传入失败!');
- }
- return $this->fetch();
- }
-
- public function edit_reportpost(){
- if($this->request->isPost()) {
- $data=$this->request->param();
-
- $report=Db::name("user_video_report_classify");
-
-
- $id=$data['id'];
- $name=$data['name'];//举报类型名称
-
- if(!trim($name)){
- $this->error('举报类型名称不能为空');
- }
-
- $isexit=Db::name("user_video_report_classify")
- ->where("id!={$id} and name='{$name}'")
- ->find();
- if($isexit){
- $this->error('该举报类型名称已存在');
- }
-
-
- $result=$report->update($data);
- if($result!==false){
- $this->success('修改成功');
- }else{
- $this->error('修改失败');
- }
- }
- }
- //删除举报类型名称
- public function del_report(){
- $id = $this->request->param('id', 0, 'intval');
- if($id){
- $result=Db::name("user_video_report_classify")->where("id={$id}")->delete();
- if($result!==false){
- $this->success('删除成功');
- }else{
- $this->error('删除失败');
- }
- }else{
- $this->error('数据传入失败!');
- }
- return $this->fetch();
- }
-
- //举报内容排序
- public function listordersset() {
-
-
- $ids=$this->request->param('listorders');
- foreach ($ids as $key => $r) {
- $data['orderno'] = $r;
- Db::name("user_video_report_classify")
- ->where(array('id' => $key))
- ->update($data);
- }
-
- $status = true;
- if ($status) {
- $this->success("排序更新成功!");
- } else {
- $this->error("排序更新失败!");
- }
- }
- //举报内容设置**************end******************
- //设置下架
- public function setXiajia(){
- $res=array("code"=>0,"msg"=>"下架成功","info"=>array());
- $data = $this->request->param();
-
-
- $id=$data['id'];
- $reason=$data["reason"];
- if(!$id){
- $res['code']=1001;
- $res['msg']="请确认视频信息";
- echo json_encode($res);
- return;
- }
- //判断此视频是否存在
- $videoInfo=Db::name("user_video")->where("id={$id}")->find();
- if(!$videoInfo){
- $res['code']=1001;
- $res['msg']="请确认视频信息";
- echo json_encode($res);
- return;
- }
- //更新视频状态
- $data=array("isdel"=>1,"xiajia_reason"=>$reason);
- $result=Db::name("user_video")->where("id={$id}")->update($data);
- if($result!==false){
- //将视频喜欢列表的状态更改
- Db::name("user_video_like")->where("videoid={$id}")->update(['status'=>0]);
- //将视频喜欢列表的状态更改
- Db::name("user_video_view")->where("videoid={$id}")->update(['status'=>0]);
- //将点赞信息列表里的状态修改
- Db::name("praise_messages")->where("videoid={$id}")->update(['status'=>0]);
- //将评论@信息列表的状态更改
- Db::name("user_video_comments_at_messages")->where("videoid={$id}")->update(['status'=>0]);
- //将评论信息列表的状态更改
- Db::name("user_video_comments_messages")->where("videoid={$id}")->update(['status'=>0]);
- //将视频收藏状态更改
- Db::name("user_video_collection")->where("videoid={$id}")->update(['status'=>0]);
- //更新此视频的举报信息
- $data1=array(
- 'status'=>1,
- 'uptime'=>time()
- );
- Db::name("user_video_report")->where("videoid={$id}")->update($data1);
- $uid=$videoInfo['uid'];
- if($videoInfo['title']!=''){
- $videoTitle='上传的《'.$videoInfo['title'].'》';
- }else{
- $videoTitle='上传的';
- }
- $baseMsg='您于'.date("Y-m-d H:i:s",$videoInfo['addtime']).$videoTitle.'视频被管理员于'.date("Y-m-d H:i:s",time()).'下架';
- if(!$reason){
- $msg=$baseMsg;
- }else{
- $msg=$baseMsg.',下架原因为:'.$reason;
- }
- $text="视频下架提醒";
- $result1=addSysytemInfo($uid,$text,$msg);
- if($result1!==false){
- //发送腾讯云IM
- txMessageIM($text,$uid);
- }
- //处理视频热门
- $this->changeVideoPopular($id,$videoInfo['p_nums'],1);
- echo json_encode($res);
- return;
- }else{
- $res['code']=1002;
- $res['msg']="下架失败";
- echo json_encode($res);
- return;
- }
-
- }
- /*下架视频列表*/
- public function lowervideo(){
-
- $ordertype = $this->request->param('ordertype');
-
- $orderstr="";
- if($ordertype==1){//评论数排序
- $orderstr="comments DESC";
- }else if($ordertype==2){//票房数量排序(点赞)
- $orderstr="likes DESC";
- }else if($ordertype==3){//分享数量排序
- $orderstr="shares DESC";
- }else{
- $orderstr="addtime DESC";
- }
- $lists = Db::name('user_video')
- ->where(function (Query $query) {
- $data = $this->request->param();
- $query->where('isdel', 1);
- $query->where('is_ad', 0);
- $query->where('is_userad', 0);
- $classid=isset($data['classid']) ? $data['classid']: '';
- $keyword=isset($data['keyword']) ? $data['keyword']: '';
- $keyword1=isset($data['keyword1']) ? $data['keyword1']: '';
- $keyword2=isset($data['keyword2']) ? $data['keyword2']: '';
-
- if (!empty($classid)) {
- $query->where('classid', '=', $classid);
- }
- if (!empty($keyword)) {
- $query->where('uid|id', 'like', "%$keyword%");
- }
-
- if (!empty($keyword1)) {
- $query->where('title', 'like', "%$keyword1%");
- }
-
- if (!empty($keyword2)) {
-
- $userlist =Db::name("user")
- ->field("id")
- ->where("user_nickname like '%".$keyword2."%'")
- ->select();
- $strids="";
- $userlist->all();
- foreach ($userlist as $k => $vu) {
- if($strids==""){
- $strids=$vu['id'];
- }else{
- $strids.=",".$vu['id'];
- }
- }
- $query->where('uid', 'in', $strids);
- }
- })
- ->order($orderstr)
- ->paginate(20);
-
-
- $lists->each(function($v,$k){
- if($v['uid']==0){
- $userinfo=array(
- 'user_nickname'=>'系统管理员'
- );
- }else{
- $userinfo=getUserInfo($v['uid']);
- if(!$userinfo){
- $userinfo=array(
- 'user_nickname'=>'已删除'
- );
- }
-
- }
-
- $v['userinfo']=$userinfo;
- $v['thumb']=get_upload_path($v['thumb']);
- if($v['classid']){
- $v['class_name']=$this->getVideoClass($v['classid']);
- }else{
- $v['class_name']='';
- }
- if($v['activeid']){
- $subject = Db::name('author_center_activity')
- ->where(['id'=>$v['activeid']])
- ->value('subject');
- if($subject){
- $subject_arr = json_decode($subject,true);
- $v['activity_subject'] = '#'.implode('#',$subject_arr);
- }else{
- $v['activity_subject'] = '';
- }
- }else{
- $v['activity_subject']='';
- }
-
- return $v;
-
- });
-
- //分页-->筛选条件参数
- $data = $this->request->param();
- $lists->appends($data);
-
- // 获取分页显示
- $page = $lists->render();
-
- $p= $this->request->param('page');
- if(!$p){
- $p=1;
- }
- $classify=$this->getClassLists();
- $this->assign("classify",$classify);
- $this->assign('lists', $lists);
- $this->assign("page", $page);
- $this->assign("p",$p);
- $this->assign("time",time());
- $this->assign("name_coin",$this->name_coin);
- return $this->fetch();
- }
- public function video_listen(){
- $id = $this->request->param('id', 0, 'intval');
- if(!$id||$id==""||!is_numeric($id)){
- $this->error("加载失败");
- }else{
- //获取音乐信息
- $info=Db::name("user_video")->where("id={$id}")->find();
- $info['thumb']=get_upload_path($info['thumb']);
- $info['href']=get_upload_path($info['href']);
- $this->assign("info",$info);
- }
- return $this->fetch();
- }
- /*视频上架*/
- public function set_shangjia(){
- $id = $this->request->param('id', 0, 'intval');
- if(!$id){
- $this->error("视频信息加载失败");
- }
- //获取视频信息
- $info=Db::name("user_video")->where("id={$id}")->find();
- if(!$info){
- $this->error("视频信息加载失败");
- }
- $data=array(
- 'xiajia_reason'=>'',
- 'isdel'=>0
- );
- $result=Db::name("user_video")->where("id={$id}")->update($data);
- if($result!==false){
- //将视频喜欢列表的状态更改
- Db::name("user_video_like")->where("videoid={$id}")->update(['status'=>1]);
-
- //将视频观看列表的状态更改
- Db::name("user_video_view")->where("videoid={$id}")->update(['status'=>1]);
- //将点赞信息列表里的状态修改
- Db::name("praise_messages")->where("videoid={$id}")->update(['status'=>1]);
- //将评论@信息列表的状态更改
- Db::name("user_video_comments_at_messages")->where("videoid={$id}")->update(['status'=>1]);
- //将评论信息列表的状态更改
- Db::name("user_video_comments_messages")->where("videoid={$id}")->update(['status'=>1]);
- //将视频收藏状态更改
- Db::name("user_video_collection")->where("videoid={$id}")->update(['status'=>1]);
- $this->success("上架成功");
- }
- return $this->fetch();
- }
-
-
- //评论列表
- public function commentlists(){
-
- $data = $this->request->param();
- $videoid=$data['videoid'];
-
- $lists = Db::name('user_video_comments')
- ->where("videoid={$videoid}")
- ->order("addtime DESC")
- ->paginate(20);
-
-
- $lists->each(function($v,$k){
-
- $userinfo=getUserInfo($v['uid']);
- if(!$userinfo){
- $userinfo=array(
- 'user_nickname'=>'已删除'
- );
- }
- $v['user_nickname']=$userinfo['user_nickname'];
- if($v['voice']){
- $v['voice']=get_upload_path($v['voice']);
- }
-
- return $v;
-
- });
-
- //分页-->筛选条件参数
- $lists->appends($data);
- // 获取分页显示
- $page = $lists->render();
- $this->assign("lists",$lists);
- $this->assign("page", $page);
- return $this->fetch();
- }
-
- public function commentlists_del(){
- $data = $this->request->param();
-
- $id = $data['id']; //获取删除id
-
- $info=Db::name('user_video_comments')->where("id={$id}")->find();
- if(!$info){
- $this->error("删除失败!");
- }
- Db::name('user_video_comments')->where("id={$id}")->delete();
- Db::name('user_video_comments_like')->where("commentid={$id}")->delete();
- Db::name('user_video')
- ->where("id={$info['videoid']} and comments>=1")
- ->dec('comments','1')
- ->update();
-
- $this->success("删除成功","video/commentlists?videoid={$info['videoid']}" );
-
- }
-
-
-
- private function getClassLists(){
- //获取视频分类
- $classify=Db::name("user_video_class")->where("status=1")->order("orderno")->select();
- return $classify;
- }
- //批量下架
- public function setBatchXiajia(){
- $data = $this->request->param();
- $status=$data['status'];
- $ids = $data['ids'];
- if(empty($ids)){
- $this->error("请选择列表");
- }
- foreach ($ids as $k => $v) {
-
- $id=$v;
-
- //获取视频详情
- $videoInfo=Db::name("user_video")->where("id={$id}")->find();
- if(!$videoInfo){
- continue;
- }
- $update_data=array(
- 'isdel'=>$status
- );
- $result=Db::name("user_video")->where("id={$id}")->update($update_data);
- if($result!==false){
- //将视频喜欢列表的状态更改
- Db::name("user_video_like")->where("videoid={$id}")->update(['status'=>0]);
- //将视频喜欢列表的状态更改
- Db::name("user_video_view")->where("videoid={$id}")->update(['status'=>0]);
- //将点赞信息列表里的状态修改
- Db::name("praise_messages")->where("videoid={$id}")->update(['status'=>0]);
- //将评论@信息列表的状态更改
- Db::name("user_video_comments_at_messages")->where("videoid={$id}")->update(['status'=>0]);
- //将评论信息列表的状态更改
- Db::name("user_video_comments_messages")->where("videoid={$id}")->update(['status'=>0]);
- //将视频收藏状态更改
- Db::name("user_video_collection")->where("videoid={$id}")->update(['status'=>0]);
- //更新此视频的举报信息
- $data1=array(
- 'status'=>1,
- 'uptime'=>time()
- );
- Db::name("user_video_report")->where("videoid={$id}")->update($data1);
- $uid=$videoInfo['uid'];
- if($videoInfo['title']!=''){
- $videoTitle='上传的《'.$videoInfo['title'].'》';
- }else{
- $videoTitle='上传的';
- }
- $baseMsg='您于'.date("Y-m-d H:i:s",$videoInfo['addtime']).$videoTitle.'视频被管理员于'.date("Y-m-d H:i:s",time()).'下架';
- $text="视频下架提醒";
- $result1=addSysytemInfo($uid,$text,$baseMsg);
- if($result1!==false){
- //发送腾讯云IM
- txMessageIM($text,$uid);
- }
- //处理视频热门
- $this->changeVideoPopular($id,$videoInfo['p_nums'],1);
- }
- }
- $this->success("操作成功!");
- }
- //批量删除
- public function setBatchDel(){
- $data = $this->request->param();
- $ids = $data['ids'];
- if(empty($ids)){
- $this->error("请选择列表");
- }
- foreach ($ids as $k => $v) {
- $id=$v;
- //获取视频信息
- $videoInfo=Db::name("user_video")->where("id={$id}")->find();
- $result=Db::name("user_video")->where("id={$id}")->delete();
-
- if($result!==false){
- Db::name("user_video_comments_at_messages")->where("videoid={$id}")->delete(); //删除视频评论@信息列表
- Db::name("user_video_comments_messages")->where("videoid={$id}")->delete(); //删除视频评论信息列表
- Db::name("praise_messages")->where("videoid={$id}")->delete(); //删除赞通知列表
- Db::name("user_video_comments")->where("videoid={$id}")->delete(); //删除视频评论
- Db::name("user_video_like")->where("videoid={$id}")->delete(); //删除视频喜欢
- Db::name("user_video_report")->where("videoid={$id}")->delete(); //删除视频举报
- Db::name("user_video_view")->where("videoid={$id}")->delete(); //删除视频观看
- Db::name("user_video_comments_like")->where("videoid={$id}")->delete(); //删除视频评论喜欢
- if($videoInfo['isdel']==0){ //视频上架情况下被删除发送通知
-
- $uid=$videoInfo['uid'];
- if($videoInfo['title']!=''){
- $videoTitle='上传的《'.$videoInfo['title'].'》';
- }else{
- $videoTitle='上传的';
- }
- $baseMsg='您于'.date("Y-m-d H:i:s",$videoInfo['addtime']).$videoTitle.'视频被管理员于'.date("Y-m-d H:i:s",time()).'删除';
- $text="视频删除提醒";
- $result1=addSysytemInfo($uid,$text,$baseMsg);
- if($result1!==false){
- //发送腾讯云IM
- txMessageIM($text,$uid);
- }
- }
- //处理视频热门
- $this->changeVideoPopular($id,$videoInfo['p_nums'],0);
-
- }
- }
- $this->success("操作成功!");
- }
- //批量审核 通过/不通过
- public function setBatchStatus(){
- $data=$this->request->param();
- $status=$data['status'];
- $ids=$data['ids'];
- if(empty($ids)){
- $this->error("请选择列表");
- }
- foreach ($ids as $k => $v) {
- $post_data=array(
- 'status'=>$status
- );
- if($status==2){
- $post_data['nopass_time']=time();
- }
- $id=$v;
- $videoInfo=Db::name("user_video")->where("id={$id}")->find();
-
- $result=Db::name("user_video")->where("id={$id}")->update($post_data);
- if($result!==false){
- if($status==2){ //如果该视频状态改为不通过,需要将视频喜欢列表的状态更改
- Db::name("user_video_like")->where("videoid={$id}")->update(['status'=>0]);
- Db::name("user_video_view")->where("videoid={$id}")->update(['status'=>0]);
- }
-
- if($status==2&&$videoInfo['nopasstime']==0){ //视频状态为审核不通过且为第一次审核为不通过,发送极光IM
- $uid=$videoInfo['uid'];
- if($videoInfo['title']!=''){
- $videoTitle='上传的《'.$videoInfo['title'].'》';
- }else{
- $videoTitle='上传的';
- }
- $baseMsg='您于'.date("Y-m-d H:i:s",$videoInfo['addtime']).$videoTitle.'视频被管理员于'.date("Y-m-d H:i:s",time()).'审核为不通过';;
- $text="视频未审核通过提醒";
- $result1=addSysytemInfo($uid,$text,$baseMsg);
- if($result1!==false){
- //发送腾讯云IM
- txMessageIM($text,$uid);
- }
- }
-
- }
- }
- $this->success('修改成功');
- }
- //处理热门视频 type 处理类型 1要更新视频的热门信息 0不处理
- public function changeVideoPopular($videoid,$pnums,$type){
- //如果该视频正在上热门,将上热门剩余的钻石退回
- $popinfo=Db::name("popular_orders")->where("videoid={$videoid} and status=1 and refund_status=0")->field("id,uid,touid,money,nums")->find();
- if($popinfo){
- if($popinfo['nums']){
- $coin=$pnums/$popinfo['nums']*$popinfo['money'];
- $coin=floor($coin);
- if($coin>=1){
- $isok=changeUserCoin($popinfo['uid'],$coin,1);
- if($isok){
- $data=array(
- 'type'=>'income',
- 'action'=>'pop_refund',
- 'uid'=>$popinfo['touid'], //视频发布者
- 'touid'=>$popinfo['uid'], //花钱帮助上热门用户的id
- 'totalcoin'=>$coin,
- 'videoid'=>$videoid,
- 'addtime'=>time()
- );
- //写入钻石消费记录
- setCoinRecord($data);
- if($type){
- //更新视频的热门信息
- $data1=array(
- 'p_expire'=>0,
- 'p_nums'=>0,
- 'p_add'=>0
- );
- Db::name("user_video")->where("id={$videoid}")->update($data1);
- }
-
- }
- }
- //将上热门记录的退款状态修改一下
- Db::name("popular_orders")->where("id={$popinfo['id']}")->update(["refund_status"=>1]);
- }
- }
-
- }
- //批量上架
- public function setBatchShelves(){
- $data = $this->request->param();
- $ids = $data['ids'];
- if(empty($ids)){
- $this->error("请选择列表");
- }
-
- foreach ($ids as $k => $v) {
- $id=$v;
- $arr=array(
- 'xiajia_reason'=>'',
- 'isdel'=>0
- );
- $result=Db::name("user_video")->where("id={$id}")->update($arr);
-
- if($result!==false){
- //将视频喜欢列表的状态更改
- Db::name("user_video_like")->where("videoid={$id}")->update(['status'=>1]);
-
- //将视频观看列表的状态更改
- Db::name("user_video_view")->where("videoid={$id}")->update(['status'=>1]);
- //将点赞信息列表里的状态修改
- Db::name("praise_messages")->where("videoid={$id}")->update(['status'=>1]);
- //将评论@信息列表的状态更改
- Db::name("user_video_comments_at_messages")->where("videoid={$id}")->update(['status'=>1]);
- //将评论信息列表的状态更改
- Db::name("user_video_comments_messages")->where("videoid={$id}")->update(['status'=>1]);
- //将视频收藏状态更改
- Db::name("user_video_collection")->where("videoid={$id}")->update(['status'=>1]);
-
- }
- }
- $this->success("操作成功!");
- }
- }
|