AppiontController.php 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  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. ];
  43. if(request()->isMethod('post')){
  44. $defaulRes = ['server_handle_result'=>1,'tip_msg'=>''];
  45. if(empty($data['orderId'])){
  46. $defaulRes['tip_msg'] = '请输入订单id';
  47. exit(json_encode($defaulRes));
  48. }
  49. if($data['reqNo']) {
  50. Order::where('id',$data['orderId'])->update(['is_ticket'=>1]);
  51. $defaulRes['tip_msg'] = 'ok';
  52. }
  53. exit(json_encode($defaulRes));
  54. } else {
  55. if(empty($data['telphone'])){
  56. $defaulRes['tip_msg'] = '请输入手机号';
  57. exit(json_encode($defaulRes));
  58. }
  59. if(empty($data['sig'])){
  60. $defaulRes['tip_msg'] = '请输入sig签名';
  61. exit(json_encode($defaulRes));
  62. }
  63. if(empty($data['SecretKey']) || $data['SecretKey'] != 2018){
  64. $defaulRes['tip_msg'] = 'SecretKey秘钥错误';
  65. exit(json_encode($defaulRes));
  66. }
  67. if(empty($data['st']) ){
  68. $defaulRes['tip_msg'] = '请输入时间信息';
  69. exit(json_encode($defaulRes));
  70. }
  71. $sign = md5($data['id'].$data['telphone'].$data['barcode'].$data['st'].$data['st'].$data['area'].$data['st'].$data['st'].$data['SecretKey']);
  72. if($data['sig'] != $sign){
  73. $defaulRes['sig'] = '签名验证失败';
  74. exit(json_encode($defaulRes));
  75. }
  76. //先用患者表找,如果没有就直接查找用户表
  77. $user_id = Patient::where('phone',$data['telphone'])->value('user_id');
  78. if(empty($user_id)){
  79. $user_id = User::where('phone',$data['telphone'])->value('id');
  80. }
  81. if(empty($user_id)){
  82. $defaulRes['tip_msg'] = '无效账号';
  83. exit(json_encode($defaulRes));
  84. }
  85. DB::enableQueryLog();
  86. $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');
  87. if($data['st']){
  88. $order = $order->whereHas('orderPatient',function ($query) use ($data){
  89. $query->where('appoint_start_time','<=',$data['st']);
  90. $query->where('appoint_end_time','>=',$data['st']);
  91. });
  92. }
  93. $order_list =$order->first();
  94. if(empty($order_list)){
  95. $defaulRes['tip_msg'] = '无预约';
  96. exit(json_encode($defaulRes));
  97. }
  98. $order = $order_list->toArray();
  99. $defaulRes['orderId'] = $order['id'];
  100. $defaulRes['server_handle_result'] = 1;
  101. if( $order['is_ticket'] == 0 && !empty($order['order_patient'])){
  102. $start = intval($order['order_patient']['appoint_start_time']);
  103. $end = intval($order['order_patient']['appoint_end_time']);
  104. $date = date('Y-m-d',intval($order['order_patient']['appoint_start_time']));
  105. if($end < intval($data['st']) || intval($data['st']) < time()){
  106. $defaulRes['tip_msg'] = '预约已过期,您预约的时间为:'.$date.' '.date('H:i',$start).'~'.date('H:i',$end);
  107. exit(json_encode($defaulRes));
  108. }
  109. $defaulRes['reserve_start_time'] = date('H:i',$start);
  110. $defaulRes['reserve_end_time'] = date('H:i',$end);
  111. $defaulRes['allow_post_ticket'] = 1;
  112. $defaulRes['allow_get_ticket'] = 1;
  113. $defaulRes['reserve_check_result'] = 1;
  114. $defaulRes['reserve_date'] = $date;
  115. } else {
  116. $defaulRes['reserve_check_result'] = 1;
  117. $defaulRes['allow_post_ticket'] = 0;
  118. }
  119. exit(json_encode($defaulRes));
  120. }
  121. }
  122. }