Fixed bug: https://sourceforge.net/p/openemr/bugs/416/
[openemr.git] / interface / globals.php
blob8bd8458e165603b4f0590d65cb1d32e8c66bf882
1 <?php
3 // Is this windows or non-windows? Create a boolean definition.
4 if (!defined('IS_WINDOWS'))
5 define('IS_WINDOWS', (stripos(PHP_OS,'WIN') === 0));
7 // Some important php.ini overrides. Defaults for these values are often
8 // too small. You might choose to adjust them further.
9 //
10 ini_set('session.gc_maxlifetime', '14400');
12 // This is for sanitization of all escapes.
13 // (ie. reversing magic quotes if it's set)
14 if (isset($sanitize_all_escapes) && $sanitize_all_escapes) {
15 if (get_magic_quotes_gpc()) {
16 function undoMagicQuotes($array, $topLevel=true) {
17 $newArray = array();
18 foreach($array as $key => $value) {
19 if (!$topLevel) {
20 $key = stripslashes($key);
22 if (is_array($value)) {
23 $newArray[$key] = undoMagicQuotes($value, false);
25 else {
26 $newArray[$key] = stripslashes($value);
29 return $newArray;
31 $_GET = undoMagicQuotes($_GET);
32 $_POST = undoMagicQuotes($_POST);
33 $_COOKIE = undoMagicQuotes($_COOKIE);
34 $_REQUEST = undoMagicQuotes($_REQUEST);
39 // The webserver_root and web_root are now automatically collected.
40 // If not working, can set manually below.
41 // Auto collect the full absolute directory path for openemr.
42 $webserver_root = dirname(dirname(__FILE__));
43 if (IS_WINDOWS) {
44 //convert windows path separators
45 $webserver_root = str_replace("\\","/",$webserver_root);
47 // Collect the apache server document root (and convert to windows slashes, if needed)
48 $server_document_root = realpath($_SERVER['DOCUMENT_ROOT']);
49 if (IS_WINDOWS) {
50 //convert windows path separators
51 $server_document_root = str_replace("\\","/",$server_document_root);
53 // Auto collect the relative html path, i.e. what you would type into the web
54 // browser after the server address to get to OpenEMR.
55 // This removes the leading portion of $webserver_root that it has in common with the web server's document
56 // root and assigns the result to $web_root. In addition to the common case where $webserver_root is
57 // /var/www/openemr and document root is /var/www, this also handles the case where document root is
58 // /var/www/html and there is an Apache "Alias" command that directs /openemr to /var/www/openemr.
59 $web_root = substr($webserver_root, strspn($webserver_root ^ $server_document_root, "\0"));
60 // Ensure web_root starts with a path separator
61 if (preg_match("/^[^\/]/",$web_root)) {
62 $web_root = "/".$web_root;
64 // The webserver_root and web_root are now automatically collected in
65 // real time per above code. If above is not working, can uncomment and
66 // set manually here:
67 // $webserver_root = "/var/www/openemr";
68 // $web_root = "/openemr";
71 // This is the directory that contains site-specific data. Change this
72 // only if you have some reason to.
73 $GLOBALS['OE_SITES_BASE'] = "$webserver_root/sites";
75 // The session name names a cookie stored in the browser.
76 // Now that restore_session() is implemented in javaScript, session IDs are
77 // effectively saved in the top level browser window and there is no longer
78 // any need to change the session name for different OpenEMR instances.
79 session_name("OpenEMR");
81 session_start();
83 // Set the site ID if required. This must be done before any database
84 // access is attempted.
85 if (empty($_SESSION['site_id']) || !empty($_GET['site'])) {
86 if (!empty($_GET['site'])) {
87 $tmp = $_GET['site'];
89 else {
90 if (!$ignoreAuth) die("Site ID is missing from session data!");
91 $tmp = $_SERVER['HTTP_HOST'];
92 if (!is_dir($GLOBALS['OE_SITES_BASE'] . "/$tmp")) $tmp = "default";
94 if (empty($tmp) || preg_match('/[^A-Za-z0-9\\-.]/', $tmp))
95 die("Site ID '". htmlspecialchars($tmp,ENT_NOQUOTES) . "' contains invalid characters.");
96 if (isset($_SESSION['site_id']) && ($_SESSION['site_id'] != $tmp)) {
97 // This is to prevent using session to penetrate other OpenEMR instances within same multisite module
98 session_unset(); // clear session, clean logout
99 if (isset($landingpage) && !empty($landingpage)) {
100 // OpenEMR Patient Portal use
101 header('Location: index.php?site='.$tmp);
103 else {
104 // Main OpenEMR use
105 header('Location: ../login/login_frame.php?site='.$tmp); // Assuming in the interface/main directory
107 exit;
109 if (!isset($_SESSION['site_id']) || $_SESSION['site_id'] != $tmp) {
110 $_SESSION['site_id'] = $tmp;
111 //error_log("Session site ID has been set to '$tmp'"); // debugging
115 // Set the site-specific directory path.
116 $GLOBALS['OE_SITE_DIR'] = $GLOBALS['OE_SITES_BASE'] . "/" . $_SESSION['site_id'];
118 require_once($GLOBALS['OE_SITE_DIR'] . "/config.php");
120 // Collecting the utf8 disable flag from the sqlconf.php file in order
121 // to set the correct html encoding. utf8 vs iso-8859-1. If flag is set
122 // then set to iso-8859-1.
123 require_once(dirname(__FILE__) . "/../library/sqlconf.php");
124 if (!$disable_utf8_flag) {
125 ini_set('default_charset', 'utf-8');
126 $HTML_CHARSET = "UTF-8";
128 else {
129 ini_set('default_charset', 'iso-8859-1');
130 $HTML_CHARSET = "ISO-8859-1";
133 // Root directory, relative to the webserver root:
134 $GLOBALS['rootdir'] = "$web_root/interface";
135 $rootdir = $GLOBALS['rootdir'];
136 // Absolute path to the source code include and headers file directory (Full path):
137 $GLOBALS['srcdir'] = "$webserver_root/library";
138 // Absolute path to the location of documentroot directory for use with include statements:
139 $GLOBALS['fileroot'] = "$webserver_root";
140 // Absolute path to the location of interface directory for use with include statements:
141 $include_root = "$webserver_root/interface";
142 // Absolute path to the location of documentroot directory for use with include statements:
143 $GLOBALS['webroot'] = $web_root;
145 $GLOBALS['template_dir'] = $GLOBALS['fileroot'] . "/templates/";
146 $GLOBALS['incdir'] = $include_root;
147 // Location of the login screen file
148 $GLOBALS['login_screen'] = $GLOBALS['rootdir'] . "/login_screen.php";
150 // Variable set for Eligibility Verification [EDI-271] path
151 $GLOBALS['edi_271_file_path'] = $GLOBALS['OE_SITE_DIR'] . "/edi/";
153 // Include the translation engine. This will also call sql.inc to
154 // open the openemr mysql connection.
155 include_once (dirname(__FILE__) . "/../library/translation.inc.php");
157 // Include convenience functions with shorter names than "htmlspecialchars" (for security)
158 require_once (dirname(__FILE__) . "/../library/htmlspecialchars.inc.php");
160 // Include sanitization/checking functions (for security)
161 require_once (dirname(__FILE__) . "/../library/formdata.inc.php");
163 // Include sanitization/checking function (for security)
164 require_once (dirname(__FILE__) . "/../library/sanitize.inc.php");
166 // Includes functions for date internationalization
167 include_once (dirname(__FILE__) . "/../library/date_functions.php");
169 // Defaults for specific applications.
170 $GLOBALS['athletic_team'] = false;
171 $GLOBALS['weight_loss_clinic'] = false;
172 $GLOBALS['ippf_specific'] = false;
173 $GLOBALS['cene_specific'] = false;
175 // Defaults for drugs and products.
176 $GLOBALS['inhouse_pharmacy'] = false;
177 $GLOBALS['sell_non_drug_products'] = 0;
179 $glrow = sqlQuery("SHOW TABLES LIKE 'globals'");
180 if (!empty($glrow)) {
181 // Collect user specific settings from user_settings table.
183 $gl_user = array();
184 if (!empty($_SESSION['authUserID'])) {
185 $glres_user = sqlStatement("SELECT `setting_label`, `setting_value` " .
186 "FROM `user_settings` " .
187 "WHERE `setting_user` = ? " .
188 "AND `setting_label` LIKE 'global:%'", array($_SESSION['authUserID']) );
189 for($iter=0; $row=sqlFetchArray($glres_user); $iter++) {
190 //remove global_ prefix from label
191 $row['setting_label'] = substr($row['setting_label'],7);
192 $gl_user[$iter]=$row;
195 // Set global parameters from the database globals table.
196 // Some parameters require custom handling.
198 $GLOBALS['language_menu_show'] = array();
199 $glres = sqlStatement("SELECT gl_name, gl_index, gl_value FROM globals " .
200 "ORDER BY gl_name, gl_index");
201 while ($glrow = sqlFetchArray($glres)) {
202 $gl_name = $glrow['gl_name'];
203 $gl_value = $glrow['gl_value'];
204 // Adjust for user specific settings
205 if (!empty($gl_user)) {
206 foreach ($gl_user as $setting) {
207 if ($gl_name == $setting['setting_label']) {
208 $gl_value = $setting['setting_value'];
212 if ($gl_name == 'language_menu_other') {
213 $GLOBALS['language_menu_show'][] = $gl_value;
215 else if ($gl_name == 'css_header') {
216 $GLOBALS[$gl_name] = "$rootdir/themes/" . $gl_value;
218 else if ($gl_name == 'specific_application') {
219 if ($gl_value == '1') $GLOBALS['athletic_team'] = true;
220 else if ($gl_value == '2') $GLOBALS['ippf_specific'] = true;
221 else if ($gl_value == '3') $GLOBALS['weight_loss_clinic'] = true;
223 else if ($gl_name == 'inhouse_pharmacy') {
224 if ($gl_value) $GLOBALS['inhouse_pharmacy'] = true;
225 if ($gl_value == '2') $GLOBALS['sell_non_drug_products'] = 1;
226 else if ($gl_value == '3') $GLOBALS['sell_non_drug_products'] = 2;
228 else {
229 $GLOBALS[$gl_name] = $gl_value;
232 // Language cleanup stuff.
233 $GLOBALS['language_menu_login'] = false;
234 if ((count($GLOBALS['language_menu_show']) >= 1) || $GLOBALS['language_menu_showall']) {
235 $GLOBALS['language_menu_login'] = true;
238 // End of globals table processing.
240 else {
241 // Temporary stuff to handle the case where the globals table does not
242 // exist yet. This will happen in sql_upgrade.php on upgrading to the
243 // first release containing this table.
244 $GLOBALS['language_menu_login'] = true;
245 $GLOBALS['language_menu_showall'] = true;
246 $GLOBALS['language_menu_show'] = array('English (Standard)','Swedish');
247 $GLOBALS['language_default'] = "English (Standard)";
248 $GLOBALS['translate_layout'] = true;
249 $GLOBALS['translate_lists'] = true;
250 $GLOBALS['translate_gacl_groups'] = true;
251 $GLOBALS['translate_form_titles'] = true;
252 $GLOBALS['translate_document_categories'] = true;
253 $GLOBALS['translate_appt_categories'] = true;
254 $GLOBALS['concurrent_layout'] = 2;
255 $timeout = 7200;
256 $openemr_name = 'OpenEMR';
257 $css_header = "$rootdir/themes/style_default.css";
258 $GLOBALS['css_header'] = $css_header;
259 $GLOBALS['schedule_start'] = 8;
260 $GLOBALS['schedule_end'] = 17;
261 $GLOBALS['calendar_interval'] = 15;
262 $GLOBALS['phone_country_code'] = '1';
263 $GLOBALS['disable_non_default_groups'] = true;
264 $GLOBALS['ippf_specific'] = false;
267 // If >0 this will enforce a separate PHP session for each top-level
268 // browser window. You must log in separately for each. This is not
269 // thoroughly tested yet and some browsers might have trouble with it,
270 // so make it 0 if you must. Alternatively, you can set it to 2 to be
271 // notified when the session ID changes.
272 $GLOBALS['restore_sessions'] = 1; // 0=no, 1=yes, 2=yes+debug
274 // Theme definition. All this stuff should be moved to CSS.
276 if ($GLOBALS['concurrent_layout']) {
277 $top_bg_line = ' bgcolor="#dddddd" ';
278 $GLOBALS['style']['BGCOLOR2'] = "#dddddd";
279 $bottom_bg_line = $top_bg_line;
280 $title_bg_line = ' bgcolor="#bbbbbb" ';
281 $nav_bg_line = ' bgcolor="#94d6e7" ';
282 } else {
283 $top_bg_line = ' bgcolor="#94d6e7" ';
284 $GLOBALS['style']['BGCOLOR2'] = "#94d6e7";
285 $bottom_bg_line = ' background="'.$rootdir.'/pic/aquabg.gif" ';
286 $title_bg_line = ' bgcolor="#aaffff" ';
287 $nav_bg_line = ' bgcolor="#94d6e7" ';
289 $login_filler_line = ' bgcolor="#f7f0d5" ';
290 $logocode = "<img src='$web_root/sites/" . $_SESSION['site_id'] . "/images/login_logo.gif'>";
291 $linepic = "$rootdir/pic/repeat_vline9.gif";
292 $table_bg = ' bgcolor="#cccccc" ';
293 $GLOBALS['style']['BGCOLOR1'] = "#cccccc";
294 $GLOBALS['style']['TEXTCOLOR11'] = "#222222";
295 $GLOBALS['style']['HIGHLIGHTCOLOR'] = "#dddddd";
296 $GLOBALS['style']['BOTTOM_BG_LINE'] = $bottom_bg_line;
297 // The height in pixels of the Logo bar at the top of the login page:
298 $GLOBALS['logoBarHeight'] = 110;
299 // The height in pixels of the Navigation bar:
300 $GLOBALS['navBarHeight'] = 22;
301 // The height in pixels of the Title bar:
302 $GLOBALS['titleBarHeight'] = 40;
304 // The assistant word, MORE printed next to titles that can be clicked:
305 // Note this label gets translated here via the xl function
306 // -if you don't want it translated, then strip the xl function away
307 $tmore = xl('(More)');
308 // The assistant word, BACK printed next to titles that return to previous screens:
309 // Note this label gets translated here via the xl function
310 // -if you don't want it translated, then strip the xl function away
311 $tback = xl('(Back)');
313 // This is the idle logout function:
314 // if a page has not been refreshed within this many seconds, the interface
315 // will return to the login page
316 if (!empty($special_timeout)) {
317 $timeout = intval($special_timeout);
320 //Version tag
321 require_once(dirname(__FILE__) . "/../version.php");
322 $patch_appending = "";
323 if ( ($v_realpatch != '0') && (!(empty($v_realpatch))) ) {
324 $patch_appending = " (".$v_realpatch.")";
326 $openemr_version = "$v_major.$v_minor.$v_patch".$v_tag.$patch_appending;
328 $srcdir = $GLOBALS['srcdir'];
329 $login_screen = $GLOBALS['login_screen'];
330 $GLOBALS['css_header'] = $css_header;
331 $GLOBALS['backpic'] = $backpic;
333 // 1 = send email message to given id for Emergency Login user activation,
334 // else 0.
335 $GLOBALS['Emergency_Login_email'] = $GLOBALS['Emergency_Login_email_id'] ? 1 : 0;
337 //set include_de_identification to enable De-identification (currently de-identification works fine only with linux machines)
338 //Run de_identification_upgrade.php script to upgrade OpenEMR database to include procedures,
339 //functions, tables for de-identification(Mysql root user and password is required for successful
340 //execution of the de-identification upgrade script)
341 $GLOBALS['include_de_identification']=0;
342 // Include the authentication module code here, but the rule is
343 // if the file has the word "login" in the source code file name,
344 // don't include the authentication module - we do this to avoid
345 // include loops.
347 if (!isset($ignoreAuth) || !$ignoreAuth) {
348 include_once("$srcdir/auth.inc");
351 // If you do not want your accounting system to have a customer added to it
352 // for each insurance company, then set this to true. SQL-Ledger currently
353 // (2005-03-21) does nothing useful with insurance companies as customers.
354 $GLOBALS['insurance_companies_are_not_customers'] = true;
356 // This is the background color to apply to form fields that are searchable.
357 // Currently it is applicable only to the "Search or Add Patient" form.
358 $GLOBALS['layout_search_color'] = '#ffff55';
360 //EMAIL SETTINGS
361 $SMTP_Auth = !empty($GLOBALS['SMTP_USER']);
363 // Customize these if you are using SQL-Ledger with OpenEMR, or if you are
364 // going to run sl_convert.php to convert from SQL-Ledger.
366 $sl_cash_acc = '1060'; // sql-ledger account number for checking account
367 $sl_ar_acc = '1200'; // sql-ledger account number for accounts receivable
368 $sl_income_acc = '4320'; // sql-ledger account number for medical services income
369 $sl_services_id = 'MS'; // sql-ledger parts table id for medical services
370 $sl_dbname = 'sql-ledger'; // sql-ledger database name
371 $sl_dbuser = 'sql-ledger'; // sql-ledger database login name
372 $sl_dbpass = 'secret'; // sql-ledger database login password
373 //////////////////////////////////////////////////////////////////
375 //module configurations
376 $GLOBALS['baseModDir'] = "interface/modules/"; //default path of modules
377 $GLOBALS['customModDir']= "custom_modules"; //non zend modules
378 $GLOBALS['zendModDir'] = "zend_modules"; //zend modules
380 // Don't change anything below this line. ////////////////////////////
382 $encounter = empty($_SESSION['encounter']) ? 0 : $_SESSION['encounter'];
384 if (!empty($_GET['pid']) && empty($_SESSION['pid'])) {
385 $_SESSION['pid'] = $_GET['pid'];
387 elseif (!empty($_POST['pid']) && empty($_SESSION['pid'])) {
388 $_SESSION['pid'] = $_POST['pid'];
390 $pid = empty($_SESSION['pid']) ? 0 : $_SESSION['pid'];
391 $userauthorized = empty($_SESSION['userauthorized']) ? 0 : $_SESSION['userauthorized'];
392 $groupname = empty($_SESSION['authProvider']) ? 0 : $_SESSION['authProvider'];
394 // global interface function to format text length using ellipses
395 function strterm($string,$length) {
396 if (strlen($string) >= ($length-3)) {
397 return substr($string,0,$length-3) . "...";
398 } else {
399 return $string;
403 // Override temporary_files_dir if PHP >= 5.2.1.
404 if (version_compare(phpversion(), "5.2.1", ">=")) {
405 $GLOBALS['temporary_files_dir'] = rtrim(sys_get_temp_dir(),'/');
408 // turn off PHP compatibility warnings
409 ini_set("session.bug_compat_warn","off");
411 //////////////////////////////////////////////////////////////////
413 /* If the includer didn't specify, assume they want us to "fake" register_globals. */
414 if (!isset($fake_register_globals)) {
415 $fake_register_globals = TRUE;
418 /* Pages with "myadmin" in the URL don't need register_globals. */
419 $fake_register_globals =
420 $fake_register_globals && (strpos($_SERVER['REQUEST_URI'],"myadmin") === FALSE);
423 // Emulates register_globals = On. Moved to the bottom of globals.php to prevent
424 // overrides of any variables used during global setup.
425 // EXTR_SKIP flag set to prevent overriding any variables defined earlier
426 if ($fake_register_globals) {
427 extract($_GET,EXTR_SKIP);
428 extract($_POST,EXTR_SKIP);