AppiontController.php 4.9 KB

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