cf-platform/Application/Media/Controller/SelfbuiltController.class.php

232 lines
9.4 KiB
PHP

<?php
namespace Media\Controller;
use Think\Controller;
use Common\Api\GameApi;
use Admin\Model\GameModel;
class SelfbuiltController extends BaseController
{
private $model_name = 'selfbuit';
public function __construct()
{
parent::__construct();
if($_REQUEST['gid']!=""){
$_REQUEST['game_id']=$_REQUEST['gid'];
}elseif($_REQUEST['game_id']!=""){
$_REQUEST['gid']=$_REQUEST['game_id'];
}
$game = new GameModel();
$selftbuilt = M("Selfbuilt")->where(['gameid' => $_REQUEST['gid']])->order('id desc')->find();
if (empty($selftbuilt)) $this->redirect('Index/index');
$selftbuilt = M("Selfbuilt")->where(['gameid' => $_REQUEST['gid']])->order('id desc')->find();
$selftbuilt['gpic'] = explode(',', $selftbuilt['screenshots']);
$selftbuilt['gshuffling'] = explode(',', $selftbuilt['shuffling']);
$info=$game->detail($_REQUEST['gid']);
if($selftbuilt['wei_url']==0)$selftbuilt['wei_url']=$info['wei_url'];
$this->assign("selftbuilt", $selftbuilt);
$this->assign('data', $info);
$map['game_id']=$info['and_id'];
$and_server=M('server','tab_')->field('id,server_name,start_time')->where($map)->order('id desc')->select();
$map['game_id']=$info['ios_id'];
$ios_server=M('server','tab_')->field('id,server_name,start_time')->where($map)->order('id desc')->select();
$this->assign('and_server',$and_server);
$this->assign('ios_server',$ios_server);
$this->assign('gamesou',get_game_source($info['and_id'],$info['ios_id']));
$hot_game_and = M('game','tab_')->field('id,relation_game_name')->where(array('game_status'=>1,'recommend_status'=>2,'sdk_version'=>1))->order('id desc')->limit(6)->select();
$hot_game_ios = M('game','tab_')->field('id,relation_game_name')->where(array('game_status'=>1,'recommend_status'=>1,'sdk_version'=>1))->order('id desc')->limit(6)->select();
$this->assign('hot_game_and', $hot_game_and);
$this->assign('hot_game_ios', $hot_game_ios);
}
/*游戏管理*/
public function game($game_id = 0)
{
$doc = D('Document');
$map['game_id']=$game_id;
$server=M('server','tab_')->field('id,server_name,server_status,game_id,server_name,server_status,start_time')->where($map)->order('id desc')->find();
$this->assign('serverss',$server);
$self_id = get_self_id($game_id);
$this->assign('grole', $doc->game_index_doc('game_int', $self_id, 6));//角色
$this->assign('newest', $doc->game_index_doc('game_guide', $self_id, 6));//游戏攻略/最新
$this->assign('news', $doc->game_index_doc('game_news', $self_id, 6));//游戏公告/新闻
$this->assign('active', $doc->game_index_doc('game_act', $self_id, 6));//游戏活动
$this->assign('novice_guide', $doc->game_index_doc('game_novice', $self_id, 6));//新手
$this->assign('master', $doc->game_index_doc('game_master', $self_id, 6));//高手进价
$this->assign('features', $doc->game_index_doc('game_character', $self_id, 6));//特色系统
$this->display();
}
public function weiduan($game_id){
$map['sys_document.display'] = 1;
$map['sys_document.status'] = 1;
$map['category_id']=51;
$map['self_id']=get_self_id($game_id);
$data = M('document')
->field('sys_document.id,sys_category.id as cid,sys_document.title,sys_category.title as ctitle')
->join('sys_category on sys_category.id = sys_document.category_id')
->join('sys_document_special on sys_document.id = sys_document_special.id')
->where($map)
->order('sys_document.create_time,level desc')
->limit($limit)
->select();
$this->assign('doc',$data);
$this->assign('game_idd',$game_id);//斗破
$this->assign('user_id',session('user_auth.uid'));
$this->display();
}
public function servers($game_id){
$map['game_id']=$game_id;
$area=M('server','tab_')->where($map)->order('start_time desc')->select();
$maps['a.game_id']=$game_id;
$maps['user_id']=session('user_auth.user_id');
$login_rec=M('user_login_record','tab_')
->field('a.server_name,a.docking_server_id,a.id,tab_user_login_record.*')
->join('tab_server as a on a.id=tab_user_login_record.server_id')
->where($maps)
->order('a.start_time desc')
->group('a.id')
->limit(2)
->select();
$this->assign('area',$area);
$this->assign('login_rec',$login_rec);
$this->display();
}
public function getlists($name, $self_id, $p, $order = "d.id desc")
{
$time = time();
$model['model'] = "Document";
$model['table'] = "__DOCUMENT__ as d";
$model['field'] = "d.id,d.title,d.link_id,d.cover_id,d.name,d.create_time,ds.self_id,ds.content,c.title as ctitle,c.id as pid,c.name as cname";
$model['join'] = "__DOCUMENT_SPECIAL__ as ds on (d.id = ds.id and ds.self_id=$self_id )";
$model['joinnum'] = "right";
$model['join1'] = "__CATEGORY__ as c on (c.id=d.category_id and c.name like '$name' )";
$model['joinnum1'] = "right";
$model['where'] = "d.status>0 and d.display=1 and d.create_time<$time and (d.deadline =0 or d.deadline > $time) ";
$model['order'] = $order;
parent::glists($model, $p);
}
public function lists($cid=1, $game_id, $p = 1){
/* 1>新闻公告 2>攻略 3>新手指南 4>游戏资料 5>高手进阶 6>特色 7>活动 8>角色 */
$cat = ['1'=>['name'=>'game_news','desc'=>'新闻'],
'2'=>['name'=>'game_guide','desc'=>'攻略'],
'3'=>['name'=>'game_novice','desc'=>'新手'],
'4'=>['name'=>'game_data','desc'=>'资料'],
'5'=>['name'=>'game_master','desc'=>'进阶'],
'6'=>['name'=>'game_character','desc'=>'特色'],
'7'=>['name'=>'game_act','desc'=>'活动'],
'8'=>['name'=>'game_int','desc'=>'角色'],
];
$cat_name = $cat[$cid]['name'];
$this->assign('cid',$cid);
$this->assign('cat',$cat);
$category = M("category")->where(['name'=>$cat_name])->find();
$map['category_id'] = $category['id'];
$map['self_id']=get_self_id($game_id);
$map['display']=1;
$map['status']=1;
$mode = [
'table' => 'document',
'pre'=>'sys_',
'map'=>$map,
'join' => 'sys_document_special on sys_document_special.id=sys_document.id',
'order'=>'create_time desc,level desc',
'tep'=>'lists'
];
$this->lists_page($mode,$p);
}
public function detail($id, $game_id = 0)
{
$cat = ['game_news'=>['cid'=>'1','desc'=>'新闻'],
'game_guide'=>['cid'=>'2','desc'=>'攻略'],
'game_novice'=>['cid'=>'3','desc'=>'新手'],
'game_data'=>['cid'=>'4','desc'=>'资料'],
'game_master'=>['cid'=>'5','desc'=>'进阶'],
'game_character'=>['cid'=>'6','desc'=>'特色'],
'game_act'=>['cid'=>'7','desc'=>'活动'],
'game_int'=>['cid'=>'8','desc'=>'角色'],
];
$doc = D('Document');
$detail = $doc->game_detail($id);
$this->assign('detail', $detail);
$map['category_id'] = $detail['category_id'];
$map['self_id']=$detail['self_id'];
$map['display']=1;
$map['status']=1;
$map['sys_document.id']=['gt',$id];
$data = D('Document')
->field('sys_document.id,sys_document.title')
->join('sys_document_special on sys_document.id = sys_document_special.id')
->where($map)
->order('create_time desc,level desc')
->find();
$this->assign('next', $data);
$cate_name = M("category")->field('name,title')->find($detail['category_id']);
$this->assign('cate_name', $cate_name['title']);
$this->assign('cid', $cat[$cate_name['name']]['cid']);
$this->assign('game_id', $game_id);
$this->display();
}
public function server($game_id, $p = 1)
{
$map['game_id']=$game_id;
$map['show_status']=1;
$map['stop_status']=1;
$mode = [
'table' => 'Server',
'pre'=>'tab_',
'map'=>$map,
'order'=>'start_time desc',
'tep'=>'server'
];
$map['recommend_status']=1;
$lists=M('Server','tab_')->where($map)->order('start_time desc')->limit(9)->select();
$this->assign('tui',$lists);
$this->lists_page($mode,$p);
}
public function error()
{
$game_id = $_REQUEST['game_id'];
$area_id = $_REQUEST['area_id'];
$time = time();
$area = D('Server');
$result = $area->table("__SERVER__ as a")
->field('a.*')
->limit(1)
->where("a.game_id=$game_id and a.id=$area_id")
->order("a.start_time desc")->select();
$data = $result[0];
$this->assign('data', $data);
$result = $area->table("__SERVER__ as a")
->field('a.*')
->limit(4)
->where("a.game_id=$game_id and a.start_time<$time")
->order("a.start_time desc")->select();
$this->assign('area', $result);
$this->display();
}
}
?>