123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151 |
- <?php
- namespace App\Http\Controllers;
- use Illuminate\Support\Facades\DB;
- use App\Models\Order;
- use App\Models\OrderPatient;
- use App\Models\Patient;
- use App\Models\User;
- class AppiontController extends Controller
- {
- public function __construct()
- {
- // 允许 $originarr 数组内的 域名跨域访问
- header('Access-Control-Allow-Origin:*');
- // 响应类型
- header('Access-Control-Allow-Methods:POST,GET,OPTIONS');
- // 带 cookie 的跨域访问
- header('Access-Control-Allow-Credentials: true');
- // 响应头设置
- header('Access-Control-Allow-Headers:x-requested-with,Content-Type,X-CSRF-Token,authorization');
- }
- public function getAppiontInfo()
- {
- // 允许 $originarr 数组内的 域名跨域访问
- header('Access-Control-Allow-Origin:*');
- // 响应类型
- header('Access-Control-Allow-Methods:POST,GET,OPTIONS');
- // 带 cookie 的跨域访问
- header('Access-Control-Allow-Credentials: true');
- // 响应头设置
- header('Access-Control-Allow-Headers:x-requested-with,Content-Type,X-CSRF-Token,authorization');
- $data = request()->all();
- $defaulRes = [
- 'server_handle_result'=>'0',
- 'reserve_check_result'=>'0',
- 'allow_get_ticket'=>'0',
- 'tip_msg'=>'',
- 'reserve_service_no'=>'Y',
- 'reserve_date'=>'',
- 'reserve_start_time'=>'',
- 'reserve_end_time'=>'',
- 'allow_post_ticket'=>'0',
- 'reserve_name'=>''
- ];
- if(request()->isMethod('post')){
- $defaulRes = ['server_handle_result'=>'1','tip_msg'=>''];
- if(empty($data['orderId'])){
- $defaulRes['tip_msg'] = '请输入订单id';
- exit(json_encode($defaulRes));
- }
- if($data['reqNo']) {
- Order::where('id',$data['orderId'])->update(['is_ticket'=>1]);
- $defaulRes['tip_msg'] = 'ok';
- }
- exit(json_encode($defaulRes));
- } else {
- if(empty($data['telephone'])){
- $defaulRes['tip_msg'] = '请输入手机号';
- exit(json_encode($defaulRes));
- }
- if(empty($data['sig'])){
- $defaulRes['tip_msg'] = '请输入sig签名';
- exit(json_encode($defaulRes));
- }
- // if(empty($data['secretKey']) || $data['secretKey'] !== '2018'){
- // $defaulRes['tip_msg'] = 'secretKey秘钥错误';
- // exit(json_encode($defaulRes));
- // }
- if(empty($data['st']) ){
- $defaulRes['tip_msg'] = '请输入时间信息';
- exit(json_encode($defaulRes));
- }
- $sign = md5($data['id'].$data['telephone'].$data['barcode'].$data['st'].$data['area'].'2018');
- if($data['sig'] != $sign){
- $defaulRes['sig'] = '签名验证失败';
- exit(json_encode($defaulRes));
- }
- //先用患者表找,如果没有就直接查找用户表
- $user_id = Patient::where('phone',$data['telephone'])->value('user_id');
- if(empty($user_id)){
- $user_id = User::where('phone',$data['telephone'])->value('id');
- }
- if(empty($user_id)){
- $defaulRes['tip_msg'] = '无效账号';
- exit(json_encode($defaulRes));
- }
- DB::enableQueryLog();
- $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');
- if($data['st']){
- $order = $order->whereHas('orderPatient',function ($query) use ($data){
- $query->where('appoint_start_time','<=',$data['st']);
- $query->where('appoint_end_time','>=',$data['st']);
- });
- }
- $order_list =$order->first();
- if(empty($order_list)){
- $defaulRes['tip_msg'] = '无预约';
- exit(json_encode($defaulRes));
- }
- $order = $order_list->toArray();
- $defaulRes['orderId'] = $order['id'];
- $defaulRes['server_handle_result'] = 1;
- if( $order['is_ticket'] == 0 && !empty($order['order_patient'])){
- $start = intval($order['order_patient']['appoint_start_time']);
- $end = intval($order['order_patient']['appoint_end_time']);
- $date = date('Y-m-d',intval($order['order_patient']['appoint_start_time']));
- if($end < intval($data['st']) || intval($data['st']) < time()){
- $defaulRes['tip_msg'] = '预约已过期,您预约的时间为:'.$date.' '.date('H:i',$start).'~'.date('H:i',$end);
- exit(json_encode($defaulRes));
- }
- $defaulRes['reserve_start_time'] = date('H:i',$start);
- $defaulRes['reserve_end_time'] = date('H:i',$end);
- $defaulRes['allow_post_ticket'] = '1';
- $defaulRes['allow_get_ticket'] = '1';
- $defaulRes['reserve_check_result'] = '1';
- $defaulRes['reserve_date'] = $date;
- $defaulRes['reserve_name'] = $order['order_patient']['name'];
- } else {
- $defaulRes['reserve_check_result'] = '1';
- $defaulRes['allow_post_ticket'] = '0';
- }
- exit(json_encode($defaulRes));
- }
- }
- }
|