AppiontController.php 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Models\Order;
  4. use App\Models\OrderPatient;
  5. use App\Models\Patient;
  6. use App\Models\User;
  7. class AppiontController extends Controller
  8. {
  9. public function getAppiontInfo()
  10. {
  11. $data = request()->all();
  12. $defaulRes = [
  13. 'server_handle_result'=>0,
  14. 'reserve_check_result'=>0,
  15. 'allow_get_ticket'=>0,
  16. 'allow_get_ticket'=>0,
  17. 'tip_msg'=>'',
  18. 'reserve_service_no'=>0,
  19. 'reserve_date'=>'',
  20. 'reserve_start_time'=>'',
  21. 'reserve_end_time'=>'',
  22. 'allow_post_ticket'=>0,
  23. ];
  24. if(empty($data['telphone'])){
  25. $defaulRes['tip_msg'] = '请输入手机号';
  26. exit(json_encode($defaulRes));
  27. }
  28. // $sign = md5($data['id'].$data['telphone'].$data['barcode'].$data['st'].$data['st'].$data['area'].$data['st'].$data['st'].$data['SecretKey']);
  29. //dd($sign);
  30. if(empty($data['sig'])){
  31. $defaulRes['tip_msg'] = '请输入sig签名';
  32. exit(json_encode($defaulRes));
  33. }
  34. if(empty($data['SecretKey']) || $data['SecretKey'] != 2018){
  35. $defaulRes['tip_msg'] = 'SecretKey秘钥错误';
  36. exit(json_encode($defaulRes));
  37. }
  38. if(empty($data['st']) ){
  39. $defaulRes['tip_msg'] = '请输入时间信息';
  40. exit(json_encode($defaulRes));
  41. }
  42. $sign = md5($data['id'].$data['telphone'].$data['barcode'].$data['st'].$data['st'].$data['area'].$data['st'].$data['st'].$data['SecretKey']);
  43. if($data['sig'] != $sign){
  44. $defaulRes['sig'] = '签名验证失败';
  45. exit(json_encode($defaulRes));
  46. }
  47. $user_id = User::where('phone',$data['telphone'])->value('id');
  48. if(empty($user_id)){
  49. $defaulRes['sig'] = '无效账号';
  50. exit(json_encode($defaulRes));
  51. }
  52. $order = Order::where('user_id',$user_id)->select('id','order_sn','user_id','patient_id')->with('orderPatient:order_id,appoint_start_time,appoint_end_time');
  53. if($data['st']){
  54. $order = $order->whereHas('orderPatient',function ($query) use ($data){
  55. $query->where('appoint_start_time','>=',$data['st']);
  56. });
  57. }
  58. $order_list =$order->get()->toArray();
  59. foreach ($order_list as $order){
  60. $defauldata = $defaulRes;
  61. if(!$order['is_ticket']){
  62. $defauldata['reserve_start_time'] = $order[''];
  63. } else {
  64. }
  65. $appiontList [] = $defauldata;
  66. }
  67. dd($order_list);
  68. }
  69. }