AppiontController.php 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  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 getAppiontInfo()
  11. {
  12. $data = request()->all();
  13. $defaulRes = [
  14. 'server_handle_result'=>0,
  15. 'reserve_check_result'=>0,
  16. 'allow_get_ticket'=>0,
  17. 'tip_msg'=>'',
  18. 'reserve_service_no'=>'Y',
  19. 'reserve_date'=>'',
  20. 'reserve_start_time'=>'',
  21. 'reserve_end_time'=>'',
  22. 'allow_post_ticket'=>0,
  23. ];
  24. if(request()->isMethod('post')){
  25. $defaulRes = ['server_handle_result'=>1,'tip_msg'=>''];
  26. if(empty($data['orderId'])){
  27. $defaulRes['tip_msg'] = '请输入订单id';
  28. exit(json_encode($defaulRes));
  29. }
  30. if($data['reqNo']) {
  31. Order::where('id',$data['orderId'])->update(['is_ticket'=>1]);
  32. $defaulRes['tip_msg'] = 'ok';
  33. }
  34. exit(json_encode($defaulRes));
  35. } else {
  36. if(empty($data['telphone'])){
  37. $defaulRes['tip_msg'] = '请输入手机号';
  38. exit(json_encode($defaulRes));
  39. }
  40. if(empty($data['sig'])){
  41. $defaulRes['tip_msg'] = '请输入sig签名';
  42. exit(json_encode($defaulRes));
  43. }
  44. if(empty($data['SecretKey']) || $data['SecretKey'] != 2018){
  45. $defaulRes['tip_msg'] = 'SecretKey秘钥错误';
  46. exit(json_encode($defaulRes));
  47. }
  48. if(empty($data['st']) ){
  49. $defaulRes['tip_msg'] = '请输入时间信息';
  50. exit(json_encode($defaulRes));
  51. }
  52. $sign = md5($data['id'].$data['telphone'].$data['barcode'].$data['st'].$data['st'].$data['area'].$data['st'].$data['st'].$data['SecretKey']);
  53. if($data['sig'] != $sign){
  54. $defaulRes['sig'] = '签名验证失败';
  55. exit(json_encode($defaulRes));
  56. }
  57. //先用患者表找,如果没有就直接查找用户表
  58. $user_id = Patient::where('phone',$data['telphone'])->value('user_id');
  59. if(empty($user_id)){
  60. $user_id = User::where('phone',$data['telphone'])->value('id');
  61. }
  62. if(empty($user_id)){
  63. $defaulRes['tip_msg'] = '无效账号';
  64. exit(json_encode($defaulRes));
  65. }
  66. DB::enableQueryLog();
  67. $order = Order::where('user_id',$user_id)->select('id','order_sn','user_id','patient_id','is_ticket')->with('orderPatient:order_id,appoint_start_time,appoint_end_time');
  68. if($data['st']){
  69. $order = $order->whereHas('orderPatient',function ($query) use ($data){
  70. $query->where('appoint_start_time','<=',$data['st']);
  71. $query->where('appoint_end_time','>=',$data['st']);
  72. });
  73. }
  74. $order_list =$order->first();
  75. if(empty($order_list)){
  76. $defaulRes['tip_msg'] = '无预约';
  77. exit(json_encode($defaulRes));
  78. }
  79. $order = $order_list->toArray();
  80. $defaulRes['orderId'] = $order['id'];
  81. $defaulRes['server_handle_result'] = 1;
  82. if( $order['is_ticket'] == 0 && !empty($order['order_patient'])){
  83. $start = intval($order['order_patient']['appoint_start_time']);
  84. $end = intval($order['order_patient']['appoint_end_time']);
  85. $date = date('Y-m-d',intval($order['order_patient']['appoint_start_time']));
  86. if($end < intval($data['st']) || intval($data['st']) < time()){
  87. $defaulRes['tip_msg'] = '预约已过期,您预约的时间为:'.$date.' '.date('H:i',$start).'~'.date('H:i',$end);
  88. exit(json_encode($defaulRes));
  89. }
  90. $defaulRes['reserve_start_time'] = date('H:i',$start);
  91. $defaulRes['reserve_end_time'] = date('H:i',$end);
  92. $defaulRes['allow_post_ticket'] = 1;
  93. $defaulRes['allow_get_ticket'] = 1;
  94. $defaulRes['reserve_check_result'] = 1;
  95. $defaulRes['reserve_date'] = $date;
  96. } else {
  97. $defaulRes['reserve_check_result'] = 1;
  98. $defaulRes['allow_post_ticket'] = 0;
  99. }
  100. exit(json_encode($defaulRes));
  101. }
  102. }
  103. }