Tan Style sheet Improvements
[openemr.git] / interface / globals.php
blobe423141257b119eca30e89dc57d96a2ec5736c3d
1 <?php
3 // Default values for optional variables that are allowed to be set by callers.
5 // Unless specified explicitly, apply Auth functions
6 if (!isset($ignoreAuth)) $ignoreAuth = false;
7 // Unless specified explicitly, caller is not offsite_portal and Auth is required
8 if (!isset($ignoreAuth_offsite_portal)) $ignoreAuth_offsite_portal = false;
9 // Unless specified explicitly, do not reverse magic quotes
10 if (!isset($sanitize_all_escapes)) $sanitize_all_escapes = false;
11 // Unless specified explicitly, "fake" register_globals.
12 if (!isset($fake_register_globals)) $fake_register_globals = true;
14 // Is this windows or non-windows? Create a boolean definition.
15 if (!defined('IS_WINDOWS'))
16 define('IS_WINDOWS', (stripos(PHP_OS,'WIN') === 0));
18 // Some important php.ini overrides. Defaults for these values are often
19 // too small. You might choose to adjust them further.
21 ini_set('session.gc_maxlifetime', '14400');
23 // This is for sanitization of all escapes.
24 // (ie. reversing magic quotes if it's set)
25 if ($sanitize_all_escapes) {
26 if (get_magic_quotes_gpc()) {
27 function undoMagicQuotes($array, $topLevel=true) {
28 $newArray = array();
29 foreach($array as $key => $value) {
30 if (!$topLevel) {
31 $key = stripslashes($key);
33 if (is_array($value)) {
34 $newArray[$key] = undoMagicQuotes($value, false);
36 else {
37 $newArray[$key] = stripslashes($value);
40 return $newArray;
42 $_GET = undoMagicQuotes($_GET);
43 $_POST = undoMagicQuotes($_POST);
44 $_COOKIE = undoMagicQuotes($_COOKIE);
45 $_REQUEST = undoMagicQuotes($_REQUEST);
50 // The webserver_root and web_root are now automatically collected.
51 // If not working, can set manually below.
52 // Auto collect the full absolute directory path for openemr.
53 $webserver_root = dirname(dirname(__FILE__));
54 if (IS_WINDOWS) {
55 //convert windows path separators
56 $webserver_root = str_replace("\\","/",$webserver_root);
58 // Collect the apache server document root (and convert to windows slashes, if needed)
59 $server_document_root = realpath($_SERVER['DOCUMENT_ROOT']);
60 if (IS_WINDOWS) {
61 //convert windows path separators
62 $server_document_root = str_replace("\\","/",$server_document_root);
64 // Auto collect the relative html path, i.e. what you would type into the web
65 // browser after the server address to get to OpenEMR.
66 // This removes the leading portion of $webserver_root that it has in common with the web server's document
67 // root and assigns the result to $web_root. In addition to the common case where $webserver_root is
68 // /var/www/openemr and document root is /var/www, this also handles the case where document root is
69 // /var/www/html and there is an Apache "Alias" command that directs /openemr to /var/www/openemr.
70 $web_root = substr($webserver_root, strspn($webserver_root ^ $server_document_root, "\0"));
71 // Ensure web_root starts with a path separator
72 if (preg_match("/^[^\/]/",$web_root)) {
73 $web_root = "/".$web_root;
75 // The webserver_root and web_root are now automatically collected in
76 // real time per above code. If above is not working, can uncomment and
77 // set manually here:
78 // $webserver_root = "/var/www/openemr";
79 // $web_root = "/openemr";
82 // This is the directory that contains site-specific data. Change this
83 // only if you have some reason to.
84 $GLOBALS['OE_SITES_BASE'] = "$webserver_root/sites";
86 // The session name names a cookie stored in the browser.
87 // Now that restore_session() is implemented in javaScript, session IDs are
88 // effectively saved in the top level browser window and there is no longer
89 // any need to change the session name for different OpenEMR instances.
90 session_name("OpenEMR");
92 session_start();
94 // Set the site ID if required. This must be done before any database
95 // access is attempted.
96 if (empty($_SESSION['site_id']) || !empty($_GET['site'])) {
97 if (!empty($_GET['site'])) {
98 $tmp = $_GET['site'];
100 else {
101 if (empty($ignoreAuth)) die("Site ID is missing from session data!");
102 $tmp = $_SERVER['HTTP_HOST'];
103 if (!is_dir($GLOBALS['OE_SITES_BASE'] . "/$tmp")) $tmp = "default";
105 if (empty($tmp) || preg_match('/[^A-Za-z0-9\\-.]/', $tmp))
106 die("Site ID '". htmlspecialchars($tmp,ENT_NOQUOTES) . "' contains invalid characters.");
107 if (isset($_SESSION['site_id']) && ($_SESSION['site_id'] != $tmp)) {
108 // This is to prevent using session to penetrate other OpenEMR instances within same multisite module
109 session_unset(); // clear session, clean logout
110 if (isset($landingpage) && !empty($landingpage)) {
111 // OpenEMR Patient Portal use
112 header('Location: index.php?site='.$tmp);
114 else {
115 // Main OpenEMR use
116 header('Location: ../login/login.php?site='.$tmp); // Assuming in the interface/main directory
118 exit;
120 if (!isset($_SESSION['site_id']) || $_SESSION['site_id'] != $tmp) {
121 $_SESSION['site_id'] = $tmp;
122 //error_log("Session site ID has been set to '$tmp'"); // debugging
126 // Set the site-specific directory path.
127 $GLOBALS['OE_SITE_DIR'] = $GLOBALS['OE_SITES_BASE'] . "/" . $_SESSION['site_id'];
129 require_once($GLOBALS['OE_SITE_DIR'] . "/config.php");
131 // Collecting the utf8 disable flag from the sqlconf.php file in order
132 // to set the correct html encoding. utf8 vs iso-8859-1. If flag is set
133 // then set to iso-8859-1.
134 require_once(dirname(__FILE__) . "/../library/sqlconf.php");
135 if (!$disable_utf8_flag) {
136 ini_set('default_charset', 'utf-8');
137 $HTML_CHARSET = "UTF-8";
138 mb_internal_encoding('UTF-8');
140 else {
141 ini_set('default_charset', 'iso-8859-1');
142 $HTML_CHARSET = "ISO-8859-1";
143 mb_internal_encoding('ISO-8859-1');
146 // Root directory, relative to the webserver root:
147 $GLOBALS['rootdir'] = "$web_root/interface";
148 $rootdir = $GLOBALS['rootdir'];
149 // Absolute path to the source code include and headers file directory (Full path):
150 $GLOBALS['srcdir'] = "$webserver_root/library";
151 // Absolute path to the location of documentroot directory for use with include statements:
152 $GLOBALS['fileroot'] = "$webserver_root";
153 // Absolute path to the location of interface directory for use with include statements:
154 $include_root = "$webserver_root/interface";
155 // Absolute path to the location of documentroot directory for use with include statements:
156 $GLOBALS['webroot'] = $web_root;
158 // Static assets directory, relative to the webserver root.
159 // (it is very likely that this path will be changed in the future))
160 $GLOBALS['assets_static_relative'] = "$web_root/public/assets";
162 // Relative images directory, relative to the webserver root.
163 $GLOBALS['images_static_relative'] = "$web_root/public/images";
165 // Static images directory, absolute to the webserver root.
166 $GLOBALS['images_static_absolute'] = "$webserver_root/public/images";
168 //Composer vendor directory, absolute to the webserver root.
169 $GLOBALS['vendor_dir'] = "$webserver_root/vendor";
171 $GLOBALS['template_dir'] = $GLOBALS['fileroot'] . "/templates/";
172 $GLOBALS['incdir'] = $include_root;
173 // Location of the login screen file
174 $GLOBALS['login_screen'] = $GLOBALS['rootdir'] . "/login_screen.php";
176 // Variable set for Eligibility Verification [EDI-271] path
177 $GLOBALS['edi_271_file_path'] = $GLOBALS['OE_SITE_DIR'] . "/edi/";
179 // Include the translation engine. This will also call sql.inc to
180 // open the openemr mysql connection.
181 require_once (dirname(__FILE__) . "/../library/translation.inc.php");
183 // Include convenience functions with shorter names than "htmlspecialchars" (for security)
184 require_once (dirname(__FILE__) . "/../library/htmlspecialchars.inc.php");
186 // Include sanitization/checking functions (for security)
187 require_once (dirname(__FILE__) . "/../library/formdata.inc.php");
189 // Include sanitization/checking function (for security)
190 require_once (dirname(__FILE__) . "/../library/sanitize.inc.php");
192 // Includes functions for date internationalization
193 require_once (dirname(__FILE__) . "/../library/date_functions.php");
195 // Includes compoaser autoload
196 require_once $GLOBALS['vendor_dir'] ."/autoload.php";
198 // Includes functions for page validation
199 require_once (dirname(__FILE__) . "/../library/validation/validate_core.php");
201 // Include the version file
202 require_once (dirname(__FILE__) . "/../version.php");
204 // Defaults for specific applications.
205 $GLOBALS['weight_loss_clinic'] = false;
206 $GLOBALS['ippf_specific'] = false;
207 $GLOBALS['cene_specific'] = false;
209 // Defaults for drugs and products.
210 $GLOBALS['inhouse_pharmacy'] = false;
211 $GLOBALS['sell_non_drug_products'] = 0;
213 $glrow = sqlQuery("SHOW TABLES LIKE 'globals'");
214 if (!empty($glrow)) {
215 // Collect user specific settings from user_settings table.
217 $gl_user = array();
218 // Collect the user id first
219 $temp_authuserid = '';
220 if (!empty($_SESSION['authUserID'])) {
221 //Set the user id from the session variable
222 $temp_authuserid = $_SESSION['authUserID'];
224 else {
225 if (!empty($_POST['authUser'])) {
226 $temp_sql_ret = sqlQuery("SELECT `id` FROM `users` WHERE `username` = ?", array($_POST['authUser']) );
227 if (!empty($temp_sql_ret['id'])) {
228 //Set the user id from the login variable
229 $temp_authuserid = $temp_sql_ret['id'];
233 if (!empty($temp_authuserid)) {
234 $glres_user = sqlStatement("SELECT `setting_label`, `setting_value` " .
235 "FROM `user_settings` " .
236 "WHERE `setting_user` = ? " .
237 "AND `setting_label` LIKE 'global:%'", array($temp_authuserid) );
238 for($iter=0; $row=sqlFetchArray($glres_user); $iter++) {
239 //remove global_ prefix from label
240 $row['setting_label'] = substr($row['setting_label'],7);
241 $gl_user[$iter]=$row;
244 // Set global parameters from the database globals table.
245 // Some parameters require custom handling.
247 $GLOBALS['language_menu_show'] = array();
248 $glres = sqlStatement("SELECT gl_name, gl_index, gl_value FROM globals " .
249 "ORDER BY gl_name, gl_index");
250 while ($glrow = sqlFetchArray($glres)) {
251 $gl_name = $glrow['gl_name'];
252 $gl_value = $glrow['gl_value'];
253 // Adjust for user specific settings
254 if (!empty($gl_user)) {
255 foreach ($gl_user as $setting) {
256 if ($gl_name == $setting['setting_label']) {
257 $gl_value = $setting['setting_value'];
261 if ($gl_name == 'language_menu_other') {
262 $GLOBALS['language_menu_show'][] = $gl_value;
264 else if ($gl_name == 'css_header') {
265 $GLOBALS[$gl_name] = $rootdir.'/themes/'.$gl_value.'?v='.$v_js_includes;
266 $temp_css_theme_name = $gl_value;
268 else if ($gl_name == 'weekend_days') {
269 $GLOBALS[$gl_name] = explode(',', $gl_value);
271 else if ($gl_name == 'specific_application') {
272 if ($gl_value == '2') $GLOBALS['ippf_specific'] = true;
273 else if ($gl_value == '3') $GLOBALS['weight_loss_clinic'] = true;
275 else if ($gl_name == 'inhouse_pharmacy') {
276 if ($gl_value) $GLOBALS['inhouse_pharmacy'] = true;
277 if ($gl_value == '2') $GLOBALS['sell_non_drug_products'] = 1;
278 else if ($gl_value == '3') $GLOBALS['sell_non_drug_products'] = 2;
280 else {
281 $GLOBALS[$gl_name] = $gl_value;
284 // Language cleanup stuff.
285 $GLOBALS['language_menu_login'] = false;
286 if ((count($GLOBALS['language_menu_show']) >= 1) || $GLOBALS['language_menu_showall']) {
287 $GLOBALS['language_menu_login'] = true;
290 // Added this $GLOBALS['concurrent_layout'] set to 3 in order to support legacy forms
291 // that may use this; note this global has been removed from the standard codebase.
292 $GLOBALS['concurrent_layout'] = 3;
294 // Additional logic to override theme name.
295 // For RTL languages we substitute the theme name with the name of RTL-adapted CSS file.
296 $rtl_override = false;
297 if( isset( $_SESSION['language_direction'] )) {
298 if( $_SESSION['language_direction'] == 'rtl' &&
299 !strpos($GLOBALS['css_header'], 'rtl') ) {
301 // the $css_header_value is set above
302 $rtl_override = true;
306 else {
307 //$_SESSION['language_direction'] is not set, so will use the default language
308 $default_lang_id = sqlQuery('SELECT lang_id FROM lang_languages WHERE lang_description = ?',array($GLOBALS['language_default']));
310 if ( getLanguageDir( $default_lang_id['lang_id'] ) === 'rtl' && !strpos($GLOBALS['css_header'], 'rtl')) { // @todo eliminate 1 SQL query
311 $rtl_override = true;
316 // change theme name, if the override file exists.
317 if( $rtl_override ) {
318 // the $css_header_value is set above
319 $new_theme = 'rtl_' . $temp_css_theme_name;
321 // Check file existance
322 if( file_exists( $include_root.'/themes/'.$new_theme ) ) {
323 $GLOBALS['css_header'] = $rootdir.'/themes/'.$new_theme.'?v='.$v_js_includes;
324 } else {
325 // throw a warning if rtl'ed file does not exist.
326 error_log("Missing theme file ".text($include_root).'/themes/'.text($new_theme) );
329 unset( $temp_css_theme_name, $new_theme,$rtl_override);
330 // end of RTL section
333 // End of globals table processing.
335 else {
336 // Temporary stuff to handle the case where the globals table does not
337 // exist yet. This will happen in sql_upgrade.php on upgrading to the
338 // first release containing this table.
339 $GLOBALS['language_menu_login'] = true;
340 $GLOBALS['language_menu_showall'] = true;
341 $GLOBALS['language_menu_show'] = array('English (Standard)','Swedish');
342 $GLOBALS['language_default'] = "English (Standard)";
343 $GLOBALS['translate_layout'] = true;
344 $GLOBALS['translate_lists'] = true;
345 $GLOBALS['translate_gacl_groups'] = true;
346 $GLOBALS['translate_form_titles'] = true;
347 $GLOBALS['translate_document_categories'] = true;
348 $GLOBALS['translate_appt_categories'] = true;
349 $timeout = 7200;
350 $openemr_name = 'OpenEMR';
351 $css_header = "$rootdir/themes/style_default.css";
352 $GLOBALS['css_header'] = $css_header;
353 $GLOBALS['schedule_start'] = 8;
354 $GLOBALS['schedule_end'] = 17;
355 $GLOBALS['calendar_interval'] = 15;
356 $GLOBALS['phone_country_code'] = '1';
357 $GLOBALS['disable_non_default_groups'] = true;
358 $GLOBALS['ippf_specific'] = false;
361 // If >0 this will enforce a separate PHP session for each top-level
362 // browser window. You must log in separately for each. This is not
363 // thoroughly tested yet and some browsers might have trouble with it,
364 // so make it 0 if you must. Alternatively, you can set it to 2 to be
365 // notified when the session ID changes.
366 $GLOBALS['restore_sessions'] = 1; // 0=no, 1=yes, 2=yes+debug
368 // Theme definition. All this stuff should be moved to CSS.
370 $top_bg_line = ' bgcolor="#dddddd" ';
371 $GLOBALS['style']['BGCOLOR2'] = "#dddddd";
372 $bottom_bg_line = $top_bg_line;
373 $title_bg_line = ' bgcolor="#bbbbbb" ';
374 $nav_bg_line = ' bgcolor="#94d6e7" ';
375 $login_filler_line = ' bgcolor="#f7f0d5" ';
376 $logocode = "<img class='img-responsive center-block' src='$web_root/sites/" . $_SESSION['site_id'] . "/images/login_logo.gif'>";
377 // optimal size for the tiny logo is height 43 width 86 px
378 // inside the open emr they will be auto reduced
379 $tinylogocode1 = "<img class='tinylogopng' src='$web_root/sites/" . $_SESSION['site_id'] . "/images/logo_1.png'>";
380 $tinylogocode2 = "<img class='tinylogopng' src='$web_root/sites/" . $_SESSION['site_id'] . "/images/logo_2.png'>";
382 $linepic = "$rootdir/pic/repeat_vline9.gif";
383 $table_bg = ' bgcolor="#cccccc" ';
384 $GLOBALS['style']['BGCOLOR1'] = "#cccccc";
385 $GLOBALS['style']['TEXTCOLOR11'] = "#222222";
386 $GLOBALS['style']['HIGHLIGHTCOLOR'] = "#dddddd";
387 $GLOBALS['style']['BOTTOM_BG_LINE'] = $bottom_bg_line;
388 // The height in pixels of the Logo bar at the top of the login page:
389 $GLOBALS['logoBarHeight'] = 110;
390 // The height in pixels of the Navigation bar:
391 $GLOBALS['navBarHeight'] = 22;
392 // The height in pixels of the Title bar:
393 $GLOBALS['titleBarHeight'] = 40;
395 // The assistant word, MORE printed next to titles that can be clicked:
396 // Note this label gets translated here via the xl function
397 // -if you don't want it translated, then strip the xl function away
398 $tmore = xl('(More)');
399 // The assistant word, BACK printed next to titles that return to previous screens:
400 // Note this label gets translated here via the xl function
401 // -if you don't want it translated, then strip the xl function away
402 $tback = xl('(Back)');
404 // This is the idle logout function:
405 // if a page has not been refreshed within this many seconds, the interface
406 // will return to the login page
407 if (!empty($special_timeout)) {
408 $timeout = intval($special_timeout);
411 //Version tag
412 $patch_appending = "";
413 if ( ($v_realpatch != '0') && (!(empty($v_realpatch))) ) {
414 $patch_appending = " (".$v_realpatch.")";
416 $openemr_version = "$v_major.$v_minor.$v_patch".$v_tag.$patch_appending;
418 $srcdir = $GLOBALS['srcdir'];
419 $login_screen = $GLOBALS['login_screen'];
420 $GLOBALS['css_header'] = $css_header;
421 $GLOBALS['backpic'] = $backpic;
423 // 1 = send email message to given id for Emergency Login user activation,
424 // else 0.
425 $GLOBALS['Emergency_Login_email'] = empty($GLOBALS['Emergency_Login_email_id']) ? 0 : 1;
427 //set include_de_identification to enable De-identification (currently de-identification works fine only with linux machines)
428 //Run de_identification_upgrade.php script to upgrade OpenEMR database to include procedures,
429 //functions, tables for de-identification(Mysql root user and password is required for successful
430 //execution of the de-identification upgrade script)
431 $GLOBALS['include_de_identification']=0;
432 // Include the authentication module code here, but the rule is
433 // if the file has the word "login" in the source code file name,
434 // don't include the authentication module - we do this to avoid
435 // include loops.
437 if ( ($ignoreAuth_offsite_portal === true) && ($GLOBALS['portal_offsite_enable'] == 1) ) {
438 $ignoreAuth = true;
440 if (!$ignoreAuth) {
441 include_once("$srcdir/auth.inc");
445 // This is the background color to apply to form fields that are searchable.
446 // Currently it is applicable only to the "Search or Add Patient" form.
447 $GLOBALS['layout_search_color'] = '#ffff55';
449 //EMAIL SETTINGS
450 $SMTP_Auth = !empty($GLOBALS['SMTP_USER']);
453 //module configurations
454 $GLOBALS['baseModDir'] = "interface/modules/"; //default path of modules
455 $GLOBALS['customModDir']= "custom_modules"; //non zend modules
456 $GLOBALS['zendModDir'] = "zend_modules"; //zend modules
458 // Don't change anything below this line. ////////////////////////////
460 $encounter = empty($_SESSION['encounter']) ? 0 : $_SESSION['encounter'];
462 if (!empty($_GET['pid']) && empty($_SESSION['pid'])) {
463 $_SESSION['pid'] = $_GET['pid'];
465 elseif (!empty($_POST['pid']) && empty($_SESSION['pid'])) {
466 $_SESSION['pid'] = $_POST['pid'];
468 $pid = empty($_SESSION['pid']) ? 0 : $_SESSION['pid'];
469 $userauthorized = empty($_SESSION['userauthorized']) ? 0 : $_SESSION['userauthorized'];
470 $groupname = empty($_SESSION['authProvider']) ? 0 : $_SESSION['authProvider'];
472 // global interface function to format text length using ellipses
473 function strterm($string,$length) {
474 if (strlen($string) >= ($length-3)) {
475 return substr($string,0,$length-3) . "...";
476 } else {
477 return $string;
481 // Override temporary_files_dir if PHP >= 5.2.1.
482 if (version_compare(phpversion(), "5.2.1", ">=")) {
483 $GLOBALS['temporary_files_dir'] = rtrim(sys_get_temp_dir(),'/');
486 // turn off PHP compatibility warnings
487 ini_set("session.bug_compat_warn","off");
489 //////////////////////////////////////////////////////////////////
491 /* Pages with "myadmin" in the URL don't need register_globals. */
492 $fake_register_globals =
493 $fake_register_globals && (strpos($_SERVER['REQUEST_URI'],"myadmin") === FALSE);
496 // Emulates register_globals = On. Moved to the bottom of globals.php to prevent
497 // overrides of any variables used during global setup.
498 // EXTR_SKIP flag set to prevent overriding any variables defined earlier
499 if ($fake_register_globals) {
500 extract($_GET,EXTR_SKIP);
501 extract($_POST,EXTR_SKIP);