Migrated logging options from global.php to Administration => Globals.
[openemr.git] / interface / globals.php
blob81e1e4a4237da6324ce12fe71ac38d1f0db24e70
1 <?php
2 /* $Id$ */
3 // ------------------------------------------------------------------------ //
4 // OpenEMR Electronic Medical Records System //
5 // Copyright (c) 2005-2010 oemr.org //
6 // <http://www.oemr.org/> //
7 // ------------------------------------------------------------------------ //
8 // This program is free software; you can redistribute it and/or modify //
9 // it under the terms of the GNU General Public License as published by //
10 // the Free Software Foundation; either version 2 of the License, or //
11 // (at your option) any later version. //
12 // //
13 // You may not change or alter any portion of this comment or credits //
14 // of supporting developers from this source code or any supporting //
15 // source code which is considered copyrighted (c) material of the //
16 // original comment or credit authors. //
17 // //
18 // This program is distributed in the hope that it will be useful, //
19 // but WITHOUT ANY WARRANTY; without even the implied warranty of //
20 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the //
21 // GNU General Public License for more details. //
22 // //
23 // You should have received a copy of the GNU General Public License //
24 // along with this program; if not, write to the Free Software //
25 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA //
26 // ------------------------------------------------------------------------ //
28 // Is this windows or non-windows? Create a boolean definition.
29 if (!defined('IS_WINDOWS'))
30 define('IS_WINDOWS', (stripos(PHP_OS,'WIN') === 0));
32 // Some important php.ini overrides. Defaults for these values are often
33 // too small. You might choose to adjust them further.
35 ini_set('memory_limit', '64M');
36 ini_set('session.gc_maxlifetime', '14400');
38 /* If the includer didn't specify, assume they want us to "fake" register_globals. */
39 if (!isset($fake_register_globals)) {
40 $fake_register_globals = TRUE;
43 /* Pages with "myadmin" in the URL don't need register_globals. */
44 $fake_register_globals =
45 $fake_register_globals && (strpos($_SERVER['REQUEST_URI'],"myadmin") === FALSE);
47 // Emulates register_globals = On. Moved to here from the bottom of this file
48 // to address security issues. Need to change everything requiring this!
49 if ($fake_register_globals) {
50 extract($_GET);
51 extract($_POST);
54 // This is for sanitization of all escapes.
55 // (ie. reversing magic quotes if it's set)
56 if ($sanitize_all_escapes) {
57 if (get_magic_quotes_gpc()) {
58 function undoMagicQuotes($array, $topLevel=true) {
59 $newArray = array();
60 foreach($array as $key => $value) {
61 if (!$topLevel) {
62 $key = stripslashes($key);
64 if (is_array($value)) {
65 $newArray[$key] = undoMagicQuotes($value, false);
67 else {
68 $newArray[$key] = stripslashes($value);
71 return $newArray;
73 $_GET = undoMagicQuotes($_GET);
74 $_POST = undoMagicQuotes($_POST);
75 $_COOKIE = undoMagicQuotes($_COOKIE);
76 $_REQUEST = undoMagicQuotes($_REQUEST);
81 // The webserver_root and web_root are now automatically collected.
82 // If not working, can set manually below.
83 // Auto collect the full absolute directory path for openemr.
84 $webserver_root = dirname(dirname(__FILE__));
85 if (IS_WINDOWS) {
86 //convert windows path separators
87 $webserver_root = str_replace("\\","/",$webserver_root);
89 // Auto collect the relative html path, i.e. what you would type into the web
90 // browser after the server address to get to OpenEMR.
91 $web_root = substr($webserver_root, strlen($_SERVER['DOCUMENT_ROOT']));
92 // Ensure web_root starts with a path separator
93 if (preg_match("/^[^\/]/",$web_root)) {
94 $web_root = "/".$web_root;
96 // The webserver_root and web_root are now automatically collected in
97 // real time per above code. If above is not working, can uncomment and
98 // set manually here:
99 // $webserver_root = "/var/www/openemr"
100 // $web_root = "/openemr"
103 // This is the directory that contains site-specific data. Change this
104 // only if you have some reason to.
105 $GLOBALS['OE_SITES_BASE'] = "$webserver_root/sites";
107 // The session name names a cookie stored in the browser.
108 // If you modify session_name, then need to place the identical name in
109 // the phpmyadmin file here: openemr/phpmyadmin/libraries/session.inc.php
110 // at line 71. This was required after embedded new phpmyadmin version on
111 // 05-12-2009 by Brady. Hopefully will figure out a more appropriate fix.
112 // Now that restore_session() is implemented in javaScript, session IDs are
113 // effectively saved in the top level browser window and there is no longer
114 // any need to change the session name for different OpenEMR instances.
115 session_name("OpenEMR");
117 session_start();
119 // Set the site ID if required. This must be done before any database
120 // access is attempted.
121 if (empty($_SESSION['site_id']) || !empty($_GET['site'])) {
122 if (!empty($_GET['site'])) {
123 $tmp = $_GET['site'];
125 else {
126 if (!$ignoreAuth) die("Site ID is missing from session data!");
127 $tmp = $_SERVER['HTTP_HOST'];
128 if (!is_dir($GLOBALS['OE_SITES_BASE'] . "/$tmp")) $tmp = "default";
130 if (!isset($_SESSION['site_id']) || $_SESSION['site_id'] != $tmp) {
131 $_SESSION['site_id'] = $tmp;
132 error_log("Session site ID has been set to '$tmp'"); // debugging
136 // Set the site-specific directory path.
137 $GLOBALS['OE_SITE_DIR'] = $GLOBALS['OE_SITES_BASE'] . "/" . $_SESSION['site_id'];
139 require_once($GLOBALS['OE_SITE_DIR'] . "/config.php");
141 // Collecting the utf8 disable flag from the sqlconf.php file in order
142 // to set the correct html encoding. utf8 vs iso-8859-1. If flag is set
143 // then set to iso-8859-1.
144 require_once(dirname(__FILE__) . "/../library/sqlconf.php");
145 if (!$disable_utf8_flag) {
146 ini_set('default_charset', 'utf-8');
147 $HTML_CHARSET = "UTF-8";
149 else {
150 ini_set('default_charset', 'iso-8859-1');
151 $HTML_CHARSET = "ISO-8859-1";
154 // Root directory, relative to the webserver root:
155 $GLOBALS['rootdir'] = "$web_root/interface";
156 $rootdir = $GLOBALS['rootdir'];
157 // Absolute path to the source code include and headers file directory (Full path):
158 $GLOBALS['srcdir'] = "$webserver_root/library";
159 // Absolute path to the location of documentroot directory for use with include statements:
160 $GLOBALS['fileroot'] = "$webserver_root";
161 // Absolute path to the location of interface directory for use with include statements:
162 $include_root = "$webserver_root/interface";
163 // Absolute path to the location of documentroot directory for use with include statements:
164 $GLOBALS['webroot'] = $web_root;
166 $GLOBALS['template_dir'] = $GLOBALS['fileroot'] . "/templates/";
167 $GLOBALS['incdir'] = $include_root;
168 // Location of the login screen file
169 $GLOBALS['login_screen'] = $GLOBALS['rootdir'] . "/login_screen.php";
171 // Variable set for Eligibility Verification [EDI-271] path
172 $GLOBALS['edi_271_file_path'] = $GLOBALS['OE_SITE_DIR'] . "/edi/";
174 // Include the translation engine. This will also call sql.inc to
175 // open the openemr mysql connection.
176 include_once (dirname(__FILE__) . "/../library/translation.inc.php");
178 // Includes functions for date internationalization
179 include_once (dirname(__FILE__) . "/../library/date_functions.php");
181 // Defaults for specific applications.
182 $GLOBALS['athletic_team'] = false;
183 $GLOBALS['weight_loss_clinic'] = false;
184 $GLOBALS['ippf_specific'] = false;
185 $GLOBALS['cene_specific'] = false;
187 // Defaults for drugs and products.
188 $GLOBALS['inhouse_pharmacy'] = false;
189 $GLOBALS['sell_non_drug_products'] = 0;
191 $glrow = sqlQuery("SHOW TABLES LIKE 'globals'");
192 if (!empty($glrow)) {
193 // Set global parameters from the database globals table.
194 // Some parameters require custom handling.
196 $GLOBALS['language_menu_show'] = array();
197 $glres = sqlStatement("SELECT gl_name, gl_index, gl_value FROM globals " .
198 "ORDER BY gl_name, gl_index");
199 while ($glrow = sqlFetchArray($glres)) {
200 $gl_name = $glrow['gl_name'];
201 $gl_value = $glrow['gl_value'];
202 if ($gl_name == 'language_menu_other') {
203 $GLOBALS['language_menu_show'][] = $gl_value;
205 else if ($gl_name == 'css_header') {
206 $GLOBALS[$gl_name] = "$rootdir/themes/" . $gl_value;
208 else if ($gl_name == 'specific_application') {
209 if ($gl_value == '1') $GLOBALS['athletic_team'] = true;
210 else if ($gl_value == '2') $GLOBALS['ippf_specific'] = true;
211 else if ($gl_value == '3') $GLOBALS['weight_loss_clinic'] = true;
213 else if ($gl_name == 'inhouse_pharmacy') {
214 if ($gl_value) $GLOBALS['inhouse_pharmacy'] = true;
215 if ($gl_value == '2') $GLOBALS['sell_non_drug_products'] = 1;
216 else if ($gl_value == '3') $GLOBALS['sell_non_drug_products'] = 2;
218 else {
219 $GLOBALS[$gl_name] = $glrow['gl_value'];
222 // Language cleanup stuff.
223 $GLOBALS['language_menu_login'] = false;
224 if ((count($GLOBALS['language_menu_show']) >= 1) || $GLOBALS['language_menu_showall']) {
225 $GLOBALS['language_menu_login'] = true;
228 // End of globals table processing.
230 else {
231 // Temporary stuff to handle the case where the globals table does not
232 // exist yet. This will happen in sql_upgrade.php on upgrading to the
233 // first release containing this table.
234 $GLOBALS['language_menu_login'] = true;
235 $GLOBALS['language_menu_showall'] = true;
236 $GLOBALS['language_menu_show'] = array('English (Standard)','Swedish');
237 $GLOBALS['language_default'] = "English (Standard)";
238 $GLOBALS['translate_layout'] = true;
239 $GLOBALS['translate_lists'] = true;
240 $GLOBALS['translate_gacl_groups'] = true;
241 $GLOBALS['translate_form_titles'] = true;
242 $GLOBALS['translate_document_categories'] = true;
243 $GLOBALS['translate_appt_categories'] = true;
244 $GLOBALS['concurrent_layout'] = 2;
245 $timeout = 7200;
246 $openemr_name = 'OpenEMR';
247 $css_header = "$rootdir/themes/style_sky_blue.css";
248 $GLOBALS['css_header'] = $css_header;
249 $GLOBALS['schedule_start'] = 8;
250 $GLOBALS['schedule_end'] = 17;
251 $GLOBALS['calendar_interval'] = 15;
252 $GLOBALS['phone_country_code'] = '1';
253 $GLOBALS['disable_non_default_groups'] = true;
254 $GLOBALS['ippf_specific'] = false;
258 // Lists and Layouts Control Section
261 // 'state_custom_addlist_widget'
262 // - If true, then will display a customized addlist widget for
263 // state list entries (will ask for title and abbreviation)
264 $GLOBALS['state_custom_addlist_widget'] = true;
265 $GLOBALS['state_list'] = "state";
266 $GLOBALS['country_list'] = "country";
268 // Option to set the top default window. By default, it is set
269 // to the calendar screen. The starting directory is
270 // interface/main/ , hence:
271 // The calendar screen is 'main_info.php' .
272 // The patient search/add screen is '../new/new.php' .
273 $GLOBALS['default_top_pane'] = 'main_info.php';
275 // Default category for find_patient screen
276 $GLOBALS['default_category'] = 5;
277 $GLOBALS['default_event_title'] = 'Office Visit';
279 // If >0 this will enforce a separate PHP session for each top-level
280 // browser window. You must log in separately for each. This is not
281 // thoroughly tested yet and some browsers might have trouble with it,
282 // so make it 0 if you must. Alternatively, you can set it to 2 to be
283 // notified when the session ID changes.
284 $GLOBALS['restore_sessions'] = 1; // 0=no, 1=yes, 2=yes+debug
286 // Theme definition. All this stuff should be moved to CSS.
288 if ($GLOBALS['concurrent_layout']) {
289 $top_bg_line = ' bgcolor="#dddddd" ';
290 $GLOBALS['style']['BGCOLOR2'] = "#dddddd";
291 $bottom_bg_line = $top_bg_line;
292 $title_bg_line = ' bgcolor="#bbbbbb" ';
293 $nav_bg_line = ' bgcolor="#94d6e7" ';
294 } else {
295 $top_bg_line = ' bgcolor="#94d6e7" ';
296 $GLOBALS['style']['BGCOLOR2'] = "#94d6e7";
297 $bottom_bg_line = ' background="'.$rootdir.'/pic/aquabg.gif" ';
298 $title_bg_line = ' bgcolor="#aaffff" ';
299 $nav_bg_line = ' bgcolor="#94d6e7" ';
301 $login_filler_line = ' bgcolor="#f7f0d5" ';
302 $login_body_line = ' background="'.$rootdir.'/pic/aquabg.gif" ';
303 $logocode = "<img src='$web_root/sites/" . $_SESSION['site_id'] . "/images/login_logo.gif'>";
304 $linepic = "$rootdir/pic/repeat_vline9.gif";
305 $table_bg = ' bgcolor="#cccccc" ';
306 $GLOBALS['style']['BGCOLOR1'] = "#cccccc";
307 $GLOBALS['style']['TEXTCOLOR11'] = "#222222";
308 $GLOBALS['style']['HIGHLIGHTCOLOR'] = "#dddddd";
309 $GLOBALS['style']['BOTTOM_BG_LINE'] = $bottom_bg_line;
310 // The height in pixels of the Logo bar at the top of the login page:
311 $GLOBALS['logoBarHeight'] = 110;
312 // The height in pixels of the Navigation bar:
313 $GLOBALS['navBarHeight'] = 22;
314 // The height in pixels of the Title bar:
315 $GLOBALS['titleBarHeight'] = 40;
317 // The assistant word, MORE printed next to titles that can be clicked:
318 // Note this label gets translated here via the xl function
319 // -if you don't want it translated, then strip the xl function away
320 $tmore = xl('(More)');
321 // The assistant word, BACK printed next to titles that return to previous screens:
322 // Note this label gets translated here via the xl function
323 // -if you don't want it translated, then strip the xl function away
324 $tback = xl('(Back)');
326 // This is the idle logout function:
327 // if a page has not been refreshed within this many seconds, the interface
328 // will return to the login page
329 if (!empty($special_timeout)) {
330 $timeout = intval($special_timeout);
333 //Version tags
334 require_once(dirname(__FILE__) . "/../version.php");
335 $openemr_version = "$v_major.$v_minor.$v_patch".$v_tag; // Version tag used by program
337 $srcdir = $GLOBALS['srcdir'];
338 $login_screen = $GLOBALS['login_screen'];
339 $GLOBALS['css_header'] = $css_header;
340 $GLOBALS['backpic'] = $backpic;
342 // 1 = send email message to given id for Emergency Login user activation,
343 // else 0.
344 $GLOBALS['Emergency_Login_email'] = $GLOBALS['Emergency_Login_email_id'] ? 1 : 0;
346 //set include_de_identification to enable De-identification (currently de-identification works fine only with linux machines)
347 //Run de_identification_upgrade.php script to upgrade OpenEMR database to include procedures,
348 //functions, tables for de-identification(Mysql root user and password is required for successful
349 //execution of the de-identification upgrade script)
350 $GLOBALS['include_de_identification']=0;
351 // Include the authentication module code here, but the rule is
352 // if the file has the word "login" in the source code file name,
353 // don't include the authentication module - we do this to avoid
354 // include loops.
356 if (!$ignoreAuth) {
357 include_once("$srcdir/auth.inc");
360 // If you do not want your accounting system to have a customer added to it
361 // for each insurance company, then set this to true. SQL-Ledger currently
362 // (2005-03-21) does nothing useful with insurance companies as customers.
363 $GLOBALS['insurance_companies_are_not_customers'] = true;
365 // This is the background color to apply to form fields that are searchable.
366 // Currently it is applicable only to the "Search or Add Patient" form.
367 $GLOBALS['layout_search_color'] = '#ffff55';
369 //EMAIL SETTINGS
370 $SMTP_Auth = !empty($GLOBALS['SMTP_USER']);
372 // The following credentials are provided by OpenEMR Support LLC for testing.
373 // When you sign up with their Lab Exchange service, they will provide you with your own credentials.
375 /* use this for testing
376 $LAB_EXCHANGE_SITEID = "3";
377 $LAB_EXCHANGE_TOKEN = "12345";
378 $LAB_EXCHANGE_ENDPOINT = "https://openemrsupport.com:29443/len/api";
381 $LAB_EXCHANGE_SITEID = "";
382 $LAB_EXCHANGE_TOKEN = "";
383 $LAB_EXCHANGE_ENDPOINT = "";
385 // If you want Hylafax support then uncomment and customize the following
386 // statements, and also customize custom/faxcover.txt:
388 // $GLOBALS['hylafax_server'] = 'localhost';
389 // $GLOBALS['hylafax_basedir'] = '/var/spool/fax';
390 // $GLOBALS['hylafax_enscript'] = 'enscript -M Letter -B -e^ --margins=36:36:36:36';
392 // For scanner support, uncomment and customize the following. This is
393 // the directory in which scanned-in documents may be found, and may for
394 // example be a smbfs-mounted share from the PC supporting the scanner:
396 // $GLOBALS['scanner_output_directory'] = '/mnt/scan_docs';
398 // Customize these if you are using SQL-Ledger with OpenEMR, or if you are
399 // going to run sl_convert.php to convert from SQL-Ledger.
401 $sl_cash_acc = '1060'; // sql-ledger account number for checking account
402 $sl_ar_acc = '1200'; // sql-ledger account number for accounts receivable
403 $sl_income_acc = '4320'; // sql-ledger account number for medical services income
404 $sl_services_id = 'MS'; // sql-ledger parts table id for medical services
405 $sl_dbname = 'sql-ledger'; // sql-ledger database name
406 $sl_dbuser = 'sql-ledger'; // sql-ledger database login name
407 $sl_dbpass = 'secret'; // sql-ledger database login password
408 //////////////////////////////////////////////////////////////////
410 // Don't change anything below this line. ////////////////////////////
412 $encounter = empty($_SESSION['encounter']) ? 0 : $_SESSION['encounter'];
414 if (!empty($_GET['pid']) && empty($_SESSION['pid'])) {
415 $_SESSION['pid'] = $_GET['pid'];
417 elseif (!empty($_POST['pid']) && empty($_SESSION['pid'])) {
418 $_SESSION['pid'] = $_POST['pid'];
420 $pid = empty($_SESSION['pid']) ? 0 : $_SESSION['pid'];
421 $userauthorized = empty($_SESSION['userauthorized']) ? 0 : $_SESSION['userauthorized'];
422 $groupname = empty($_SESSION['authProvider']) ? 0 : $_SESSION['authProvider'];
424 // global interface function to format text length using ellipses
425 function strterm($string,$length) {
426 if (strlen($string) >= ($length-3)) {
427 return substr($string,0,$length-3) . "...";
428 } else {
429 return $string;
433 // Override temporary_files_dir if PHP >= 5.2.1.
434 if (version_compare(phpversion(), "5.2.1", ">=")) {
435 $GLOBALS['temporary_files_dir'] = rtrim(sys_get_temp_dir(),'/');
438 // turn off PHP compatibility warnings
439 ini_set("session.bug_compat_warn","off");
441 //////////////////////////////////////////////////////////////////