AppiontController.php 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  1. <?php
  2. namespace App\Http\Controllers;
  3. use Illuminate\Support\Facades\DB;
  4. use App\Models\Order;
  5. use App\Models\OrderPatient;
  6. use App\Models\Patient;
  7. use App\Models\User;
  8. class AppiontController extends Controller
  9. {
  10. public function __construct()
  11. {
  12. // 允许 $originarr 数组内的 域名跨域访问
  13. header('Access-Control-Allow-Origin:*');
  14. // 响应类型
  15. header('Access-Control-Allow-Methods:POST,GET,OPTIONS');
  16. // 带 cookie 的跨域访问
  17. header('Access-Control-Allow-Credentials: true');
  18. // 响应头设置
  19. header('Access-Control-Allow-Headers:x-requested-with,Content-Type,X-CSRF-Token,authorization');
  20. }
  21. public function getAppiontInfo()
  22. {
  23. // 允许 $originarr 数组内的 域名跨域访问
  24. header('Access-Control-Allow-Origin:*');
  25. // 响应类型
  26. header('Access-Control-Allow-Methods:POST,GET,OPTIONS');
  27. // 带 cookie 的跨域访问
  28. header('Access-Control-Allow-Credentials: true');
  29. // 响应头设置
  30. header('Access-Control-Allow-Headers:x-requested-with,Content-Type,X-CSRF-Token,authorization');
  31. $data = request()->all();
  32. $defaulRes = [
  33. 'server_handle_result'=>'0',
  34. 'reserve_check_result'=>'0',
  35. 'allow_get_ticket'=>'0',
  36. 'tip_msg'=>'',
  37. 'reserve_service_no'=>'Y',
  38. 'reserve_date'=>'',
  39. 'reserve_start_time'=>'',
  40. 'reserve_end_time'=>'',
  41. 'allow_post_ticket'=>'0',
  42. 'reserve_name'=>''
  43. ];
  44. if(request()->isMethod('post')){
  45. $defaulRes = ['server_handle_result'=>'1','tip_msg'=>''];
  46. if(empty($data['orderId'])){
  47. $defaulRes['tip_msg'] = '请输入订单id';
  48. exit(json_encode($defaulRes));
  49. }
  50. if($data['reqNo']) {
  51. Order::where('id',$data['orderId'])->update(['is_ticket'=>1]);
  52. $defaulRes['tip_msg'] = 'ok';
  53. }
  54. exit(json_encode($defaulRes));
  55. } else {
  56. if(empty($data['telephone'])){
  57. $defaulRes['tip_msg'] = '请输入手机号';
  58. exit(json_encode($defaulRes));
  59. }
  60. if(empty($data['sig'])){
  61. $defaulRes['tip_msg'] = '请输入sig签名';
  62. exit(json_encode($defaulRes));
  63. }
  64. // if(empty($data['secretKey']) || $data['secretKey'] !== '2018'){
  65. // $defaulRes['tip_msg'] = 'secretKey秘钥错误';
  66. // exit(json_encode($defaulRes));
  67. // }
  68. if(empty($data['st']) ){
  69. $defaulRes['tip_msg'] = '请输入时间信息';
  70. exit(json_encode($defaulRes));
  71. }
  72. $sign = md5($data['id'].$data['telephone'].$data['barcode'].$data['st'].$data['area'].'2018');
  73. if($data['sign'] == 1) dd($sign);
  74. if($data['sign'] != $sign){
  75. $defaulRes['tip_msg'] = '签名验证失败';
  76. exit(json_encode($defaulRes));
  77. }
  78. //先用患者表找,如果没有就直接查找用户表
  79. $user_id = Patient::where('phone',$data['telephone'])->value('user_id');
  80. if(empty($user_id)){
  81. $user_id = User::where('phone',$data['telephone'])->value('id');
  82. }
  83. if(empty($user_id)){
  84. $defaulRes['tip_msg'] = '无效账号';
  85. exit(json_encode($defaulRes));
  86. }
  87. DB::enableQueryLog();
  88. $order = Order::where('user_id',$user_id)->where('organization_id',$data['area'])->select('id','order_sn','user_id','patient_id','is_ticket')->with('orderPatient:order_id,appoint_start_time,appoint_end_time,name');
  89. // if($data['st']){
  90. // $order = $order->whereHas('orderPatient',function ($query) use ($data){
  91. // $query->where('appoint_start_time','<=',$data['st']);
  92. // $query->where('appoint_end_time','>=',$data['st']);
  93. // });
  94. // }
  95. //dd(strtotime('2021-01-21 12:00:00'));
  96. if($data['st']){
  97. $order = $order->whereHas('orderPatient',function ($query) use ($data){
  98. $query->where('appoint_start_time','>=',$data['st']);
  99. });
  100. }
  101. $order_list =$order->first();
  102. if($data['sql'] == 1) dd(DB::getQueryLog());
  103. if(empty($order_list)){
  104. $defaulRes['tip_msg'] = '无预约';
  105. exit(json_encode($defaulRes));
  106. }
  107. $order = $order_list->toArray();
  108. $defaulRes['orderId'] = $order['id'];
  109. $defaulRes['server_handle_result'] = 1;
  110. if( $order['is_ticket'] == 0 && !empty($order['order_patient'])){
  111. $start = intval($order['order_patient']['appoint_start_time']);
  112. $end = intval($order['order_patient']['appoint_end_time']);
  113. $date = date('Y-m-d',intval($order['order_patient']['appoint_start_time']));
  114. if($end < intval($data['st']) ){
  115. $defaulRes['tip_msg'] = '预约已过期,您预约的时间为:'.$date.' '.date('H:i',$start).'~'.date('H:i',$end);
  116. exit(json_encode($defaulRes));
  117. }
  118. $defaulRes['reserve_start_time'] = date('H:i',$start);
  119. $defaulRes['reserve_end_time'] = date('H:i',$end);
  120. $defaulRes['allow_post_ticket'] = '1';
  121. $defaulRes['allow_get_ticket'] = '1';
  122. $defaulRes['reserve_check_result'] = '1';
  123. $defaulRes['reserve_date'] = $date;
  124. $defaulRes['reserve_name'] = $order['order_patient']['name'] ?? '';
  125. } else {
  126. $defaulRes['reserve_check_result'] = '1';
  127. $defaulRes['allow_post_ticket'] = '0';
  128. }
  129. exit(json_encode($defaulRes));
  130. }
  131. }
  132. }