3 * Command-line / Unattended document import utility.
6 * site - As required for all cronjobs
7 * path - $GLOBALS key specifying the path
8 * pid - patient id to be used for all selected documents
9 * category - encoded category description to assign all selected documents
10 * limit - Maximum number of files to be imported
11 * in_situ - Retain documents in current folder
14 * 1. To import received faxes:
15 * a. Set 'Scanner Directory' to network location where a fax machine can save received files
16 * b. Schedule cronjob '/usr/bin/php -f /var/www/html/emr/custom/zutil.cli.doc_import.php site=default'
17 * c. View and process received faxes using 'New Documents' menu.
19 * 2. To import collection of medical record files for a specific patient:
20 * a. Save files in Scanner Directory
21 * b. For patient nnn and category 'Patient Records', access this script online with request parameters as:
22 * zutil.cli.doc_import?site=default&pid=nnn&category=Patient+Records&limit=1000
24 * 3. Use in_situ=true option to create document records without relocating the files.
25 * This option requires good understanding of current functionality.
28 * @link http://www.open-emr.org
29 * @author MD Support <mdsupport@users.sf.net>
30 * @copyright Copyright (c) 2017 MD Support <mdsupport@users.sf.net>
31 * @license https://github.com/openemr/openemr/blob/master/LICENSE GNU General Public License 3
34 // Allow this script to be run as a cronjob
35 require_once(dirname(__FILE__
, 2)."/library/allow_cronjobs.php");
39 'path' => 'scanner_output_directory',
47 foreach ($arg as $key => $def) {
48 if (isset($_GET[$key])) {
49 $arg[$key] = $_GET[$key];
53 require_once(dirname(__FILE__
, 2)."/interface/globals.php");
54 require_once("$srcdir/documents.php");
56 if (isset($GLOBALS[$arg['path']])) {
57 $arg['path'] = $GLOBALS[$arg['path']];
60 if ($arg['category'] != 1) {
61 $rec_cat = sqlQuery('SELECT id FROM categories WHERE name=?', array(urldecode($arg['category'])));
62 if (isset($rec_cat['id'])) {
63 $arg['category'] = $rec_cat['id'];
66 // Defined here as fallback
68 "pdf" => "application/pdf",
69 "exe" => "application/octet-stream",
70 "zip" => "application/zip",
71 "docx" => "application/msword",
72 "doc" => "application/msword",
73 "xls" => "application/vnd.ms-excel",
74 "ppt" => "application/vnd.ms-powerpoint",
77 "jpeg" => "image/jpg",
79 "mp3" => "audio/mpeg",
80 "wav" => "audio/x-wav",
81 "mpeg" => "video/mpeg",
82 "mpg" => "video/mpeg",
83 "mpe" => "video/mpeg",
84 "mov" => "video/quicktime",
85 "avi" => "video/x-msvideo",
86 "3gp" => "video/3gpp",
88 "jsc" => "application/javascript",
89 "js" => "application/javascript",
95 printf('%s %s %s (%s)%s', xlt('Import'), text($arg['limit']), xlt('documents'), text($arg['path']), "\n");
97 $docs = new DirectoryIterator($arg['path']);
98 foreach ($docs as $doc) {
103 $doc_pathname = $doc->getPathname();
104 $doc_url = "file://".$doc_pathname;
106 $finfo = finfo_open();
107 $str_mime = finfo_file($finfo, $doc_pathname, FILEINFO_MIME_TYPE
);
111 $str_mime = $ext2mime[$doc->getExtension()];
114 if ($arg['in_situ']) {
115 // Skip prior documents
116 // mdsupport - Check both formats since there is no consistent code for managing urls.
117 $rec_doc = sqlQuery('SELECT id FROM documents WHERE url=? or url=?', array($doc_pathname, $doc_url));
118 if (isset($rec_doc['id'])) {
121 // mdsupport - This should be a standard method with DocStore variations. Until then,
122 // Create a document record for file
123 $objDoc = new Document();
124 $objDoc->set_storagemethod('0');
125 $objDoc->set_mimetype($str_mime);
126 $objDoc->set_url($doc_url);
127 $objDoc->set_size($doc->getSize());
128 $objDoc->set_hash(sha1_file($doc_pathname));
129 $objDoc->set_type($objDoc->type_array
['file_url']);
130 $objDoc->set_owner('');
131 $objDoc->set_foreign_id($arg['pid']);
134 // mdsupport - Need set_category method for the Document
135 if (is_numeric($objDoc->get_id())) {
136 sqlInsert("INSERT INTO categories_to_documents(category_id, document_id) VALUES(?,?)", array($arg['category'], $objDoc->get_id()));
138 printf('%s - %s%s', text($doc_pathname), (is_numeric($objDoc->get_id()) ?
text($objDoc->get_url()) : xlt('Documents setup error')), "\n");
140 // Too many parameters for the function make the following setup necessary for readability.
142 'name' => $doc->getFilename(),
143 'mime_type' => $str_mime,
144 'full_path' => $doc_pathname,
145 'upload_error' => '',
146 'size' => $doc->getSize(),
148 'patient_id' => $arg['pid'],
149 'category_id' => '1',
150 'higher_level_path' => '',
153 $new_doc = call_user_func_array('addNewDocument', $doc_params);
154 printf('%s - %s%s', text($doc_pathname), (isset($new_doc) ?
text($new_doc->get_url()) : xlt('Documents setup error')), "\n");
157 } elseif (!unlink($doc_pathname)) {
158 printf('%s - %s', text($doc_pathname), xlt('Original file deletion error'));
162 if (--$arg['limit'] < 1) {