PageModel.class.php 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. <?php
  2. namespace Api\Model;
  3. use Api\Model\BaseModel;
  4. /**
  5. *
  6. * @author star7th
  7. */
  8. class PageModel extends BaseModel {
  9. protected $cat_name_id = array();
  10. //根据内容更新页面
  11. //其中cat_name参数特别说明下,传递各格式如 '二级目录/三级目录/四级目录'
  12. public function update_by_content($item_id,$page_title,$page_content,$cat_name='',$s_number = 99){
  13. $item_id = intval($item_id);
  14. if (!$item_id) {
  15. return false;
  16. }
  17. if ($this->cat_name_id && isset($this->cat_name_id[$cat_name])) {
  18. $cat_id = $this->cat_name_id[$cat_name] ;
  19. $cat_name = '' ; //如果已经有缓存了则设置为空
  20. }else{
  21. $cat_id = 0 ;
  22. }
  23. $catalog_array = explode('/', $cat_name);
  24. $cat_name = $catalog_array[0] ;
  25. $cat_name_sub = !empty($catalog_array[1])? $catalog_array[1] : '';
  26. $cat_name_sub_sub = !empty($catalog_array[2])? $catalog_array[2] : '';
  27. //如果传送了二级目录
  28. if ($cat_name) {
  29. $cat_name_array = D("Catalog")->where(" item_id = '$item_id' and level = 2 and cat_name = '%s' ",array($cat_name))->find();
  30. //如果不存在则新建
  31. if (!$cat_name_array) {
  32. $add_data = array(
  33. "cat_name" => $cat_name,
  34. "item_id" => $item_id,
  35. "addtime" => time(),
  36. "level" => 2
  37. );
  38. D("Catalog")->add($add_data);
  39. $cat_name_array = D("Catalog")->where(" item_id = '$item_id' and level = 2 and cat_name = '%s' ",array($cat_name))->find();
  40. }
  41. }
  42. //如果传送了三级目录
  43. if ($cat_name_sub) {
  44. $cat_name_sub_array = D("Catalog")->where(" item_id = '$item_id' and level = 3 and cat_name = '%s' and parent_cat_id = '%s' ",array($cat_name_sub,$cat_name_array['cat_id']))->find();
  45. //如果不存在则新建
  46. if (!$cat_name_sub_array) {
  47. $add_data = array(
  48. "cat_name" => $cat_name_sub,
  49. "item_id" => $item_id,
  50. "parent_cat_id" => $cat_name_array['cat_id'],
  51. "addtime" => time(),
  52. "level" => 3
  53. );
  54. D("Catalog")->add($add_data);
  55. $cat_name_sub_array = D("Catalog")->where(" item_id = '$item_id' and level = 3 and cat_name = '%s' and parent_cat_id = '%s' ",array($cat_name_sub,$cat_name_array['cat_id']))->find();
  56. }
  57. }
  58. //如果传送了四级目录
  59. if ($cat_name_sub_sub) {
  60. $cat_name_sub_sub_array = D("Catalog")->where(" item_id = '$item_id' and level = 4 and cat_name = '%s' and parent_cat_id = '%s' ",array($cat_name_sub_sub,$cat_name_sub_array['cat_id']))->find();
  61. //如果不存在则新建
  62. if (!$cat_name_sub_sub_array) {
  63. $add_data = array(
  64. "cat_name" => $cat_name_sub_sub,
  65. "item_id" => $item_id,
  66. "parent_cat_id" => $cat_name_sub_array['cat_id'],
  67. "addtime" => time(),
  68. "level" => 4
  69. );
  70. D("Catalog")->add($add_data);
  71. $cat_name_sub_sub_array = D("Catalog")->where(" item_id = '$item_id' and level = 4 and cat_name = '%s' and parent_cat_id = '%s' ",array($cat_name_sub_sub,$cat_name_sub_array['cat_id']))->find();
  72. }
  73. }
  74. //目录id
  75. $cat_id = 0 ;
  76. if ($cat_name_array && $cat_name_array['cat_id'] > 0 ) {
  77. $cat_id = $cat_name_array['cat_id'] ;
  78. }
  79. if ($cat_name_sub_array && $cat_name_sub_array['cat_id'] > 0 ) {
  80. $cat_id = $cat_name_sub_array['cat_id'] ;
  81. }
  82. if ($cat_name_sub_sub_array && $cat_name_sub_sub_array['cat_id'] > 0 ) {
  83. $cat_id = $cat_name_sub_sub_array['cat_id'] ;
  84. }
  85. $this->cat_name_id[$cat_name] = $cat_id ;
  86. if ($page_content) {
  87. $page_array = D("Page")->where(" item_id = '$item_id' and is_del = 0 and cat_id = '$cat_id' and page_title ='%s' ",array($page_title))->find();
  88. //如果不存在则新建
  89. if (!$page_array) {
  90. $add_data = array(
  91. "author_username" => "update_by_content",
  92. "item_id" => $item_id,
  93. "cat_id" => $cat_id,
  94. "page_title" => $page_title,
  95. "page_content" => $page_content,
  96. "s_number" => $s_number,
  97. "addtime" => time(),
  98. );
  99. $page_id = D("Page")->add($add_data);
  100. }else{
  101. $page_id = $page_array['page_id'] ;
  102. $update_data = array(
  103. "author_username" => "update_by_content",
  104. "item_id" => $item_id,
  105. "cat_id" => $cat_id,
  106. "page_title" => $page_title,
  107. "page_content" => $page_content,
  108. "s_number" => $s_number,
  109. );
  110. D("Page")->where(" page_id = '$page_id' ")->save($update_data);
  111. }
  112. }
  113. return $page_id ;
  114. }
  115. //软删除页面
  116. public function softDeletePage($page_id){
  117. $ret = M("Page")->where(" page_id = '$page_id' ")->save(array("is_del"=>1 ,"addtime"=>time()));
  118. return $ret;
  119. }
  120. //删除页面
  121. public function deletePage($page_id){
  122. $ret = M("Page")->where(" page_id = '$page_id' ")->delete();
  123. return $ret;
  124. }
  125. }