function.php 3.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. <?php
  2. require_once "../path.php";
  3. require_once "../share/function.php";
  4. class Article
  5. {
  6. private $dbh;
  7. private $_redis;
  8. public function __construct($redis=false) {
  9. $this->dbh = new PDO(_FILE_DB_USER_ARTICLE_, "", "",array(PDO::ATTR_PERSISTENT=>true));
  10. $this->dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_WARNING);
  11. $this->_redis=$redis;
  12. }
  13. public function getInfo($id){
  14. $output = array();
  15. if($this->_redis!==false){
  16. if($this->_redis->exists("article://info/".$id)===1){
  17. $output["title"]=$this->_redis->hGet("article://info/".$id,"title");
  18. $output["owner"]=$this->_redis->hGet("article://info/".$id,"owner");
  19. $output["summary"]=$this->_redis->hGet("article://info/".$id,"summary");
  20. $output["status"]=$this->_redis->hGet("article://info/".$id,"status");
  21. $output["create_time"]=$this->_redis->hGet("article://info/".$id,"create_time");
  22. $output["modify_time"]=$this->_redis->hGet("article://info/".$id,"modify_time");
  23. return $output;
  24. }
  25. }
  26. $query = "SELECT title,owner,summary,status,create_time,modify_time FROM article WHERE id= ? ";
  27. $stmt = $this->dbh->prepare($query);
  28. $stmt->execute(array($id));
  29. $output = $stmt->fetch(PDO::FETCH_ASSOC);
  30. if($output){
  31. if($this->_redis!==false){
  32. $this->_redis->hSet("article://info/".$id,"title",$output["title"]);
  33. $this->_redis->hSet("article://info/".$id,"owner",$output["owner"]);
  34. $this->_redis->hSet("article://info/".$id,"summary",$output["summary"]);
  35. $this->_redis->hSet("article://info/".$id,"status",$output["status"]);
  36. $this->_redis->hSet("article://info/".$id,"create_time",$output["create_time"]);
  37. $this->_redis->hSet("article://info/".$id,"modify_time",$output["modify_time"]);
  38. }
  39. return $output;
  40. }
  41. else{
  42. return false;
  43. }
  44. }
  45. public function getTitle($id){
  46. $query = "SELECT title FROM article WHERE id = ? ";
  47. $stmt = $this->dbh->prepare($query);
  48. $stmt->execute(array($id));
  49. $channal = $stmt->fetch(PDO::FETCH_ASSOC);
  50. if ($channel) {
  51. return $channel["name"];
  52. } else {
  53. return "";
  54. }
  55. }
  56. public function getPower($id){
  57. #查询用户对此channel是否有权限
  58. $iPower = 0;
  59. $query = "SELECT owner,status FROM article WHERE id=? and status>0 ";
  60. $stmt = $this->dbh->prepare($query);
  61. $stmt->execute(array($id));
  62. $channel = $stmt->fetch(PDO::FETCH_ASSOC);
  63. if($channel){
  64. if(!isset($_COOKIE["userid"]) ){
  65. #未登录用户
  66. if($channel["status"]==30){
  67. #全网公开有建议权限
  68. return 10;
  69. }
  70. else{
  71. #其他状态没有任何权限
  72. return 0;
  73. }
  74. }
  75. if($channel["owner"]==$_COOKIE["userid"]){
  76. return 30;
  77. }
  78. else if($channel["status"]>=30){
  79. #全网公开的 可以提交pr
  80. $iPower = 10;
  81. }
  82. }
  83. #查询共享权限,如果共享权限更大,覆盖上面的的
  84. $sharePower = share_get_res_power($_COOKIE["userid"],$id);
  85. if($sharePower>$iPower){
  86. $iPower=$sharePower;
  87. }
  88. return $iPower;
  89. }
  90. }
  91. ?>