BaseController.class.php 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. <?php
  2. namespace Home\Controller;
  3. use Think\Controller;
  4. class BaseController extends Controller {
  5. public function message($msg , $redirect = ''){
  6. $this->assign("msg" , $msg);
  7. $this->assign("redirect" , $redirect);
  8. $this->display ("Common/message");
  9. }
  10. public function checkLogin($redirect = true){
  11. if ( ! session("login_user")) {
  12. $cookie_token = cookie('cookie_token');
  13. if ($cookie_token) {
  14. $ret = D("User")->where("cookie_token = '%s' ",array($cookie_token))->find();
  15. if ($ret && $ret['cookie_token_expire'] > time() ) {
  16. $login_user = $ret ;
  17. session("login_user" , $login_user);
  18. return $login_user ;
  19. }
  20. }
  21. if ($redirect) {
  22. $this->message("你尚未登录!",U('Home/User/login'));
  23. exit();
  24. }
  25. }else{
  26. return session("login_user") ;
  27. }
  28. }
  29. /**
  30. * 返回json数据
  31. */
  32. public function sendResult($array){
  33. if (isset($array['error_code'])) {
  34. $result['error_code'] = $array['error_code'] ;
  35. $result['error_message'] = $array['error_message'] ;
  36. }
  37. else{
  38. $result['error_code'] = 0 ;
  39. $result['data'] = $array ;
  40. }
  41. echo json_encode($result);
  42. }
  43. //判断某用户是否有项目管理权限(项目成员和项目创建者)
  44. protected function checkItemPermn($uid , $item_id){
  45. if (!$uid) {
  46. return false;
  47. }
  48. if (session("mamage_item_".$item_id)) {
  49. return true;
  50. }
  51. $item = D("Item")->where("item_id = '%d' ",array($item_id))->find();
  52. if ($item['uid'] && $item['uid'] == $uid) {
  53. session("mamage_item_".$item_id , 1 );
  54. return true;
  55. }
  56. $ItemMember = D("ItemMember")->where("item_id = '%d' and uid = '%d' ",array($item_id,$uid))->find();
  57. if ($ItemMember) {
  58. session("mamage_item_".$item_id , 1 );
  59. return true;
  60. }
  61. return false;
  62. }
  63. //判断某用户是否为项目创建者
  64. protected function checkItemCreator($uid , $item_id){
  65. if (!$uid) {
  66. return false;
  67. }
  68. if (session("creat_item_".$item_id)) {
  69. return true;
  70. }
  71. $item = D("Item")->where("item_id = '%d' ",array($item_id))->find();
  72. if ($item['uid'] && $item['uid'] == $uid) {
  73. session("creat_item_".$item_id , 1 );
  74. return true;
  75. }
  76. return false;
  77. }
  78. //判断某用户是否有项目访问权限(公开项目的话所有人可访问,私有项目则项目成员、项目创建者和访问密码输入者可访问)
  79. protected function checkItemVisit($uid , $item_id){
  80. if (session("visit_item_".$item_id)) {
  81. return true;
  82. }
  83. if ($this->checkItemPermn($uid , $item_id)) {
  84. return true;
  85. }
  86. $item = D("Item")->where("item_id = '%d' ",array($item_id))->find();
  87. if ($item['password']) {
  88. //跳转到输入访问密码框
  89. header("location:".U("Home/item/pwd").'?item_id='.$item_id);
  90. }else{
  91. session("visit_item_".$item_id , 1 );
  92. return true;
  93. }
  94. }
  95. }