Writereport.php 45 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826
  1. <?php
  2. namespace app\inter\controller;
  3. //use Doctrine\Common\Cache\Cache;
  4. use think\Controller;
  5. use think\Db;
  6. use think\Session;
  7. use app\common\library\UUIDs;
  8. use think\Cache;
  9. use think\Log;
  10. use app\common\library\Verify;
  11. class Writereport extends Base
  12. {
  13. /**
  14. * 写报告页面
  15. *
  16. * @ApiTitle (写报告页面)
  17. * @ApiSummary (写报告页面)
  18. * @ApiSector (远程诊断)
  19. * @ApiMethod (POST)
  20. * @ApiRoute (/inter/writereport/index)
  21. * @ApiHeaders (name="sign", type="string", required=true, description="请求头-校验key")
  22. * @ApiHeaders (name="nonce", type="string", required=true, description="请求头-随机数")
  23. * @ApiHeaders (name="timestamp", type=string, required=true, description="请求头-时间戳s")
  24. * @ApiParams (name="sessionid", type="string", required=true, description="参数json字符串")
  25. * @ApiParams (name="param", type="string", required=true, description="参数json字符串")
  26. * @ApiParams (name="is_remote", type="string", required=true, description="是否为远程列表进入")
  27. * @ApiParams (name="param[id]", type="string", sample="", description="exams表id值<必填>")
  28. * @ApiParams (name="param[images]", type="string", sample="", description="影像图片<选填>")
  29. * @ApiReturnParams (name="status", type="integer", required=true, sample="0", description="返回码 fail 失败 ok成功"))
  30. * @ApiReturnParams (name="code", type="integer", required=true, sample="0", description="返回状态码")
  31. * @ApiReturnParams (name="info", type="string", required=true, sample="返回成功", description="返回信息")
  32. * @ApiReturnParams (name="is_remote", type="object", sample="{}", description="是否为远程诊断进入")
  33. * @ApiReturnParams (name="sessionid", type="object", sample="{}", description="缓存的数据key")
  34. * @ApiReturn (data="
  35. {
  36. 'status': ok,
  37. 'code': '0000',
  38. 'sessionid': 'a17z7a7a8f9g9rh9d89jio',
  39. 'is_remote': 1,
  40. 'info' : ''
  41. }
  42. *")
  43. **/
  44. public function index(){
  45. try{
  46. log::record('-----请求值-----');
  47. log::record($_REQUEST);
  48. log::record('-----请求值-----');
  49. $sessionid = $_REQUEST['sessionid'];
  50. if(isset($_REQUEST['is_remote']) && !empty($_REQUEST['is_remote'])){
  51. $is_remote = $_REQUEST['is_remote'];
  52. }else{
  53. $is_remote = 0;
  54. }
  55. $doctor = Cache::get($sessionid);
  56. $institution = DB::table('institution')->where('id',$doctor['institution_id'])->field('name,report_subtitle')->find();
  57. $param = $_REQUEST['param'];
  58. $id = $param['id'];
  59. $info = DB::table('exams')->where('id',$id)->field(['id','ext','study_id','exam_class','exam_status','exam_datetime','exam_sub_class','body_part','accession_num','patient_id','film_type'])->find();
  60. $exam_class = DB::table('constant')->where('id',$info['exam_class'])->field('constant_value')->find();
  61. $info['exam_class'] = $exam_class['constant_value'];
  62. $exam_subclass = DB::table('exam_subclass')->where('id',$info['exam_sub_class'])->field('name')->find();
  63. $info['exam_sub_class'] = $exam_subclass['name'];
  64. $patient_info = DB::table('patient_infos')->where('id',$info['patient_id'])->field(['id','temp_patient_id','name','phone','sex','age'])->find();
  65. $info['pid'] = $patient_info['temp_patient_id'];
  66. $info['name'] = $patient_info['name'];
  67. $info['sex'] = $patient_info['sex'];
  68. $info['age'] = $patient_info['age'];
  69. $info['phone'] = $patient_info['phone'];
  70. $info['hospital_name'] = $institution['name'];
  71. $info['hospital_title'] = $institution['report_subtitle'];
  72. $info['images'] = isset($param['images']) ? $param['images'] : '';
  73. $report = DB::table('report')->where('exam_id',$id)->field('report_result,report_datetime,report_doctor_id,review_datetime,review_doctor_id,impression,description')->find();
  74. $report_doctor = DB::table('doctors')->where('id',$report['report_doctor_id'])->field('realname')->find();
  75. $info['report_doctor'] = $report_doctor['realname'];
  76. $info['report_datetime'] = $report['report_datetime'];
  77. $review_doctor = DB::table('doctors')->where('id',$report['review_doctor_id'])->field('realname')->find();
  78. $info['review_doctor'] = $review_doctor['realname'];
  79. $info['review_datetime'] = $report['review_datetime'];
  80. $info['description'] = $report['description'];
  81. $info['impression'] = $report['impression'];
  82. $info['report_result'] = $report['report_result'];
  83. $cache_key = $doctor['id'].'_'.$id;
  84. if(Cache::get($cache_key)){
  85. $cache = Cache::get($cache_key);
  86. $info['description'] = isset($cache['description']) ? $cache['description'] : '';
  87. $info['impression'] = isset($cache['impression']) ? $cache['impression'] : '';
  88. $info['report_result'] = isset($cache['r_result']) ?$cache['r_result'] : '';
  89. $info['name'] = isset($cache['name']) ? $cache['name'] : '';
  90. $info['sex'] = isset($cache['sex']) ? $cache['sex'] : '';
  91. $info['age'] = isset($cache['age']) ? $cache['age'] : '';
  92. $info['phone'] = isset($cache['phone']) ? $cache['phone'] : '';
  93. }
  94. return json_encode(['status'=>'ok','code'=>'0000','info'=>$info,'sessionid'=>$sessionid,'is_remote'=>$is_remote]);
  95. }catch(\Exception $e){
  96. return json_encode(['status'=>'fail','code'=>'2000','msg'=>$e->getMessage()]);
  97. }
  98. }
  99. /**
  100. * 上远程申请附件
  101. *
  102. * @ApiTitle (上远程申请附件)
  103. * @ApiSummary (上远程申请附件)
  104. * @ApiSector (远程诊断)
  105. * @ApiMethod (POST)
  106. * @ApiRoute (/inter/writereport/upload)
  107. * @ApiHeaders (name="sign", type="string", required=true, description="请求头-校验key")
  108. * @ApiHeaders (name="nonce", type="string", required=true, description="请求头-随机数")
  109. * @ApiHeaders (name="timestamp", type=string, required=true, description="请求头-时间戳s")
  110. * @ApiParams (name="sessionid", type="string", required=true, description="参数json字符串")
  111. * @ApiParams (name="file", type="string", required=true, description="上传的文件<必填>")
  112. * @ApiReturnParams (name="status", type="integer", required=true, sample="0", description="返回码 fail 失败 ok成功"))
  113. * @ApiReturnParams (name="code", type="integer", required=true, sample="0", description="返回状态码")
  114. * @ApiReturnParams (name="info", type="string", required=true, sample="返回成功", description="返回信息")
  115. * @ApiReturn (data="
  116. {
  117. 'status': ok,
  118. 'code': '0000',
  119. 'info' : '/upload/20180101/12346asd.jpg'
  120. }
  121. *")
  122. **/
  123. public function upload($files){
  124. // 获取表单上传文件
  125. foreach($files as $file){
  126. // 移动到框架应用根目录/public/uploads/ 目录下
  127. $info = $file->move(ROOT_PATH . 'public' . DS . 'uploads');
  128. if($info){
  129. return $info->getSaveName();
  130. // 成功上传后 获取上传信息
  131. // 输出 jpg
  132. // echo $info-> getExtension();
  133. // 输出 42a79759f284b767dfcb2a0197904287.jpg
  134. // echo $info->getFilename();
  135. }else{
  136. // 上传失败获取错误信息
  137. // echo $file->getError();
  138. }
  139. }
  140. }
  141. /**
  142. * 报告保存
  143. *
  144. * @ApiTitle (报告保存)
  145. * @ApiSummary (报告保存)
  146. * @ApiSector (远程诊断)
  147. * @ApiMethod (POST)
  148. * @ApiRoute (/inter/writereport/write)
  149. * @ApiHeaders (name="sign", type="string", required=true, description="请求头-校验key")
  150. * @ApiHeaders (name="nonce", type="string", required=true, description="请求头-随机数")
  151. * @ApiHeaders (name="timestamp", type=string, required=true, description="请求头-时间戳s")
  152. * @ApiParams (name="sessionid", type="string", required=true, description="参数json字符串")
  153. * @ApiParams (name="param", type="string", required=true, description="参数json字符串")
  154. * @ApiParams (name="is_remote", type="string", required=true, description="是否为远程列表进入")
  155. * @ApiParams (name="param[id]", type="string", sample="", description="exams表id值<必填>")
  156. * @ApiParams (name="param[pid]", type="string", sample="", description="患者id值<必填>")
  157. * @ApiParams (name="param[name]", type="string", sample="", description="患者姓名<必填>")
  158. * @ApiParams (name="param[age]", type="string", sample="", description="患者年龄<必填>")
  159. * @ApiParams (name="param[sex]", type="string", sample="", description="患者性别<必填>")
  160. * @ApiParams (name="param[impression]", type="string", sample="", description="影响所见<必填>")
  161. * @ApiParams (name="param[description]", type="string", sample="", description="意见建议<必填>")
  162. * @ApiParams (name="param[film_type]", type="string", sample="", description="胶片<必填>")
  163. * @ApiParams (name="param[r_result]", type="string", sample="", description="检查结果<必填>")
  164. * @ApiReturnParams (name="status", type="integer", required=true, sample="0", description="返回码 fail 失败 ok成功"))
  165. * @ApiReturnParams (name="code", type="integer", required=true, sample="0", description="返回状态码")
  166. * @ApiReturnParams (name="msg", type="string", required=true, sample="返回成功", description="返回消息")
  167. * @ApiReturnParams (name="sessionid", type="object", sample="{}", description="缓存的数据key")
  168. * @ApiReturn (data="
  169. {
  170. 'status': ok,
  171. 'code': '0000',
  172. 'sessionid': 'a17z7a7a8f9g9rh9d89jio',
  173. 'msg' : '保存成功'
  174. }
  175. *")
  176. **/
  177. public function write(){
  178. try{
  179. $sessionid = $_REQUEST['sessionid'];
  180. if(isset($_REQUEST['is_remote']) && $_REQUEST['is_remote'] == 1){
  181. // 是远程写报告 7
  182. $return = Verify::check_role($sessionid,7);
  183. }else{
  184. // 本地写报告权限 2
  185. $return = Verify::check_role($sessionid,2);
  186. }
  187. if($return != 1){
  188. return json_encode(['status'=>'fail','code'=>'1029','msg'=>'没有操作权限']);
  189. }
  190. $param = $_REQUEST['param'];
  191. $status = DB::table('exams')->where('id',$param['id'])->field('exam_status')->find();
  192. if($status['exam_status'] > 6){
  193. return json_encode(['status'=>'fail','code'=>'1034','msg'=>'报告已被保存,无法再次被修改']);
  194. }
  195. // Verify::wreportCheck($param);
  196. $doctor = Cache::get($sessionid);
  197. $remote_app = DB::table('remote_application')->where('exam_id',$param['id'])->field('remote_doctor_id')->find();
  198. if(!empty($remote_app['remote_doctor_id'])){
  199. if($remote_app['remote_doctor_id'] != $doctor['id']){
  200. // return json_encode(['status'=>'fail','code'=>'1029','msg'=>'已被指定报告医生,您没有操作权限']);
  201. }
  202. }
  203. $this->uuids = new UUIDs();
  204. //初步报告生成
  205. $film_type = isset($param['film_type']) ? $param['film_type'] : '';
  206. // $exam_status = $this->get_exam_status($doctor['id'],7);
  207. $patient_info = array();
  208. $patient_info['id'] = isset($param['pid']) ? $param['pid'] : '';
  209. $patient_info['name'] = isset($param['name']) ? $param['name'] : '';
  210. $patient_info['age'] = isset($param['age']) ? $param['age'] : '';
  211. $patient_info['phone'] = isset($param['phone']) ? $param['phone'] : '';
  212. $patient_info['sex'] = isset($param['sex']) ? $param['sex'] : '';
  213. $patient = DB::table('patient_infos')->where('id',$param['pid'])->update($patient_info);
  214. $info = array();
  215. $info['exam_id'] = $param['id'];
  216. $info['impression'] = isset($param['impression']) ? $param['impression'] : '';
  217. $info['description'] = isset($param['description']) ? $param['description'] : '';
  218. if(isset($param['r_result']) && $param['r_result'] == 'true'){
  219. $info['report_result'] = 2;
  220. }else{
  221. $info['report_result'] = 1;
  222. }
  223. DB::table('exams')->where('id',$param['id'])->update(['exam_status'=>'7','film_type'=>$film_type,'exam_report'=>$info['report_result']]);
  224. $info['report_datetime'] = date('Y-m-d H:i:s',time());
  225. $info['report_doctor_id'] = $doctor['id'];
  226. $report_info = DB::table('report')->where('exam_id',$param['id'])->find();
  227. if($report_info){
  228. $report = DB::table('report')->where('exam_id',$param['id'])->update($info);
  229. $id = $report_info['id'];
  230. }else{
  231. $id = $this->uuids->uuid16();
  232. $info['id'] = $id;
  233. $info['createdAt'] = date('Y-m-d H:i:s',time());
  234. $report = DB::table('report')->insert($info);
  235. }
  236. $cache_key = $doctor['id'].'_'.$param['id'];
  237. if(Cache::get($cache_key)){
  238. Cache::rm($cache_key);
  239. }
  240. //写入log日志
  241. log::record('----日志写入----');
  242. $log = array();
  243. $log['id'] = UUIDs::uuid16();
  244. $log['impression'] = isset($param['impression']) ? $param['impression'] : '';
  245. $log['description'] = isset($param['description']) ? $param['description'] : '';
  246. $log['report_id'] = $id;
  247. $log['createdAt'] = date('Y-m-d H:i:s',time());
  248. $log['doctor_id'] = $doctor['id'];
  249. $log['type'] = 1; //写报告
  250. log::record($log);
  251. $report_log = DB::table('report_record')->insert($log);
  252. log::record($report_log);
  253. log::record('----日志写入成功----');
  254. return json_encode(['status'=>'ok','code'=>'0000','msg'=>'保存成功','sessionid'=>$sessionid]);
  255. }catch(\Exception $e){
  256. return json_encode(['status'=>'fail','code'=>'2000','msg'=>$e->getMessage()]);
  257. }
  258. }
  259. public function get_exam_status($doctorid,$status){
  260. $doctor_class = DB::table('doctor_class')->where('doctor_id',$doctorid)->field('doctor_class')->find();
  261. if(strpos($doctor_class['doctor_class'],'9')){
  262. return 9;
  263. }elseif(strpos($doctor_class['doctor_class'],'8')){
  264. return 8;
  265. }else{
  266. return $status;
  267. }
  268. }
  269. /**
  270. * 公有模板列表
  271. *
  272. * @ApiTitle (公有模板列表)
  273. * @ApiSummary (公有模板列表)
  274. * @ApiSector (远程诊断)
  275. * @ApiMethod (POST)
  276. * @ApiRoute (/inter/writereport/public_template)
  277. * @ApiHeaders (name="sign", type="string", required=true, description="请求头-校验key")
  278. * @ApiHeaders (name="nonce", type="string", required=true, description="请求头-随机数")
  279. * @ApiHeaders (name="timestamp", type=string, required=true, description="请求头-时间戳s")
  280. * @ApiParams (name="sessionid", type="string", required=true, description="参数json字符串")
  281. * @ApiParams (name="exam_class", type="string", required=true, description="检查类id")
  282. * @ApiReturnParams (name="info", type="string", required=true, sample="返回成功", description="返回信息")
  283. * @ApiReturn (data="
  284. {
  285. 'info' : ''
  286. }
  287. *")
  288. **/
  289. public function public_template(){
  290. $sessionid = $_REQUEST['sessionid'];
  291. $doctor = Cache::get($sessionid);
  292. $exam = $_REQUEST['exam_class'];
  293. //第一级 公共模板
  294. $info = $this->get_template(1,$doctor['id'],$exam);
  295. return json_encode(['status'=>'ok','code'=>'0000','info'=>$info,'sessionid'=>$sessionid]);
  296. }
  297. /**
  298. * 私有模板列表
  299. *
  300. * @ApiTitle (私有模板列表)
  301. * @ApiSummary (私有模板列表)
  302. * @ApiSector (远程诊断)
  303. * @ApiMethod (POST)
  304. * @ApiRoute (/inter/writereport/private_template)
  305. * @ApiHeaders (name="sign", type="string", required=true, description="请求头-校验key")
  306. * @ApiHeaders (name="nonce", type="string", required=true, description="请求头-随机数")
  307. * @ApiHeaders (name="timestamp", type=string, required=true, description="请求头-时间戳s")
  308. * @ApiParams (name="sessionid", type="string", required=true, description="参数json字符串")
  309. * @ApiParams (name="exam_class", type="string", required=true, description="检查类id")
  310. * @ApiReturnParams (name="info", type="string", required=true, sample="返回成功", description="返回信息")
  311. * @ApiReturn (data="
  312. {
  313. 'info' : ''
  314. }
  315. *")
  316. **/
  317. public function private_template(){
  318. $sessionid = $_REQUEST['sessionid'];
  319. $doctor = Cache::get($sessionid);
  320. $exam = $_REQUEST['exam_class'];
  321. //私有模板
  322. $info = $this->get_template(2,$doctor['id'],$exam);
  323. return json_encode(['status'=>'ok','code'=>'0000','info'=>$info,'sessionid'=>$sessionid]);
  324. }
  325. public function get_template($public,$id,$exam){
  326. // 查询exam_class表
  327. $examCla = DB::table('constant')->where('id',$exam)->field('constant_value as name')->find();
  328. if($public == 1){
  329. $t = DB::table('templates')->where('is_public',$public)->where('exam_class_id',$examCla['name'])->field(['id','title as label','impression','description','parent_id'])->select();
  330. }else{
  331. // 私有模板 添加创建人条件
  332. $t = DB::table('templates')->where('is_public',$public)->where('create_user',$id)->where('exam_class_id',$examCla['name'])->field(['id','title as label','impression','description','parent_id'])->select();
  333. }
  334. if(!$t){
  335. return '';
  336. }
  337. $data = array();
  338. foreach ($t as $k => $v) {
  339. if($v['parent_id'] == 0){
  340. var_dump(int($v['parent_id']));
  341. $data[] = $v;
  342. }
  343. }
  344. foreach ($data as $k => $v) {
  345. unset($data[$k]['impression']);
  346. unset($data[$k]['description']);
  347. unset($data[$k]['parent_id']);
  348. }
  349. foreach ($t as $k => $v) {
  350. foreach ($data as $key => $value) {
  351. if($v['parent_id'] == $value['id']){
  352. unset($t[$k]['parent_id']);
  353. $data[$key]['children'][] = $t[$k];
  354. }
  355. }
  356. }
  357. if($data){
  358. return $data;
  359. }
  360. }
  361. /**
  362. * 确认报告
  363. *
  364. * @ApiTitle (确认报告)
  365. * @ApiSummary (确认报告)
  366. * @ApiSector (远程诊断)
  367. * @ApiMethod (POST)
  368. * @ApiRoute (/inter/writereport/confirm)
  369. * @ApiHeaders (name="sign", type="string", required=true, description="请求头-校验key")
  370. * @ApiHeaders (name="nonce", type="string", required=true, description="请求头-随机数")
  371. * @ApiHeaders (name="timestamp", type=string, required=true, description="请求头-时间戳s")
  372. * @ApiParams (name="sessionid", type="string", required=true, description="参数json字符串")
  373. * @ApiParams (name="id", type="string", sample="", description="exams表id值<必填>")
  374. * @ApiParams (name="film_type", type="string", sample="", description="胶片类型<必填>")
  375. * @ApiReturnParams (name="status", type="integer", required=true, sample="0", description="返回码 fail 失败 ok成功"))
  376. * @ApiReturnParams (name="code", type="integer", required=true, sample="0", description="返回状态码")
  377. * @ApiReturnParams (name="msg", type="string", required=true, sample="返回成功", description="返回消息")
  378. * @ApiReturn (data="
  379. {
  380. 'status': ok,
  381. 'code': '0000',
  382. 'msg': '已确认',
  383. }
  384. *")
  385. **/
  386. public function confirm(){
  387. try{
  388. $is_remote = $_REQUEST['is_remote'];
  389. if($is_remote == 1){
  390. return json_encode(['status'=>'fail','code'=>'1133','msg'=>'远程无法确诊报告']);
  391. }
  392. $sessionid = $_REQUEST['sessionid'];
  393. $doctor = Cache::get($sessionid);
  394. $param = $_REQUEST['param'];
  395. $id = $param['id'];
  396. $status = DB::table('exams')->where('id',$id)->field('exam_status')->find();
  397. if($status['exam_status'] < 8 ){
  398. return json_encode(['status'=>'fail','code'=>'1033','msg'=>'只能确认通过审核的报告']);
  399. }elseif($status['exam_status'] == 9){
  400. return json_encode(['status'=>'fail','code'=>'1034','msg'=>'已经确认过该报告,不可再次确认']);
  401. }
  402. $rinfo = array();
  403. $rinfo['impression'] = isset($param['impression']) ? $param['impression'] : '';
  404. $rinfo['description'] = isset($param['description']) ? $param['description'] : '';
  405. if(isset($param['r_result']) && $param['r_result'] == 'true'){
  406. $rinfo['report_result'] = 2;
  407. }else{
  408. $rinfo['report_result'] = 1;
  409. }
  410. $rinfo['confirm_datetime'] = date('Y-m-d H:i:s',time());
  411. $rinfo['confirm_doctor_id'] = $doctor['id'];
  412. // $exam_status = $this->get_exam_status($doctor['id'],9);
  413. DB::table('exams')->where('id',$id)->update(['exam_status'=>'9','film_type'=>$_REQUEST['param']['film_type']]);
  414. DB::table('report')->where('exam_id',$id)->update($rinfo);
  415. $cache_key = $doctor['id'].'_'.$id;
  416. if(Cache::get($cache_key)){
  417. Cache::rm($cache_key);
  418. }
  419. // 添加 确认log日志
  420. $info = array();
  421. $info['id'] = UUIDs::uuid16();
  422. $info['createdAt'] = date('Y-m-d H:i:s',time());
  423. $info['doctor_id'] = $doctor['id'];
  424. $info['type'] = 3;
  425. $info['report_id'] = '';
  426. DB::table('report_record')->insert($info);
  427. return json_encode(['status'=>'ok','code'=>'0000','msg'=>'已确认']);
  428. }catch(\Exception $e){
  429. return json_encode(['status'=>'fail','code'=>'2000','msg'=>$e->getMessage()]);
  430. }
  431. }
  432. /**
  433. * 审核报告
  434. *
  435. * @ApiTitle (审核报告)
  436. * @ApiSummary (审核报告)
  437. * @ApiSector (远程诊断)
  438. * @ApiMethod (POST)
  439. * @ApiRoute (/inter/writereport/examine)
  440. * @ApiHeaders (name="sign", type="string", required=true, description="请求头-校验key")
  441. * @ApiHeaders (name="nonce", type="string", required=true, description="请求头-随机数")
  442. * @ApiHeaders (name="timestamp", type=string, required=true, description="请求头-时间戳s")
  443. * @ApiParams (name="sessionid", type="string", required=true, description="参数json字符串")
  444. * @ApiParams (name="param", type="string", required=true, description="参数json字符串")
  445. * @ApiParams (name="is_remote", type="string", required=true, description="是否为远程列表进入")
  446. * @ApiParams (name="id", type="string", sample="", description="exams表id值<必填>")
  447. * @ApiParams (name="param[impression]", type="string", sample="", description="检查所见<必填>")
  448. * @ApiParams (name="param[description]", type="string", sample="", description="意见建议<必填>")
  449. * @ApiParams (name="param[r_result]", type="string", sample="", description="检查结果<必填>")
  450. * @ApiReturnParams (name="status", type="integer", required=true, sample="0", description="返回码 fail 失败 ok成功"))
  451. * @ApiReturnParams (name="code", type="integer", required=true, sample="0", description="返回状态码")
  452. * @ApiReturnParams (name="msg", type="string", required=true, sample="返回成功", description="返回消息")
  453. * @ApiReturn (data="
  454. {
  455. 'status': ok,
  456. 'code': '0000',
  457. 'msg': '已审核',
  458. }
  459. *")
  460. **/
  461. public function examine(){
  462. try{
  463. $id = $_REQUEST['id'];
  464. $status = DB::table('exams')->where('id',$id)->field('exam_status')->find();
  465. if($status['exam_status'] < 7){
  466. return json_encode(['status'=>'fail','code'=>'1032','msg'=>'只能审核已提交的报告']);
  467. }elseif($status['exam_status']>7){
  468. return json_encode(['status'=>'fail','code'=>'1035','msg'=>'报告已通过审核步骤,请勿重复操作']);
  469. }
  470. $report = DB::table('report')->where('exam_id',$id)->field('id')->find();
  471. $param = $_REQUEST['param'];
  472. $sessionid = $_REQUEST['sessionid'];
  473. $doctor = Cache::get($sessionid);
  474. if(isset($_REQUEST['is_remote']) && $_REQUEST['is_remote'] == 1){
  475. // 是远程审核报告 8
  476. $return = Verify::check_role($sessionid,8);
  477. }else{
  478. // 本地审核权限 3
  479. $return = Verify::check_role($sessionid,3);
  480. }
  481. $report_info = array();
  482. $report_info['impression'] = isset($param['impression']) ? $param['impression'] : '';
  483. $report_info['description'] = isset($param['description']) ? $param['description'] : '';
  484. if(isset($param['r_result']) && $param['r_result'] == 'true'){
  485. $report_info['report_result'] = 2;
  486. }else{
  487. $report_info['report_result'] = 1;
  488. }
  489. $report_info['review_datetime'] = date('Y-m-d H:i:s',time());
  490. $report_info['review_doctor_id'] = $doctor['id'];
  491. DB::table('report')->where('id',$report['id'])->update($report_info);
  492. $cache_key = $doctor['id'].'_'.$id;
  493. if(Cache::get($cache_key)){
  494. Cache::rm($cache_key);
  495. }
  496. $info = array();
  497. $info['id'] = UUIDs::uuid16();
  498. $info['type'] = 2; //审核
  499. $info['createdAt'] = date('Y-m-d H:i:s',time());
  500. $info['doctor_id'] = $doctor['id'];
  501. $info['impression'] = isset($param['impression']) ? $param['impression'] : '';
  502. $info['description'] = isset($param['description']) ? $param['description'] : '';
  503. $info['report_id'] = $report['id'];
  504. DB::table('report_record')->insert($info);
  505. // $exam_status = $this->get_exam_status($doctor['id'],8);
  506. DB::table('exams')->where('id',$id)->update(['exam_status'=>'8','film_type'=>$param['film_type']]);
  507. return json_encode(['status'=>'ok','code'=>'0000','msg'=>'已审核']);
  508. }catch(\Exception $e){
  509. return json_encode(['status'=>'fail','code'=>'2000','msg'=>$e->getMessage()]);
  510. }
  511. }
  512. /**
  513. * 获取报告权限
  514. *
  515. * @ApiTitle (获取报告权限)
  516. * @ApiSummary (获取报告权限)
  517. * @ApiSector (远程诊断)
  518. * @ApiMethod (POST)
  519. * @ApiRoute (/inter/writereport/getrole)
  520. * @ApiHeaders (name="sign", type="string", required=true, description="请求头-校验key")
  521. * @ApiHeaders (name="nonce", type="string", required=true, description="请求头-随机数")
  522. * @ApiHeaders (name="timestamp", type=string, required=true, description="请求头-时间戳s")
  523. * @ApiParams (name="sessionid", type="string", required=true, description="参数json字符串")
  524. * @ApiParams (name="is_remote", type="string", required=true, description="是否为远程列表进入")
  525. * @ApiReturnParams (name="status", type="integer", required=true, sample="0", description="返回码 fail 失败 ok成功"))
  526. * @ApiReturnParams (name="code", type="integer", required=true, sample="0", description="返回状态码")
  527. * @ApiReturnParams (name="info", type="string", required=true, sample="返回成功", description="返回信息")
  528. * @ApiReturn (data="
  529. {
  530. 'status': ok,
  531. 'code': '0000',
  532. 'info': '',
  533. }
  534. *")
  535. **/
  536. public function getrole(){
  537. try{
  538. if(isset($_REQUEST['is_remote']) && $_REQUEST['is_remote'] == 1){
  539. $is_remote = $_REQUEST['is_remote'];
  540. }
  541. $sessionid = $_REQUEST['sessionid'];
  542. $doctor = Cache::get($sessionid);
  543. $dclass = DB::table('doctor_class')->where('doctor_id',$doctor['id'])->field('doctor_class')->find();
  544. $doctor_class = explode(',',$dclass['doctor_class']);
  545. $info = array();
  546. foreach ($doctor_class as $k=>$v) {
  547. switch($v){
  548. case 2: //报告医生
  549. if(isset($is_remote)){
  550. //远程报告
  551. break;
  552. }
  553. $info['bg'] = 1;
  554. break;
  555. case 7: //远程报告医生
  556. if(!isset($is_remote)){
  557. //远程报告
  558. break;
  559. }
  560. $info['bg'] = 1;
  561. break;
  562. case 3: //3审核医生
  563. if(isset($is_remote)){
  564. //远程报告
  565. break;
  566. }
  567. $info['sh'] = 2;
  568. break;
  569. case 8: //远程审核医生
  570. if(!isset($is_remote)){
  571. //远程报告
  572. break;
  573. }
  574. $info['sh'] = 2;
  575. break;
  576. case 4: //确认医生
  577. $info['qr'] = 3;
  578. break;
  579. }
  580. }
  581. return json_encode(['status'=>'ok','code'=>'0000','info'=>$info]);
  582. }catch(\Exception $e){
  583. return json_encode(['status'=>'fail','code'=>'2000','msg'=>$e->getMessage()]);
  584. }
  585. }
  586. /**
  587. * 获取报告日志
  588. *
  589. * @ApiTitle (获取报告日志)
  590. * @ApiSummary (获取报告日志)
  591. * @ApiSector (远程诊断)
  592. * @ApiMethod (POST)
  593. * @ApiRoute (/inter/writereport/get_report_log)
  594. * @ApiHeaders (name="sign", type="string", required=true, description="请求头-校验key")
  595. * @ApiHeaders (name="nonce", type="string", required=true, description="请求头-随机数")
  596. * @ApiHeaders (name="timestamp", type=string, required=true, description="请求头-时间戳s")
  597. * @ApiParams (name="sessionid", type="string", required=true, description="参数json字符串")
  598. * @ApiParams (name="id", type="string", required=true, description="exams表id值")
  599. * @ApiReturnParams (name="status", type="integer", required=true, sample="0", description="返回码 fail 失败 ok成功"))
  600. * @ApiReturnParams (name="code", type="integer", required=true, sample="0", description="返回状态码")
  601. * @ApiReturnParams (name="info", type="string", required=true, sample="返回成功", description="返回信息")
  602. * @ApiReturn (data="
  603. {
  604. 'status': ok,
  605. 'code': '0000',
  606. 'info': '',
  607. }
  608. *")
  609. **/
  610. public function get_report_log(){
  611. try{
  612. $sessionid = $_REQUEST['sessionid'];
  613. $doctor = Cache::get($sessionid);
  614. $exam_id = $_REQUEST['id'];
  615. $report = DB::table('report')->where('exam_id',$exam_id)->field('id')->find();
  616. if(empty($report)){
  617. return json_encode(['status'=>'ok','code'=>'0000','info'=>'','msg'=>'无数据']);
  618. }
  619. $log_id = $report['id'];
  620. $log = DB::table('report_record')->where('doctor_id',$doctor['id'])->where('report_id',$log_id)->order('createdAt asc,type asc')->select();
  621. foreach ($log as $k => $v) {
  622. $doc = DB::table('doctors')->where('id',$v['doctor_id'])->field('realname')->find();
  623. $log[$k]['doctor_name'] = $doc['realname'];
  624. }
  625. return json_encode(['status'=>'ok','code'=>'0000','info'=>$log]);
  626. }catch(\Exception $e){
  627. return json_encode(['status'=>'fail','code'=>'2000','msg'=>$e->getMessage()]);
  628. }
  629. }
  630. /**
  631. * 打印报告
  632. *
  633. * @ApiTitle (打印报告)
  634. * @ApiSummary (打印报告)
  635. * @ApiSector (远程诊断)
  636. * @ApiMethod (POST)
  637. * @ApiRoute (/inter/writereport/print_report)
  638. * @ApiHeaders (name="sign", type="string", required=true, description="请求头-校验key")
  639. * @ApiHeaders (name="nonce", type="string", required=true, description="请求头-随机数")
  640. * @ApiHeaders (name="timestamp", type=string, required=true, description="请求头-时间戳s")
  641. * @ApiParams (name="sessionid", type="string", required=true, description="参数json字符串")
  642. * @ApiParams (name="id", type="string", required=true, description="exams表id值")
  643. * @ApiReturnParams (name="status", type="integer", required=true, sample="0", description="返回码 fail 失败 ok成功"))
  644. * @ApiReturnParams (name="code", type="integer", required=true, sample="0", description="返回状态码")
  645. * @ApiReturnParams (name="info", type="string", required=true, sample="返回成功", description="返回信息")
  646. * @ApiReturnParams (name="sessionid", type="object", sample="{}", description="缓存的数据key")
  647. * @ApiReturn (data="
  648. {
  649. 'status': ok,
  650. 'code': '0000',
  651. 'sessionid': 'a17z7a7a8f9g9rh9d89jio',
  652. 'info': '',
  653. }
  654. *")
  655. **/
  656. public function print_report(){
  657. try{
  658. $sessionid = $_REQUEST['sessionid'];
  659. $doctor = Cache::get($sessionid);
  660. $id = $_REQUEST['id'];
  661. $info = array();
  662. // 检查日期 住院号 床号
  663. $exam_info = DB::table('exams')->where('id',$id)->field('id,ext,accession_num,exam_datetime,exam_class,hopitalized_no,bed_no,exam_project,patient_id')->find();
  664. $info['id'] = $exam_info['id'];
  665. $info['ext'] = $exam_info['ext'];
  666. $info['accession_num'] = $exam_info['accession_num'];
  667. if(!empty($exam_info['exam_datetime'])){
  668. $datetime = explode(' ',$exam_info['exam_datetime']);
  669. $info['exam_datetime'] = $datetime[0];
  670. }else{
  671. $info['exam_datetime'] = '';
  672. }
  673. $info['hopitalized_no'] = $exam_info['hopitalized_no'];
  674. $info['bed_no'] = $exam_info['bed_no'];
  675. // 检查项目
  676. $project = DB::table('exam_project')->where('id',$exam_info['exam_project'])->field('name')->find();
  677. $info['project'] = $project['name'];
  678. //检查类
  679. $exam_class = DB::table('constant')->where('id',$exam_info['exam_class'])->field('constant_value')->find();
  680. $info['exam_class'] = $exam_class['constant_value'];
  681. // 病历号 姓名 年龄 性别
  682. $patient_info = DB::table('patient_infos')->where('id',$exam_info['patient_id'])->field('temp_patient_id,name,sex,age')->find();
  683. $remote = DB::table('remote_application')->where('exam_id',$id)->field('req_doctor_id')->find();
  684. $info['pnumber'] = $patient_info['temp_patient_id'];
  685. $info['name'] = $patient_info['name'];
  686. $info['sex'] = $patient_info['sex'];
  687. $info['age'] = $patient_info['age'];
  688. // 申请医生
  689. $application_name = DB::table('doctors')->where('id',$remote['req_doctor_id'])->field('realname,department_id')->find();
  690. $info['application_name'] = $application_name['realname'];
  691. // 申请科室
  692. $department = DB::table('department')->where('id',$application_name['department_id'])->field('department_name')->find();
  693. $info['department_name'] = $department['department_name'];
  694. // 报告时间 影像所见 意见建议
  695. $report = DB::table('report')->where('exam_id',$id)->field('report_datetime,impression,description,report_doctor_id,review_doctor_id')->find();
  696. if(!empty($report['report_datetime'])){
  697. $datetime1 = explode(' ',$report['report_datetime']);
  698. $info['report_datetime'] = $datetime1[0];
  699. }else{
  700. $info['report_datetime'] = '';
  701. }
  702. // $info['report_datetime'] = $report['report_datetime'];
  703. $info['impression'] = $report['impression'];
  704. $info['description'] = $report['description'];
  705. // 报告医生
  706. $report_doctor = DB::table('doctors')->where('id',$report['report_doctor_id'])->field('realname')->find();
  707. $info['report_doctor'] = $report_doctor['realname'];
  708. //审核医生
  709. $review_doctor = DB::table('doctors')->where('id',$report['review_doctor_id'])->field('realname')->find();
  710. $info['review_doctor'] = $review_doctor['realname'];
  711. $hospital = DB::table('institution')->where('id',$doctor['institution_id'])->field('name')->find();
  712. $info['hospital'] = $hospital['name'];
  713. return json_encode(['status'=>'ok','code'=>'0000','info'=>$info,'sessionid'=>$sessionid]);
  714. }catch(\Exception $e){
  715. return json_encode(['status'=>'fail','code'=>'2000','msg'=>$e->getMessage()]);
  716. }
  717. }
  718. /**
  719. * 变更胶片
  720. *
  721. * @ApiTitle (变更胶片)
  722. * @ApiSummary (变更胶片)
  723. * @ApiSector (远程诊断)
  724. * @ApiMethod (POST)
  725. * @ApiRoute (/inter/writereport/change_film)
  726. * @ApiHeaders (name="sign", type="string", required=true, description="请求头-校验key")
  727. * @ApiHeaders (name="nonce", type="string", required=true, description="请求头-随机数")
  728. * @ApiHeaders (name="timestamp", type=string, required=true, description="请求头-时间戳s")
  729. * @ApiParams (name="sessionid", type="string", required=true, description="参数json字符串")
  730. * @ApiParams (name="id", type="string", required=true, description="exams表id值")
  731. * @ApiParams (name="film_type", type="string", required=true, description="胶片")
  732. * @ApiReturnParams (name="status", type="integer", required=true, sample="0", description="返回码 fail 失败 ok成功"))
  733. * @ApiReturnParams (name="code", type="integer", required=true, sample="0", description="返回状态码")
  734. * @ApiReturnParams (name="info", type="string", required=true, sample="返回成功", description="返回信息")
  735. * @ApiReturn (data="z
  736. {
  737. 'status': ok,
  738. 'code': '0000',
  739. 'info': '',
  740. }
  741. *")
  742. **/
  743. public function change_film(){
  744. $id = $_REQUEST['id'];
  745. $film = $_REQUEST['film_type'];
  746. DB::table('exams')->where('id',$id)->update(['film_type'=>$film]);
  747. return json_encode(['status'=>'ok','info'=>$film,'code'=>'0000']);
  748. }
  749. public function draft(){
  750. $sessionid = $_REQUEST['sessionid'];
  751. $doctor = Cache::get($sessionid);
  752. $param = $_REQUEST['param'];
  753. $exam_id = $param['id'];
  754. $key = $doctor['id'].'_'.$exam_id;
  755. Cache::set($key,$param);
  756. return json_encode(['status'=>'ok','msg'=>'保存成功','code'=>'0000']);
  757. }
  758. // XA类型数据获取
  759. public function get_rinfo(){
  760. $sessionid = $_REQUEST['sessionid'];
  761. $doctor = Cache::get($sessionid);
  762. $id = $_REQUEST['id'];
  763. $key = $doctor['id'].'_'.$id;
  764. if(Cache::get($key)){
  765. $patient = Cache::get($key);
  766. }else{
  767. $exam = DB::table('exams')->where('id',$id)->field('accession_num,exam_class,patient_id,ext,hopitalized_no,bed_no')->find();
  768. $patient = DB::table('patient_infos')->where('id',$exam['patient_id'])->field(['id','temp_patient_id','name','phone','sex','age'])->find();
  769. $report_info = DB::table('report')->where('exam_id',$id)->field('description')->find();
  770. $patient['ext'] = $exam['ext'];
  771. $patient['exam_id'] = $id;
  772. $patient['bed_no'] = $exam['bed_no'];
  773. $patient['accession_num'] = $exam['accession_num'];
  774. $patient['exam_class'] = $exam['exam_class'];
  775. $patient['hopitalized_no'] = $exam['hopitalized_no'];
  776. $patient['description'] = $report_info['description'];
  777. }
  778. return json_encode(['status'=>'ok','info'=>$patient,'code'=>'0000']);
  779. }
  780. // XA类型保存
  781. public function write_info(){
  782. $sessionid = $_REQUEST['sessionid'];
  783. $doctor = Cache::get($sessionid);
  784. $param = $_REQUEST['param'];
  785. $patient_info['name'] = isset($param['name']) ? $param['name'] : '';
  786. $patient_info['sex'] = isset($param['sex']) ? $param['sex'] : '';
  787. $patient_info['age'] = isset($param['age']) ? $param['age'] : '';
  788. $exam_info['hopitalized_no'] = isset($param['hospital_number']) ? $param['hospital_number'] : '';
  789. $exam_info['bed_no'] = isset($param['bed_number']) ? $param['bed_number'] : '';
  790. $exam_info['ext'] = isset($param['ext']) ? $param['ext'] : '';
  791. $exam_info['accession_num'] = isset($param['accession_num']) ? $param['accession_num'] : '';
  792. $report['description'] = isset($param['description']) ? $param['description'] : '';
  793. DB::table('patient_infos')->where('id',$param['pid'])->update($patient_info);
  794. DB::table('exams')->where('id',$param['id'])->update($exam_info);
  795. $rinfo = DB::table('report')->where('exam_id',$param['id'])->find();
  796. if($rinfo){
  797. DB::table('report')->where('exam_id',$param['id'])->update($report);
  798. }else{
  799. $report['id'] = UUIDs::uuid16();
  800. $report['exam_id'] = $param['id'];
  801. $report['createdAt'] = date('Y-m-d H:i:s',time());
  802. $report['report_datetime'] = date('Y-m-d H:i:s',time());
  803. $report['report_doctor_id'] = $doctor['id'];
  804. DB::table('report')->insert($report);
  805. }
  806. return json_encode(['status'=>'ok','msg'=>'成功','code'=>'0000']);
  807. }
  808. }