Messages.php 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  1. <?php
  2. namespace app\inter\controller;
  3. use think\Controller;
  4. use think\Db;
  5. use think\Session;
  6. use think\Cache;
  7. use think\Log;
  8. class Messages extends Base
  9. {
  10. /**
  11. * 消息列表
  12. *
  13. * @ApiTitle (消息列表)
  14. * @ApiSummary (消息列表)
  15. * @ApiSector (远程诊断)
  16. * @ApiMethod (POST)
  17. * @ApiRoute (/inter/messages/allMessage)
  18. * @ApiHeaders (name="sign", type="string", required=true, description="请求头-校验key")
  19. * @ApiHeaders (name="nonce", type="string", required=true, description="请求头-随机数")
  20. * @ApiHeaders (name="timestamp", type=string, required=true, description="请求头-时间戳s")
  21. * @ApiParams (name="sessionid", type="string", required=true, description="参数json字符串")
  22. * @ApiParams (name="param", type="string", required=true, description="参数json字符串")
  23. * @ApiParams (name="param[page]", type="string", required=true, description="当前页数<必填>")
  24. * @ApiParams (name="param[number]", type="string", sample="", description="每页条数<必填>")
  25. * @ApiReturnParams (name="status", type="integer", required=true, sample="0", description="返回码 fail 失败 ok成功"))
  26. * @ApiReturnParams (name="code", type="integer", required=true, sample="0", description="返回状态码")
  27. * @ApiReturnParams (name="num", type="integer", required=true, sample="0", description="所有消息条数")
  28. * @ApiReturnParams (name="info", type="string", required=true, sample="返回成功", description="返回信息")
  29. * @ApiReturnParams (name="sessionid", type="object", sample="{}", description="缓存的数据key")
  30. * @ApiReturn (data="
  31. {
  32. 'status': ok,
  33. 'code': '0000',
  34. 'sessionid': 'a17z7a7a8f9g9rh9d89jio',
  35. 'num' : '10',
  36. 'info' : ''
  37. }
  38. *")
  39. **/
  40. public function allMessage(){
  41. try{
  42. $sessionid = $_REQUEST['sessionid'];
  43. log::record('-----------------请求的session-------');
  44. log::record($sessionid);
  45. $doctor = Cache::get($sessionid);
  46. $param = $_REQUEST['param'];
  47. $page = $param['page'];
  48. $number = $param['number'];
  49. $info = DB::table('messages')->where('doctor_id',$doctor['id'])->where('status',1)->limit($number)->page($page)->order('is_read asc,createdAt desc')->select();
  50. $num = DB::table('messages')->where('doctor_id',$doctor['id'])->where('status',1)->count();
  51. return json_encode(['status'=>'ok','code'=>'0000','info'=>$info,'sessionid'=>$sessionid,'num'=>$num]);
  52. }catch(\Exception $e){
  53. return json_encode(['status'=>'fail','code'=>'2000','msg'=>$e->getMessage()]);
  54. }
  55. }
  56. /**
  57. * 未读消息
  58. *
  59. * @ApiTitle (未读消息)
  60. * @ApiSummary (未读消息)
  61. * @ApiSector (远程诊断)
  62. * @ApiMethod (POST)
  63. * @ApiRoute (/inter/messages/unreadMessage)
  64. * @ApiHeaders (name="sign", type="string", required=true, description="请求头-校验key")
  65. * @ApiHeaders (name="nonce", type="string", required=true, description="请求头-随机数")
  66. * @ApiHeaders (name="timestamp", type=string, required=true, description="请求头-时间戳s")
  67. * @ApiParams (name="sessionid", type="string", required=true, description="参数json字符串")
  68. * @ApiReturnParams (name="status", type="integer", required=true, sample="0", description="返回码 fail 失败 ok成功"))
  69. * @ApiReturnParams (name="code", type="integer", required=true, sample="0", description="返回状态码")
  70. * @ApiReturnParams (name="num", type="integer", required=true, sample="0", description="未读信息条数")
  71. * @ApiReturnParams (name="info", type="string", required=true, sample="返回成功", description="返回信息")
  72. * @ApiReturnParams (name="sessionid", type="object", sample="{}", description="缓存的数据key")
  73. * @ApiReturn (data="
  74. {
  75. 'status': ok,
  76. 'code': '0000',
  77. 'sessionid': 'a17z7a7a8f9g9rh9d89jio',
  78. 'info' : '',
  79. 'num' : '10'
  80. }
  81. *")
  82. **/
  83. public function unreadMessage()
  84. {
  85. try{
  86. $sessionid = $_REQUEST['sessionid'];
  87. $doctor = Cache::get($sessionid);
  88. $info = DB::table('messages')->where('is_read', 0)->where('doctor_id', $doctor['id'])->where('status', 1)->order('createdAt desc')->limit(5)->select();
  89. $num = DB::table('messages')->where('is_read', 0)->where('doctor_id', $doctor['id'])->where('status', 1)->count();
  90. return json_encode(['status' => 'ok', 'code' => '0000', 'info' => $info, 'num' => $num,'sessionid'=>$sessionid]);
  91. }catch(\Exception $e){
  92. return json_encode(['status'=>'fail','code'=>'2000','msg'=>$e->getMessage()]);
  93. }
  94. }
  95. /**
  96. * 消息详情页
  97. *
  98. * @ApiTitle (消息详情页)
  99. * @ApiSummary (消息详情页)
  100. * @ApiSector (远程诊断)
  101. * @ApiMethod (POST)
  102. * @ApiRoute (/inter/messages/messageInfo)
  103. * @ApiHeaders (name="sign", type="string", required=true, description="请求头-校验key")
  104. * @ApiHeaders (name="nonce", type="string", required=true, description="请求头-随机数")
  105. * @ApiHeaders (name="timestamp", type=string, required=true, description="请求头-时间戳s")
  106. * @ApiParams (name="sessionid", type="string", required=true, description="参数json字符串")
  107. * @ApiParams (name="param", type="string", required=true, description="参数json字符串")
  108. * @ApiParams (name="param[id]", type="string", required=true, description="消息所属id<必填>")
  109. * @ApiReturnParams (name="status", type="integer", required=true, sample="0", description="返回码 fail 失败 ok成功"))
  110. * @ApiReturnParams (name="code", type="integer", required=true, sample="0", description="返回状态码")
  111. * @ApiReturnParams (name="info", type="string", required=true, sample="返回成功", description="返回信息")
  112. * @ApiReturnParams (name="sessionid", type="object", sample="{}", description="缓存的数据key")
  113. * @ApiReturn (data="
  114. {
  115. 'status': ok,
  116. 'code': '0000',
  117. 'sessionid': 'a17z7a7a8f9g9rh9d89jio',
  118. 'info' : ''
  119. }
  120. *")
  121. **/
  122. //消息详情页
  123. public function messageInfo(){
  124. $sessionid = $_REQUEST['sessionid'];
  125. $doctor = Cache::get($sessionid);
  126. $param = $_REQUEST['param'];
  127. $id = $param['id'];
  128. $info = DB::table('messages')->where('id',$id)->where('status',1)->where('doctor_id', $doctor['id'])->field('title,content')->find();
  129. if($info){
  130. // 读取到消息 未读状态修改为已读
  131. DB::table('messages')->where('id',$id)->update(['is_read'=>1]);
  132. return json_encode(['status'=>'ok','code'=>'0000','info'=>$info]);
  133. }else{
  134. return json_encode(['status'=>'fail','code'=>'1012','msg'=>'该条信息不存在','sessionid'=>$sessionid]);
  135. }
  136. }
  137. /**
  138. * 已读
  139. *
  140. * @ApiTitle (已读)
  141. * @ApiSummary (已读)
  142. * @ApiSector (远程诊断)
  143. * @ApiMethod (POST)
  144. * @ApiRoute (/inter/messages/changeRead)
  145. * @ApiHeaders (name="sign", type="string", required=true, description="请求头-校验key")
  146. * @ApiHeaders (name="nonce", type="string", required=true, description="请求头-随机数")
  147. * @ApiHeaders (name="timestamp", type=string, required=true, description="请求头-时间戳s")
  148. * @ApiParams (name="sessionid", type="string", required=true, description="参数json字符串")
  149. * @ApiParams (name="id", type="string", required=true, description="消息所属id<必填>")
  150. * @ApiReturnParams (name="status", type="integer", required=true, sample="0", description="返回码 fail 失败 ok成功"))
  151. * @ApiReturnParams (name="code", type="integer", required=true, sample="0", description="返回状态码")
  152. * @ApiReturnParams (name="msg", type="string", required=true, sample="返回成功", description="返回消息信息")
  153. * @ApiReturn (data="
  154. {
  155. 'status': ok,
  156. 'code': '0000',
  157. 'msg' : '已读'
  158. }
  159. *")
  160. **/
  161. public function changeRead(){
  162. $id = $_REQUEST['id'];
  163. DB::table('messages')->where('id',$id)->update(['is_read'=>1]);
  164. return json_encode(['status'=>'ok','code'=>'0000','msg'=>'已读']);
  165. }
  166. }