News.php 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195
  1. <?php
  2. namespace Content\V1;
  3. use Dever;
  4. use Content\Lib\Base;
  5. class News extends Base
  6. {
  7. //*@ apiSampleRequest /v1/news.index 暂时不添加测试接口,这里需要域名和跨域支持
  8. /**
  9. * @api {get} v1/news.index 首页接口
  10. * @apiVersion 1.0.0
  11. * @apiName api.index
  12. * @apiGroup Data
  13. *
  14. * @apiDescription 小程序的首页接口
  15. *
  16. * apiSampleRequest /v1/news.index
  17. *
  18. * @apiParam {Number} appid 小程序id
  19. *
  20. * @apiSuccess {Object[]} info 小程序基本信息
  21. * @apiSuccess {Number} info.id 小程序id
  22. * @apiSuccess {String} info.name 小程序名称
  23. * @apiSuccess {Number} info.cate_id 小程序所属栏目id
  24. * @apiSuccess {String} info.logo 小程序logo
  25. * @apiSuccess {String} info.title 首页标题
  26. * @apiSuccess {String} info.pic 首页头图
  27. *
  28. * @apiSuccess {Object[]} cate 主栏目信息
  29. * @apiSuccess {Number} cate.id 栏目id
  30. * @apiSuccess {String} cate.name 栏目名称
  31. *
  32. * @apiSuccess {Object[]} cate_child 子栏目信息
  33. * @apiSuccess {Number} cate_child.id 栏目id
  34. * @apiSuccess {String} cate_child.name 栏目名称
  35. * @apiSuccess {Number} cate_child.cate_id 上级栏目id
  36. *
  37. * @apiSuccess {Object[]} cate_child.news 资讯信息
  38. * @apiSuccess {Number} cate_child.news.id 资讯id
  39. * @apiSuccess {String} cate_child.news.name 资讯标题
  40. * @apiSuccess {String} cate_child.news.content 资讯内容
  41. * @apiSuccess {String} cate_child.news.num_view 阅读数
  42. * @apiSuccess {String} cate_child.news.cdate 时间
  43. *
  44. * @apiSuccess {Object[]} cate_child.news.author 作者信息
  45. * @apiSuccess {Number} cate_child.news.author.id 作者id
  46. * @apiSuccess {String} cate_child.news.author.name 作者姓名
  47. * @apiSuccess {String} cate_child.news.author.pic 作者头像
  48. *
  49. * @apiSuccessExample 操作成功
  50. * {"status":1,"code":1,"msg":"success","data":{"info":{"id":"1","name":"\u7279\u8272\u5c0f\u9547\u600e\u4e48\u641e","cate_id":"1","logo":"http:\/\/192.168.33.10\/plant\/data\/upload\/1\/2018\/03\/24\/1e493a87d4cdddde7fd06ad9762694d2.jpg","title":"test","pic":"http:\/\/192.168.33.10\/plant\/data\/upload\/1\/2018\/03\/24\/da31b5d54d15192fea10406f77f4b0cb.jpg","state":"1","cdate":"1521858466"},"cate":{"id":"1","name":"\u7279\u8272\u5c0f\u9547\u4e0d\u5f97\u4e0d\u5b66\u4e60\u7cfb\u5217","cate_id":"-1","reorder":"1","state":"1","cdate":"1521814022"},"cate_child":[{"id":"3","name":"\u5341\u5927\u6848\u4f8b","cate_id":"1","reorder":"1","state":"1","cdate":"1521858511","news":[{"id":"1","name":"\u4e07\u8fbe\u57ce\u521b\u65b0\u4e1a\u6001\u7814\u7a76\u62a5\u544a","pic":["http:\/\/192.168.33.10\/plant\/data\/upload\/1\/2018\/03\/24\/1e493a87d4cdddde7fd06ad9762694d2.jpg"],"top":"http:\/\/192.168.33.10\/plant\/data\/upload\/1\/2018\/03\/24\/da31b5d54d15192fea10406f77f4b0cb.jpg","cate_id":"3","info_id":"1","author_id":"1","content":"<p>\u5730\u65b9\u5927\u5e45\u5ea6\u53d1<\/p>","num_view":"0","cdate":"9\u5c0f\u65f6\u524d","author":{"id":"1","name":"\u7a0b\u8302","pic":"http:\/\/192.168.33.10\/plant\/data\/upload\/1\/2018\/03\/24\/1e493a87d4cdddde7fd06ad9762694d2.jpg","state":"1","cdate":"1521858481"}}]},{"id":"2","name":"\u5341\u5927\u680f\u76ee","cate_id":"1","reorder":"1","state":"1","cdate":"1521858505"}]},"page":{"total":"1","current_page":1,"total_page":1,"next_page":1,"prev_page":1,"html":"","status":0}}
  51. *
  52. * @apiErrorExample 操作失败
  53. * {"status":2,"code":1,"msg":"\u9519\u8bef\u7684\u5c0f\u7a0b\u5e8fid"}
  54. */
  55. public function index_api()
  56. {
  57. # 获取一条主栏目
  58. $this->data['cate'] = Dever::load('set/cate-one', $this->data['info']['cate_id']);
  59. if ($this->data['cate']) {
  60. $this->data['cate_child'] = Dever::load('set/cate-getAll', array('option_cate_id' => $this->data['cate']['id']));
  61. if ($this->data['cate_child'] && isset($this->data['cate_child'][0])) {
  62. $news = Dever::load('content/news-getAll', array('option_info_id' => $this->data['info']['id'], 'option_cate_id' => $this->data['cate_child'][0]['id']));
  63. if ($news) {
  64. foreach ($news as $k => $v) {
  65. $this->data['cate_child'][0]['news'][$k] = $this->one($v);
  66. }
  67. }
  68. }
  69. }
  70. return $this->data;
  71. }
  72. /**
  73. * @api {get} v1/news.list 资讯列表
  74. * @apiVersion 1.0.0
  75. * @apiName news.list
  76. * @apiGroup Data
  77. *
  78. * @apiDescription 小程序的资讯列表接口
  79. *
  80. * @apiParam {Number} appid 小程序id
  81. * @apiParam {Number} cateid 子栏目id
  82. *
  83. * @apiSuccess {Object[]} info 小程序基本信息
  84. * @apiSuccess {Number} info.id 小程序id
  85. * @apiSuccess {String} info.name 小程序名称
  86. * @apiSuccess {Number} info.cate_id 小程序所属栏目id
  87. * @apiSuccess {String} info.logo 小程序logo
  88. * @apiSuccess {String} info.title 首页标题
  89. * @apiSuccess {String} info.pic 首页头图
  90. *
  91. * @apiSuccess {Object[]} news 资讯信息
  92. * @apiSuccess {Number} news.id 资讯id
  93. * @apiSuccess {String} news.name 资讯标题
  94. * @apiSuccess {String} news.content 资讯内容
  95. * @apiSuccess {String} news.num_view 阅读数
  96. * @apiSuccess {String} news.cdate 时间
  97. *
  98. * @apiSuccess {Object[]} news.author 作者信息
  99. * @apiSuccess {Number} news.author.id 作者id
  100. * @apiSuccess {String} news.author.name 作者姓名
  101. * @apiSuccess {String} news.author.pic 作者头像
  102. *
  103. * @apiSuccessExample 操作成功
  104. * {"status":1,"code":1,"msg":"success","data":{"info":{"id":"1","name":"\u7279\u8272\u5c0f\u9547\u600e\u4e48\u641e","cate_id":"1","logo":"http:\/\/192.168.33.10\/plant\/data\/upload\/1\/2018\/03\/24\/1e493a87d4cdddde7fd06ad9762694d2.jpg","title":"test","pic":"http:\/\/192.168.33.10\/plant\/data\/upload\/1\/2018\/03\/24\/da31b5d54d15192fea10406f77f4b0cb.jpg","state":"1","cdate":"1521858466"},"news":[{"id":"1","name":"\u4e07\u8fbe\u57ce\u521b\u65b0\u4e1a\u6001\u7814\u7a76\u62a5\u544a","pic":["http:\/\/192.168.33.10\/plant\/data\/upload\/1\/2018\/03\/24\/1e493a87d4cdddde7fd06ad9762694d2.jpg"],"top":"http:\/\/192.168.33.10\/plant\/data\/upload\/1\/2018\/03\/24\/da31b5d54d15192fea10406f77f4b0cb.jpg","cate_id":"3","info_id":"1","author_id":"1","content":"<p>\u5730\u65b9\u5927\u5e45\u5ea6\u53d1<\/p>","num_view":"0","cdate":"9\u5c0f\u65f6\u524d","author":{"id":"1","name":"\u7a0b\u8302","pic":"http:\/\/192.168.33.10\/plant\/data\/upload\/1\/2018\/03\/24\/1e493a87d4cdddde7fd06ad9762694d2.jpg","state":"1","cdate":"1521858481"}}]},"page":{"total":"1","current_page":1,"total_page":1,"next_page":1,"prev_page":1,"html":"","status":0}}
  105. *
  106. * @apiErrorExample 操作失败
  107. * {"status":2,"code":1,"msg":"\u9519\u8bef\u7684\u5c0f\u7a0b\u5e8fid"}
  108. */
  109. public function list_api()
  110. {
  111. $cateid = Dever::input('cateid');
  112. if ($cateid > 0) {
  113. $cate = Dever::load('set/cate-one', $cateid);
  114. if ($cate) {
  115. $news = Dever::load('content/news-getAll', array('option_info_id' => $this->data['info']['id'], 'option_cate_id' => $cate['id']));
  116. if ($news) {
  117. foreach ($news as $k => $v) {
  118. $this->data['news'][$k] = $this->one($v);
  119. }
  120. }
  121. }
  122. }
  123. return $this->data;
  124. }
  125. /**
  126. * @api {get} v1/news.view 资讯详情
  127. * @apiVersion 1.0.0
  128. * @apiName news.view
  129. * @apiGroup Data
  130. *
  131. * @apiDescription 小程序的资讯详情接口
  132. *
  133. * @apiParam {Number} appid 小程序id
  134. * @apiParam {Number} id 资讯id
  135. *
  136. * @apiSuccess {Object[]} info 小程序基本信息
  137. * @apiSuccess {Number} info.id 小程序id
  138. * @apiSuccess {String} info.name 小程序名称
  139. * @apiSuccess {Number} info.cate_id 小程序所属栏目id
  140. * @apiSuccess {String} info.logo 小程序logo
  141. * @apiSuccess {String} info.title 首页标题
  142. * @apiSuccess {String} info.pic 首页头图
  143. *
  144. * @apiSuccess {Object[]} news 资讯信息
  145. * @apiSuccess {Number} news.id 资讯id
  146. * @apiSuccess {String} news.name 资讯标题
  147. * @apiSuccess {String} news.content 资讯内容
  148. * @apiSuccess {String} news.num_view 阅读数
  149. * @apiSuccess {String} news.cdate 时间
  150. *
  151. * @apiSuccess {Object[]} news.author 作者信息
  152. * @apiSuccess {Number} news.author.id 作者id
  153. * @apiSuccess {String} news.author.name 作者姓名
  154. * @apiSuccess {String} news.author.pic 作者头像
  155. *
  156. * @apiSuccessExample 操作成功
  157. * {"status":1,"code":1,"msg":"success","data":{"info":{"id":"1","name":"\u7279\u8272\u5c0f\u9547\u600e\u4e48\u641e","cate_id":"1","logo":"http:\/\/192.168.33.10\/plant\/data\/upload\/1\/2018\/03\/24\/1e493a87d4cdddde7fd06ad9762694d2.jpg","title":"test","pic":"http:\/\/192.168.33.10\/plant\/data\/upload\/1\/2018\/03\/24\/da31b5d54d15192fea10406f77f4b0cb.jpg","state":"1","cdate":"1521858466"},"news":{"id":"1","name":"\u4e07\u8fbe\u57ce\u521b\u65b0\u4e1a\u6001\u7814\u7a76\u62a5\u544a","info_id":"1","author_id":"1","cate_id_parent":"1","cate_id":"3","num_add_view":"0","num_up":"0","num_view":"0","num_review":"0","pic":["http:\/\/192.168.33.10\/plant\/data\/upload\/1\/2018\/03\/24\/1e493a87d4cdddde7fd06ad9762694d2.jpg"],"top":"http:\/\/192.168.33.10\/plant\/data\/upload\/1\/2018\/03\/24\/da31b5d54d15192fea10406f77f4b0cb.jpg","content":"<p>\u5730\u65b9\u5927\u5e45\u5ea6\u53d1<\/p>","reorder":"1","state":"1","cdate":"9\u5c0f\u65f6\u524d","author":{"id":"1","name":"\u7a0b\u8302","pic":"http:\/\/192.168.33.10\/plant\/data\/upload\/1\/2018\/03\/24\/1e493a87d4cdddde7fd06ad9762694d2.jpg","state":"1","cdate":"1521858481"}}}}
  158. *
  159. * @apiErrorExample 操作失败
  160. * {"status":2,"code":1,"msg":"\u9519\u8bef\u7684\u5c0f\u7a0b\u5e8fid"}
  161. */
  162. public function view_api()
  163. {
  164. $id = Dever::input('id');
  165. if ($id > 0) {
  166. $news = Dever::load('content/news-one', $id);
  167. if ($news) {
  168. $this->data['news'] = $this->one($news);
  169. # 增加阅读量
  170. Dever::load('content/news-addView', $id);
  171. } else {
  172. Dever::alert('错误的资讯id');
  173. }
  174. } else {
  175. Dever::alert('错误的资讯id');
  176. }
  177. return $this->data;
  178. }
  179. }