function.php 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. <?php
  2. require_once '../path.php';
  3. require_once "../share/function.php";
  4. class CollectInfo
  5. {
  6. private $dbh;
  7. private $buffer;
  8. private $_redis;
  9. public function __construct($redis=false) {
  10. $dns = ""._FILE_DB_USER_ARTICLE_;
  11. $this->dbh = new PDO($dns, "", "",array(PDO::ATTR_PERSISTENT=>true));
  12. $this->dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_WARNING);
  13. $this->_redis=$redis;
  14. $buffer = array();
  15. }
  16. public function get($id){
  17. if(empty($id)){
  18. return array("title"=>"","id"=>"");
  19. }
  20. if(isset($buffer[$id])){
  21. return $buffer[$id];
  22. }
  23. if($this->dbh){
  24. $query = "SELECT id,title,owner,status,lang FROM collect WHERE id= ?";
  25. $stmt = $this->dbh->prepare($query);
  26. $stmt->execute(array($id));
  27. $collect = $stmt->fetch(PDO::FETCH_ASSOC);
  28. if($collect){
  29. $buffer[$id] = $collect;
  30. return $buffer[$id];
  31. }
  32. else{
  33. $buffer[$id] =false;
  34. return $buffer[$id];
  35. }
  36. }
  37. else{
  38. $buffer[$id] = false;
  39. return $buffer[$id];
  40. }
  41. }
  42. public function getArticleList($id){
  43. if(empty($id)){
  44. return array();
  45. }
  46. if($this->dbh){
  47. $query = "SELECT article_id FROM article_list WHERE collect_id= ? limit 0,1000";
  48. $stmt = $this->dbh->prepare($query);
  49. $stmt->execute(array($id));
  50. $article_list = $stmt->fetchAll(PDO::FETCH_ASSOC);
  51. $output=array();
  52. foreach ($article_list as $key => $value) {
  53. # code...
  54. $output[]=$value["article_id"];
  55. }
  56. return $output;
  57. }
  58. else{
  59. return array();
  60. }
  61. }
  62. public function getPower($id){
  63. #查询用户对此是否有权限
  64. if(isset($_COOKIE["userid"])){
  65. $userId = $_COOKIE["userid"];
  66. }
  67. else{
  68. $userId='0';
  69. }
  70. if($this->_redis!==false){
  71. $power = $this->_redis->hGet("power://collection/".$id,$userId);
  72. if($power!==FALSE){
  73. return $power;
  74. }
  75. }
  76. $iPower = 0;
  77. $query = "SELECT owner,status FROM collect WHERE id=? ";
  78. $stmt = $this->dbh->prepare($query);
  79. $stmt->execute(array($id));
  80. $result = $stmt->fetch(PDO::FETCH_ASSOC);
  81. if($result){
  82. if(!isset($_COOKIE["userid"])){
  83. #未登录用户
  84. if($result["status"]==30){
  85. #全网公开有读取和建议权限
  86. return 10;
  87. }
  88. else{
  89. #其他状态没有任何权限
  90. return 0;
  91. }
  92. }
  93. else{
  94. if($result["owner"]==$_COOKIE["userid"]){
  95. #自己的
  96. return 30;
  97. }
  98. else if($result["status"]>=30){
  99. #全网公开的 可以提交pr
  100. $iPower = 10;
  101. }
  102. }
  103. #查询共享权限,如果共享权限更大,覆盖上面的的
  104. $sharePower = share_get_res_power($userId,$id);
  105. if($sharePower>$iPower){
  106. $iPower=$sharePower;
  107. }
  108. $this->_redis->hSet("power://collection/".$id,$userId,$iPower);
  109. }
  110. return $iPower;
  111. }
  112. }
  113. ?>