You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
123 lines
3.3 KiB
123 lines
3.3 KiB
<?php
|
|
namespace Home\Controller;
|
|
use Think\Controller;
|
|
class BaseController extends Controller {
|
|
|
|
public function message($msg , $redirect = ''){
|
|
$this->assign("msg" , $msg);
|
|
$this->assign("redirect" , $redirect);
|
|
$this->display ("Common/message");
|
|
}
|
|
|
|
public function checkLogin($redirect = true){
|
|
if (strtolower(C("DB_TYPE")) == 'mysql' ) {
|
|
echo 'ShowDoc does not support mysql any more . https://www.showdoc.cc/help?page_id=31990 ';
|
|
clear_runtime();
|
|
exit();
|
|
}
|
|
if ( ! session("login_user")) {
|
|
$cookie_token = cookie('cookie_token');
|
|
if ($cookie_token) {
|
|
$ret = D("UserToken")->getToken($cookie_token);
|
|
if ($ret && $ret['token_expire'] > time() ) {
|
|
$login_user = D("User")->where("uid = $ret[uid]")->find();
|
|
unset($ret['password']);
|
|
session("login_user" , $login_user);
|
|
return $login_user ;
|
|
}
|
|
}
|
|
if ($redirect) {
|
|
$this->message("你尚未登录!",U('Home/User/login'));
|
|
exit();
|
|
}
|
|
}else{
|
|
return session("login_user") ;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 返回json数据
|
|
*/
|
|
public function sendResult($array){
|
|
if (isset($array['error_code'])) {
|
|
$result['error_code'] = $array['error_code'] ;
|
|
$result['error_message'] = $array['error_message'] ;
|
|
}
|
|
else{
|
|
$result['error_code'] = 0 ;
|
|
$result['data'] = $array ;
|
|
}
|
|
echo json_encode($result);
|
|
}
|
|
|
|
//判断某用户是否有项目管理权限(项目成员member_group_id为1,以及 项目创建者)
|
|
protected function checkItemPermn($uid , $item_id){
|
|
|
|
if (!$uid) {
|
|
return false;
|
|
}
|
|
|
|
if (session("mamage_item_".$item_id)) {
|
|
return true;
|
|
}
|
|
|
|
$item = D("Item")->where("item_id = '%d' ",array($item_id))->find();
|
|
if ($item['uid'] && $item['uid'] == $uid) {
|
|
session("mamage_item_".$item_id , 1 );
|
|
return true;
|
|
}
|
|
$ItemMember = D("ItemMember")->where("item_id = '%d' and uid = '%d' and member_group_id = 1 ",array($item_id,$uid))->find();
|
|
if ($ItemMember) {
|
|
session("mamage_item_".$item_id , 1 );
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
//判断某用户是否为项目创建者
|
|
protected function checkItemCreator($uid , $item_id){
|
|
if (!$uid) {
|
|
return false;
|
|
}
|
|
if (session("creat_item_".$item_id)) {
|
|
return true;
|
|
}
|
|
|
|
$item = D("Item")->where("item_id = '%d' ",array($item_id))->find();
|
|
if ($item['uid'] && $item['uid'] == $uid) {
|
|
session("creat_item_".$item_id , 1 );
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
//判断某用户是否有项目访问权限(公开项目的话所有人可访问,私有项目则项目成员、项目创建者和访问密码输入者可访问)
|
|
protected function checkItemVisit($uid , $item_id, $refer_url= ''){
|
|
if (session("visit_item_".$item_id)) {
|
|
return true;
|
|
}
|
|
|
|
if ($this->checkItemCreator($uid , $item_id)) {
|
|
session("visit_item_".$item_id , 1 );
|
|
return true;
|
|
}
|
|
|
|
$ItemMember = D("ItemMember")->where("item_id = '%d' and uid = '%d' ",array($item_id,$uid))->find();
|
|
if ($ItemMember) {
|
|
session("visit_item_".$item_id , 1 );
|
|
return true;
|
|
}
|
|
|
|
$item = D("Item")->where("item_id = '%d' ",array($item_id))->find();
|
|
if ($item['password']) {
|
|
//跳转到输入访问密码框
|
|
header("location:".U("Home/item/pwd",array("item_id"=>$item_id,"refer_url"=>base64_encode($refer_url))));
|
|
}else{
|
|
session("visit_item_".$item_id , 1 );
|
|
return true;
|
|
}
|
|
|
|
}
|
|
|
|
|
|
}
|