AppiontController.php 5.6 KB

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