forked from openemr/openemr
-
Notifications
You must be signed in to change notification settings - Fork 0
/
eRxStore.php
694 lines (646 loc) · 19.6 KB
/
eRxStore.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
<?php
/**
* interface/eRxStore.php Functions for interacting with NewCrop database.
*
* Copyright (C) 2013-2015 Sam Likins <[email protected]>
*
* LICENSE: This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by the Free
* Software Foundation; either version 3 of the License, or (at your option) any
* later version. This program is distributed in the hope that it will be
* useful, but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General
* Public License for more details. You should have received a copy of the GNU
* General Public License along with this program.
* If not, see <https://opensource.org/licenses/gpl-license.php>.
*
* @package OpenEMR
* @subpackage NewCrop
* @author Sam Likins <[email protected]>
* @link https://www.open-emr.org
*/
class eRxStore {
/**
* Strip away any non numerical characters
* @param string $value Value to sanitize
* @return string Value sanitized of all non numerical characters
*/
static public function sanitizeNumber($value) {
return preg_replace('/[^-0-9.]/', '', $value);
}
/**
* Return the primary business entity
* @return array Primary business entity
*/
public function getFacilityPrimary() {
$return = sqlQuery('SELECT `name`, `federal_ein`, `street`, `city`, `state`, `postal_code`, `country_code`, `phone`, `fax`
FROM `facility`
WHERE `primary_business_entity` = \'1\';'
);
return $return;
}
/**
* Return the Federal EIN established with the primary business entity
* @return string Federal EIN for the primary business entity
*/
public function selectFederalEin() {
$return = $this->getFacilityPrimary();
return $return['federal_ein'];
}
/**
* Return user information using user Id
* @param integer $id Id of user to return
* @return array Specified user information: index [id, username, lname, fname, mname, title, license, federaldrugid, upin, state_license_number, npi, newcrop_user_role]
*/
public function getUserById($id) {
return sqlQuery('SELECT id, username, lname, fname, mname, title, federaldrugid, upin, state_license_number, npi, newcrop_user_role
FROM users
WHERE id = ?;',
array($id)
);
}
/**
* Return user facility business entity
* @param integer $id Id of user to return
* @return array User facility business entity
*/
public function getUserFacility($id) {
return sqlQuery('SELECT facility.id, facility.name, facility.street, facility.city, facility.state, facility.postal_code, facility.country_code, facility.phone, facility.fax
FROM users
LEFT JOIN facility ON facility.id = users.facility_id
WHERE users.id = ?;',
array($id)
);
}
/**
* Return patient information using patient Id
* @param integer $patientId Id of patient
* @return array Specified patient information: index [pid, fname, mname, lname, street, city, state, postal_code, country_code, phone_home, date_of_birth, sex]
*/
public function getPatientByPatientId($patientId) {
return sqlQuery('SELECT pid, fname, mname, lname, street, city, state, postal_code, country_code, phone_home, DATE_FORMAT(DOB,\'%Y%m%d\') AS date_of_birth, sex
FROM patient_data
WHERE pid = ?;',
array($patientId)
);
}
public function getPatientHealthplansByPatientId($patientId) {
return sqlStatement('SELECT `ins`.`name`
FROM (
SELECT
`id`.`type`,
`ic`.`name`
FROM `insurance_data` AS `id`
LEFT JOIN `insurance_companies` AS `ic` ON `ic`.`id` = `id`.`provider`
WHERE `id`.`pid` = ?
AND `id`.`subscriber_relationship` = \'self\'
AND `id`.`provider` > 0
ORDER BY `id`.`date` DESC
) AS `ins`
GROUP BY `ins`.`type`;',
array($patientId)
);
}
public function getPatientAllergiesByPatientId($patientId) {
return sqlStatement('SELECT id, lists.title as title1, list_options.title as title2, comments
FROM lists
LEFT JOIN list_options ON lists.outcome = list_options.option_id
AND list_options.list_id = \'outcome\'
WHERE `type` = \'allergy\'
AND pid = ?
AND erx_source = \'0\'
AND erx_uploaded = \'0\'
AND (
enddate is NULL
OR enddate = \'\'
OR enddate = \'0000-00-00\'
);',
array($patientId)
);
}
/**
* Return TTL timestamp for provided patient Id and process
* @param string $process SOAP process to check
* @param integer $patientId Patient Id to check
* @return string|boolean TTL timestamp of last SOAP call for provided patient Id and process
*/
public function getLastSOAP($process, $patientId) {
$return = sqlQuery('SELECT updated
FROM erx_ttl_touch
WHERE patient_id = ?
AND process = ?;',
array(
$patientId,
$process
)
);
if($return === false)
return false;
return $return['updated'];
}
/**
* Set TTL timestamp for provided patient Id and process
* @param string $process SOAP process to update
* @param integer $patientId Patient Id to update
*/
public function setLastSOAP($process, $patientId) {
sqlQuery('REPLACE INTO erx_ttl_touch
SET patient_id = ?,
process = ?,
updated = NOW();',
array(
$patientId,
$process
)
);
}
/**
* Update external sourced prescripts active status for provided patient Id
* @param integer $patientId Patient Id to update
* @param integer $active Active status to set for provided patient
*/
public function updatePrescriptionsActiveByPatientId($patientId, $active = 0) {
sqlQuery('UPDATE prescriptions
SET active = ?
WHERE patient_id = ?
AND erx_source=\'1\'',
array(
($active == 1 ? 1 : 0),
$patientId
)
);
}
public function updatePrescriptionsUploadActiveByPatientIdPrescriptionId($upload, $active, $patientId, $prescriptionId) {
sqlQuery('UPDATE prescriptions
SET erx_uploaded = ?,
active = ?
WHERE patient_id = ?
AND id = ?;',
array(
$upload,
$active,
$patientId,
$prescriptionId
)
);
}
/**
* Return prescription specified
* @param integer $prescriptionId Id of the prescription to return
* @return array Prescription information specified
*/
public function getPrescriptionById($prescriptionId) {
return sqlQuery('SELECT p.note, p.dosage, p.substitute, p.per_refill, p.form, p.route, p.size, p.interval, p.drug, p.quantity,
p.id AS prescid, l1.title AS title1, l2.title AS title2, l3.title AS title3, l4.title AS title4,
DATE_FORMAT(date_added,\'%Y%m%d\') AS date_added, CONCAT_WS(fname, \' \', mname, \' \', lname) AS docname
FROM prescriptions AS p
LEFT JOIN users AS u ON p.provider_id = u.id
LEFT JOIN list_options AS l1 ON l1.list_id = \'drug_form\'
AND l1.option_id = p.form
LEFT JOIN list_options AS l2 ON l2.list_id = \'drug_route\'
AND l2.option_id = p.route
LEFT JOIN list_options AS l3 ON l3.list_id = \'drug_interval\'
AND l3.option_id = p.interval
LEFT JOIN list_options AS l4 ON l4.list_id = \'drug_units\'
AND l4.option_id = p.unit
WHERE p.drug <> \'\'
AND p.id = ?;',
array($prescriptionId)
);
}
public function selectMedicationsNotUploadedByPatientId($patientId, $uploadActive, $limit) {
return sqlStatement('SELECT id, begdate, title
FROM lists
WHERE type = \'medication\'
AND pid = ?
AND title <> \'\'
AND erx_uploaded = \'0\'
AND (? = 0
OR (enddate IS NULL
OR enddate = \'\'
OR enddate = \'0000-00-00\'
)
)
ORDER BY enddate
LIMIT 0, ?;',
array(
$patientId,
$uploadActive,
$limit
)
);
}
public function selectPrescriptionIdsNotUploadedByPatientId($patientId, $uploadActive, $limit) {
return sqlStatement('SELECT id
FROM prescriptions
WHERE patient_id = ?
AND erx_source = \'0\'
AND erx_uploaded = \'0\'
AND (? = 0
OR active = 1
) LIMIT 0, ?;',
array(
$patientId,
$uploadActive,
$limit,
)
);
}
/**
* Return option Id for title text of specified list
* @param string $listId Id of list to reference
* @param string $title Title text to find
* @return string Option Id of selected list item
*/
public function selectOptionIdByTitle($listId, $title) {
$return = sqlQuery('SELECT option_id
FROM list_options
WHERE list_id = ?
AND title = ?;',
array(
$listId,
$title
)
);
if(is_array($return))
$return = $return['option_id'];
return $return;
}
/**
* Return highest option Id for provided list Id
* @param string $listId Id of list to reference
* @return integer Highest option Id for provided list Id
*/
public function selectOptionIdsByListId($listId) {
$return = sqlQuery('SELECT option_id
FROM list_options
WHERE list_id = ?
ORDER BY ABS(option_id) DESC
LIMIT 1;',
array($listId)
);
if(is_array($return))
$return = $return['option_id'];
return $return;
}
/**
* Return user Id by user name
* @param string $name Name of user to reference
* @return integer Id of provided user name
*/
public function selectUserIdByUserName($name) {
$return = sqlQuery('SELECT id
FROM users
WHERE username = ?;',
array($name)
);
return $return['id'];
}
/**
* Insert new option to specified list
* @param string $listId Id of list to add option to
* @param string $optionId Option Id to add to referenced list
* @param string $title Title of option to add to new option
*/
public function insertListOptions($listId, $optionId, $title) {
sqlQuery('INSERT INTO list_options
(list_id, option_id, title, seq)
VALUES
(?, ?, ?, ?);',
array(
$listId,
$optionId,
$title,
$optionId
)
);
}
/**
* Return Id of prescription selected by GUID and patient Id
* @param string $prescriptionGuid GUID of prescription
* @param integer $patientId Id of patient
* @return resource Prescription Id of specified GUID for selected patient, this resource comes from a call to mysql_query()
*/
public function selectPrescriptionIdByGuidPatientId($prescriptionGuid, $patientId) {
return sqlStatement('SELECT id
FROM prescriptions
WHERE prescriptionguid = ?
AND prescriptionguid IS NOT NULL
AND patient_id = ?;',
array(
$prescriptionGuid,
$patientId
)
);
}
/**
* Insert new prescription as external sourced
* @param array $prescriptionData Information for creating prescription: [PrescriptionDate, DrugName, DrugID, DrugInfo, DosageNumberDescription, Strength, Refills, PrescriptionNotes, SiteID, rxcui, PrescriptionGuid, ExternalPatientID]
* @param integer $encounter Id of encounter for prescription
* @param integer $providerId Id of provider for prescription
* @param string $authUserId Id of user creating prescription
* @param integer $formOptionId Option Id for prescription form
* @param integer $routeOptionId Option Id for prescription route
* @param integer $unitsOptionId Option Id for prescription units
* @param integer $intervalOptionId Option Id for prescription interval
* @return integer Id of newly created prescription
*/
public function insertPrescriptions($prescriptionData, $encounter, $providerId, $authUserId, $formOptionId, $routeOptionId, $unitsOptionId, $intervalOptionId) {
return sqlInsert('INSERT INTO `prescriptions`
(
`datetime`,
`erx_source`,
`encounter`,
`date_added`,
`user`,
`provider_id`,
`form`,
`unit`,
`route`,
`interval`,
`drug`,
`drug_id`,
`drug_info_erx`,
`dosage`,
`size`,
`refills`,
`note`,
`site`,
`rxnorm_drugcode`,
`prescriptionguid`,
`patient_id`
)
VALUES
(
NOW(), \'1\', ?, ?, ?,
?, ?, ?, ?, ?, ?, ?, ?,
?, ?, ?, ?, ?, ?, ?, ?
);',
array(
$encounter,
substr($prescriptionData['PrescriptionDate'], 0, 10),
$authUserId,
$providerId,
$formOptionId,
$unitsOptionId,
$routeOptionId,
$intervalOptionId,
$prescriptionData['DrugName'],
$prescriptionData['DrugID'],
$prescriptionData['DrugInfo'],
$prescriptionData['DosageNumberDescription'],
self::sanitizeNumber($prescriptionData['Strength']),
$prescriptionData['Refills'],
$prescriptionData['PrescriptionNotes'],
$prescriptionData['SiteID'],
$prescriptionData['rxcui'],
$prescriptionData['PrescriptionGuid'],
$prescriptionData['ExternalPatientID']
)
);
}
/**
* Update prescription information as external sourced
* @param array $prescriptionData Information for creating prescription: [DrugName, DrugID, DrugInfo, DosageNumberDescription, Strength, Refills, PrescriptionNotes, SiteID, rxcui, PrescriptionGuid, ExternalPatientID]
* @param integer $providerId Id of provider for prescription
* @param string $authUserId Id of user creating prescription
* @param integer $formOptionId Option Id for prescription form
* @param integer $routeOptionId Option Id for prescription route
* @param integer $unitsOptionId Option Id for prescription units
* @param integer $intervalOptionId Option Id for prescription interval
*/
public function updatePrescriptions($prescriptionData, $providerId, $authUserId, $formOptionId, $routeOptionId, $unitsOptionId, $intervalOptionId) {
sqlQuery('UPDATE prescriptions SET
`datetime` = NOW(),
`erx_source` = \'1\',
`active` = \'1\',
`user` = ?,
`provider_id` = ?,
`form` = ?,
`unit` = ?,
`route` = ?,
`interval` = ?,
`drug` = ?,
`drug_id` = ?,
`drug_info_erx` = ?,
`dosage` = ?,
`size` = ?,
`refills` = ?,
`note` = ?,
`site` = ?,
`rxnorm_drugcode` = ?
WHERE prescriptionguid = ?
AND patient_id = ?;',
array(
$authUserId,
$providerId,
$formOptionId,
$unitsOptionId,
$routeOptionId,
$intervalOptionId,
$prescriptionData['DrugName'],
$prescriptionData['DrugID'],
$prescriptionData['DrugInfo'],
$prescriptionData['DosageNumberDescription'],
self::sanitizeNumber($prescriptionData['Strength']),
$prescriptionData['Refills'],
$prescriptionData['PrescriptionNotes'],
$prescriptionData['SiteID'],
$prescriptionData['rxcui'],
$prescriptionData['PrescriptionGuid'],
$prescriptionData['ExternalPatientID']
)
);
}
/**
* Return eRx source of specified active allergy for selected patient
* @param integer $patientId Id of patient to select
* @param string $name Name of active allergy to return
* @return integer eRx source flag of specified allergy for selected patient: [0 = OpenEMR, 1 = External]
*/
public function selectAllergyErxSourceByPatientIdName($patientId, $name) {
$return = sqlQuery('SELECT erx_source
FROM lists
WHERE pid = ?
AND type = \'allergy\'
AND title = ?
AND (
enddate IS NULL
OR enddate = \'\'
OR enddate = \'0000-00-00\'
);',
array(
$patientId,
$name
)
);
if(is_array($return))
$return = $return['erx_source'];
return $return;
}
/**
* Insert new allergy as external sourced
* @param string $name Allergy name to insert
* @param integer $allergyId External allergy Id
* @param integer $patientId Patient Id
* @param integer $authUserId User Id
* @param integer $outcome Allergy option Id
*/
public function insertAllergy($name, $allergyId, $patientId, $authUserId, $outcome) {
sqlQuery('INSERT INTO lists
(
date, type, erx_source, begdate,
title, external_allergyid, pid, user, outcome
)
VALUES
(
NOW(), \'allergy\', \'1\', NOW(),
?, ?, ?, ?, ?
);',
array(
$name,
$allergyId,
$patientId,
$authUserId,
$outcome
)
);
setListTouch($patientId, 'allergy');
}
/**
* Update allergy outcome and external Id as external sourced using patient Id and allergy name
* @param integer $outcome Allergy outcome Id to set
* @param integer $externalId External allergy Id to set
* @param integer $patientId Patient Id to select
* @param string $name Allergy name to select
*/
public function updateAllergyOutcomeExternalIdByPatientIdName($outcome, $externalId, $patientId, $name) {
sqlQuery('UPDATE lists
SET outcome = ?,
erx_source = \'1\',
external_allergyid = ?
WHERE pid = ?
AND title = ?;',
array(
$outcome,
$externalId,
$patientId,
$name
)
);
}
/**
* Update external sourced allergy outcome using patient Id, external Id, and allergy name
* @param integer $outcome Allergy outcome Id to set
* @param integer $patientId Patient Id to select
* @param integer $externalId External allergy Id to select
* @param string $name Allergy name to select
*/
public function updateAllergyOutcomeByPatientIdExternalIdName($outcome, $patientId, $externalId, $name) {
sqlQuery('UPDATE lists
SET outcome = ?
WHERE pid = ?
AND erx_source = \'1\'
AND external_allergyid = ?
AND title = ?;',
array(
$outcome,
$patientId,
$externalId,
$name
)
);
}
public function updateAllergyUploadedByPatientIdAllergyId($uploaded, $patientId, $allergyId) {
sqlQuery('UPDATE lists
SET erx_uploaded = ?
WHERE type = \'allergy\'
AND pid = ?
AND id = ?;',
array(
$uploaded,
$patientId,
$allergyId
)
);
}
/**
* Return all external sourced active allergies for patient using patient Id
* @param integer $patientId Patient Id to select
* @return resource Patients active allergies, this resource comes from a call to mysql_query()
*/
public function selectActiveAllergiesByPatientId($patientId) {
return sqlStatement('SELECT id, title
FROM lists
WHERE pid = ?
AND type = \'allergy\'
AND erx_source = \'1\'
AND (
enddate IS NULL
OR enddate = \'\'
OR enddate = \'0000-00-00\'
);',
array($patientId)
);
}
/**
* Update allergy end date for specified patient Id and list Id
* @param integer $patientId Id of patient to lookup
* @param integer $listId Id of allergy to update
*/
public function updateAllergyEndDateByPatientIdListId($patientId, $listId) {
sqlQuery('UPDATE lists
SET enddate = now()
WHERE pid = ?
AND id = ?
AND type = \'allergy\';',
array(
$patientId,
$listId
)
);
}
/**
* Update eRx uploaded status using list Id
* @param integer $listId Id of list item
* @param integer $erx [optional - defaults to 0] Upload status to set: [0 = Pending NewCrop upload, 1 = Uploaded TO NewCrop]
*/
public function updateErxUploadedByListId($listId, $erx = 0) {
sqlQuery('UPDATE lists
SET erx_uploaded = ?
WHERE id = ?;',
array(
$erx,
$listId
)
);
}
/**
* Return patient import status using patient Id
* @param integer $patientId Id of patient
* @return integer Import status for specified patient: [1 = Prescription Press, 2 = Prescription Import, 3 = Allergy Press, 4 = Allergy Import]
*/
public function getPatientImportStatusByPatientId($patientId) {
$return = sqlquery('SELECT soap_import_status
FROM patient_data
WHERE pid = ?;',
array($patientId)
);
return $return['soap_import_status'];
}
/**
* Update patient import status using patient Id
* @param integer $patientId Id of patient to update
* @param integer $status Import status to update specified patient: [1 = Prescription Press, 2 = Prescription Import, 3 = Allergy Press, 4 = Allergy Import]
*/
public function updatePatientImportStatusByPatientId($patientId, $status) {
sqlQuery('UPDATE patient_data
SET soap_import_status = ?
WHERE pid = ?;',
array(
$status,
$patientId
)
);
}
}