Files
luos/workflow/public_html/sysGeneric.php

1136 lines
46 KiB
PHP
Raw Normal View History

2010-12-02 23:34:41 +00:00
<?php
use Illuminate\Foundation\Http\Kernel;
use Illuminate\Support\Facades\Log;
2018-09-27 13:16:40 -04:00
use ProcessMaker\Core\AppEvent;
use ProcessMaker\Core\JobsManager;
2018-06-11 09:58:48 -04:00
/*----------------------------------********---------------------------------*/
2018-06-04 12:33:56 -04:00
use ProcessMaker\ChangeLog\ChangeLog;
2018-06-11 09:58:48 -04:00
/*----------------------------------********---------------------------------*/
2017-08-10 16:55:51 -04:00
use ProcessMaker\Plugins\PluginRegistry;
2018-08-28 09:34:11 -04:00
use ProcessMaker\Validation\ValidationUploadedFiles;
2017-08-10 16:55:51 -04:00
/**
* bootstrap - ProcessMaker Bootstrap
* this file is used initialize main variables, redirect and dispatch all requests
*/
2014-03-20 12:37:30 -04:00
2017-12-04 13:25:35 +00:00
function transactionLog($transactionName)
{
if (extension_loaded('newrelic')) {
2017-12-04 13:25:35 +00:00
$baseName = "ProcessMaker";
//Application base name
2017-12-04 13:25:35 +00:00
newrelic_set_appname($baseName);
//Initialize Laravel app if is not booted
if (!app()->isBooted()) {
app()->make(Kernel::class)->bootstrap();
restore_error_handler();
}
//Custom parameters
2017-12-04 13:25:35 +00:00
if (!empty(config("system.workspace"))) {
newrelic_add_custom_parameter("workspace", config("system.workspace"));
}
2017-12-04 13:25:35 +00:00
if (defined("SYS_LANG")) {
newrelic_add_custom_parameter("lang", SYS_LANG);
}
2017-12-04 13:25:35 +00:00
if (defined("SYS_SKIN")) {
newrelic_add_custom_parameter("skin", SYS_SKIN);
}
2017-12-04 13:25:35 +00:00
if (defined("SYS_COLLECTION")) {
newrelic_add_custom_parameter("collection", SYS_COLLECTION);
}
2017-12-04 13:25:35 +00:00
if (defined("SYS_TARGET")) {
newrelic_add_custom_parameter("target", SYS_TARGET);
}
2017-12-04 13:25:35 +00:00
if (defined("SYS_URI")) {
newrelic_add_custom_parameter("uri", SYS_URI);
}
2017-12-04 13:25:35 +00:00
if (defined("PATH_CORE")) {
newrelic_add_custom_parameter("path_core", PATH_CORE);
}
2017-12-04 13:25:35 +00:00
if (defined("PATH_DATA_SITE")) {
newrelic_add_custom_parameter("path_site", PATH_DATA_SITE);
}
//Show correct transaction name
2017-12-04 13:25:35 +00:00
if (!empty(config("system.workspace"))) {
newrelic_set_appname("PM-" . config("system.workspace") . ";$baseName");
}
2017-12-04 13:25:35 +00:00
if (defined("PATH_CORE")) {
$transactionName = str_replace(PATH_CORE, "", $transactionName);
}
2017-12-04 13:25:35 +00:00
newrelic_name_transaction($transactionName);
}
}
// Validating if exists 'HTTP_USER_AGENT' key in $_SERVER array
if (!isset($_SERVER['HTTP_USER_AGENT'])) {
$_SERVER['HTTP_USER_AGENT'] = '';
}
// Defining the PATH_SEP constant, he we are defining if the the path separator symbol will be '\\' or '/'
2017-12-04 13:25:35 +00:00
define('PATH_SEP', '/');
// Defining the Home Directory
2017-12-04 13:25:35 +00:00
$realdocuroot = str_replace('\\', '/', $_SERVER['DOCUMENT_ROOT']);
$docuroot = explode(PATH_SEP, $realdocuroot);
2017-12-04 13:25:35 +00:00
array_pop($docuroot);
$pathhome = implode(PATH_SEP, $docuroot) . PATH_SEP;
// try to find automatically the trunk directory where are placed the RBAC and Gulliver directories
// in a normal installation you don't need to change it.
2017-12-04 13:25:35 +00:00
array_pop($docuroot);
$pathTrunk = implode(PATH_SEP, $docuroot) . PATH_SEP;
2017-12-04 13:25:35 +00:00
array_pop($docuroot);
$pathOutTrunk = implode(PATH_SEP, $docuroot) . PATH_SEP;
2017-12-04 13:25:35 +00:00
define('PATH_HOME', $pathhome);
define('PATH_TRUNK', $pathTrunk);
define('PATH_OUTTRUNK', $pathOutTrunk);
//we are focusing in have this behaivour
//1. if the uri is a existing file return the file inmediately
//2. if the uri point to png, jpg, js, or css mapped in other place, return it inmediately
//3. process the uri,
//here we are putting approved CONSTANTS, I mean constants be sure we need,
2017-12-04 13:25:35 +00:00
define('PATH_HTML', PATH_HOME . 'public_html' . PATH_SEP);
//this is the first path, if the file exists...
$request = substr($_SERVER['REQUEST_URI'], 1, strlen($_SERVER['REQUEST_URI'])); //removes the first '/'
2012-11-23 11:52:02 -04:00
$fileWithoutParam = explode("?", $request); // split the URI by '?'
$request = $fileWithoutParam[0]; // get the first element of the split URI
$requestFile = PATH_HTML . $request; // temporary assemble a path for the file embedded in the URI
if (file_exists($requestFile)) {
if (!is_file($requestFile)) {
2017-12-04 13:25:35 +00:00
header("location: /errors/error404.php?url=" . urlencode($_SERVER['REQUEST_URI']));
die;
}
2017-02-09 17:55:37 -04:00
if ($request === "app.php" || $request === "sysGeneric.php") {
//HTTP/1.0 403 Forbidden
http_response_code(403);
}
$pos = strripos($request, ".") + 1;
$size = strlen($request);
2017-12-04 13:25:35 +00:00
if ($pos < $size) {
//if this file got an extension then assign the content
$ext_file = substr($request, $pos, $size);
if ($ext_file == "gif" || $ext_file == "png") {
2017-12-04 13:25:35 +00:00
$ext_file = 'image/' . $ext_file;
} elseif ($ext_file == "jpg" || $ext_file == "jpeg") {
$ext_file = 'image/jpeg';
} elseif ($ext_file == "swf") {
$ext_file = "application/x-shockwave-flash";
2017-12-04 13:25:35 +00:00
} elseif ($ext_file == "json" || $ext_file == "htc") {
$ext_file = "text/plain";
} elseif ($ext_file == "htm" || $ext_file == "html" || $ext_file == "txt") {
$ext_file = "text/html";
} elseif ($ext_file == "doc" || $ext_file == "pdf" || $ext_file == "pm" || $ext_file == "po") {
$ext_file = "application/octet-stream";
} elseif ($ext_file == "tar") {
$ext_file = "application/x-tar";
} elseif ($ext_file == "woff") {
$ext_file = "application/font-woff";
} elseif ($ext_file == "js") {
$ext_file = "text/javascript";
2017-12-04 13:25:35 +00:00
} elseif ($ext_file == "css") {
//may this line be innecesary, all the .css are been generated at run time
$ext_file = 'text/css';
} else {
$ext_file = "application/octet-stream";
}
2017-12-04 13:25:35 +00:00
header('Content-Type: ' . $ext_file);
}
2017-12-04 13:25:35 +00:00
header('Pragma: cache');
$mtime = filemtime($requestFile);
$gmt_mtime = gmdate("D, d M Y H:i:s", $mtime) . " GMT";
header('ETag: "' . Bootstrap::encryptOld($mtime . $requestFile) . '"');
header("Last-Modified: " . $gmt_mtime);
header('Cache-Control: public');
$userAgent = strtolower($_SERVER ['HTTP_USER_AGENT']);
if (preg_match("/msie/i", $userAgent)) {
header("Expires: " . gmdate("D, d M Y H:i:s", time() + 60 * 10) . " GMT");
} else {
2017-12-04 13:25:35 +00:00
header("Expires: " . gmdate("D, d M Y H:i:s", time() + 90 * 60 * 60 * 24) . " GMT");
if (isset($_SERVER ['HTTP_IF_MODIFIED_SINCE'])) {
if ($_SERVER ['HTTP_IF_MODIFIED_SINCE'] == $gmt_mtime) {
2017-12-04 13:25:35 +00:00
header('HTTP/1.1 304 Not Modified');
}
}
2017-12-04 13:25:35 +00:00
if (isset($_SERVER ['HTTP_IF_NONE_MATCH'])) {
if (str_replace('"', '',
stripslashes($_SERVER ['HTTP_IF_NONE_MATCH'])) == Bootstrap::encryptOld($mtime . $requestFile)) {
header("HTTP/1.1 304 Not Modified");
}
}
}
readfile($requestFile);
die;
}
2012-11-23 11:52:02 -04:00
// Defining RBAC Paths constants
2017-12-04 13:25:35 +00:00
define('PATH_RBAC_HOME', PATH_TRUNK . 'rbac' . PATH_SEP);
// Defining Gulliver framework paths constants
2017-12-04 13:25:35 +00:00
define('PATH_GULLIVER_HOME', PATH_TRUNK . 'gulliver' . PATH_SEP);
define('PATH_GULLIVER', PATH_GULLIVER_HOME . 'system' . PATH_SEP); //gulliver system classes
define('PATH_GULLIVER_BIN', PATH_GULLIVER_HOME . 'bin' . PATH_SEP); //gulliver bin classes
define('PATH_TEMPLATE', PATH_GULLIVER_HOME . 'templates' . PATH_SEP);
define('PATH_THIRDPARTY', PATH_TRUNK . 'thirdparty' . PATH_SEP);
define('PATH_RBAC', PATH_RBAC_HOME . 'engine' . PATH_SEP . 'classes' . PATH_SEP); //to enable rbac version 2
define('PATH_RBAC_CORE', PATH_RBAC_HOME . 'engine' . PATH_SEP);
// Defining PMCore Path constants
2017-12-04 13:25:35 +00:00
define('PATH_CORE', PATH_HOME . 'engine' . PATH_SEP);
define('PATH_CLASSES', PATH_HOME . "engine" . PATH_SEP . "classes" . PATH_SEP);
define('PATH_SKINS', PATH_CORE . 'skins' . PATH_SEP);
define('PATH_SKIN_ENGINE', PATH_CORE . 'skinEngine' . PATH_SEP);
define('PATH_METHODS', PATH_CORE . 'methods' . PATH_SEP);
define('PATH_XMLFORM', PATH_CORE . 'xmlform' . PATH_SEP);
define('PATH_CONFIG', PATH_CORE . 'config' . PATH_SEP);
define('PATH_PLUGINS', PATH_CORE . 'plugins' . PATH_SEP);
define('PATH_HTMLMAIL', PATH_CORE . 'html_templates' . PATH_SEP);
define('PATH_TPL', PATH_CORE . 'templates' . PATH_SEP);
define('PATH_TEST', PATH_CORE . 'test' . PATH_SEP);
define('PATH_FIXTURES', PATH_TEST . 'fixtures' . PATH_SEP);
define('PATH_RTFDOCS', PATH_CORE . 'rtf_templates' . PATH_SEP);
define('PATH_DYNACONT', PATH_CORE . 'content' . PATH_SEP . 'dynaform' . PATH_SEP);
//define( 'PATH_LANGUAGECONT',PATH_CORE . 'content' . PATH_SEP . 'languages' . PATH_SEP );
2017-12-04 13:25:35 +00:00
define('SYS_UPLOAD_PATH', PATH_HOME . "public_html/files/");
define('PATH_UPLOAD', PATH_HTML . 'files' . PATH_SEP);
2017-12-04 13:25:35 +00:00
define('PATH_WORKFLOW_MYSQL_DATA', PATH_CORE . 'data' . PATH_SEP . 'mysql' . PATH_SEP);
define('PATH_RBAC_MYSQL_DATA', PATH_RBAC_CORE . 'data' . PATH_SEP . 'mysql' . PATH_SEP);
define('FILE_PATHS_INSTALLED', PATH_CORE . 'config' . PATH_SEP . 'paths_installed.php');
define('PATH_WORKFLOW_MSSQL_DATA', PATH_CORE . 'data' . PATH_SEP . 'mssql' . PATH_SEP);
define('PATH_RBAC_MSSQL_DATA', PATH_RBAC_CORE . 'data' . PATH_SEP . 'mssql' . PATH_SEP);
define('PATH_CONTROLLERS', PATH_CORE . 'controllers' . PATH_SEP);
// include Gulliver Class
2017-12-04 13:25:35 +00:00
if (file_exists(FILE_PATHS_INSTALLED)) {
// include the server installed configuration
require_once FILE_PATHS_INSTALLED;
// defining system constant when a valid server environment exists
2017-12-04 13:25:35 +00:00
define('PATH_LANGUAGECONT', PATH_DATA . "META-INF" . PATH_SEP);
define('PATH_CUSTOM_SKINS', PATH_DATA . 'skins' . PATH_SEP);
define('PATH_TEMPORAL', PATH_C . 'dynEditor/');
define('PATH_DB', PATH_DATA . 'sites' . PATH_SEP);
// smarty constants
2017-12-04 13:25:35 +00:00
define('PATH_SMARTY_C', PATH_C . 'smarty' . PATH_SEP . 'c');
define('PATH_SMARTY_CACHE', PATH_C . 'smarty' . PATH_SEP . 'cache');
/* TO DO: put these line in other part of code*/
2017-12-04 13:25:35 +00:00
Bootstrap::verifyPath(PATH_SMARTY_C, true);
Bootstrap::verifyPath(PATH_SMARTY_CACHE, true);
}
// set include path
2017-12-04 13:25:35 +00:00
set_include_path(
PATH_CORE . PATH_SEPARATOR .
PATH_THIRDPARTY . PATH_SEPARATOR .
PATH_THIRDPARTY . 'pear' . PATH_SEPARATOR .
PATH_RBAC_CORE . PATH_SEPARATOR .
get_include_path()
);
/**
* Global definitions, before it was the defines.php file
*/
// URL Key
2017-12-04 13:25:35 +00:00
define("URL_KEY", 'c0l0s40pt1mu59r1m3');
// Other definitions
2017-12-04 13:25:35 +00:00
define('TIMEOUT_RESPONSE', 100); //web service timeout
define('APPLICATION_CODE', 'ProcessMaker'); //to login like workflow system
define('MAIN_POFILE', 'processmaker');
define('PO_SYSTEM_VERSION', 'PM 4.0.1');
2017-12-04 13:25:35 +00:00
$G_CONTENT = null;
$G_MESSAGE = "";
$G_MESSAGE_TYPE = "info";
2017-12-04 13:25:35 +00:00
$G_MENU_SELECTED = -1;
$G_MAIN_MENU = "default";
// Environment definitions
2017-12-04 13:25:35 +00:00
define('G_PRO_ENV', 'PRODUCTION');
define('G_DEV_ENV', 'DEVELOPMENT');
define('G_TEST_ENV', 'TEST');
// Number of files per folder at PATH_UPLOAD (cases documents)
2017-12-04 13:25:35 +00:00
define('APPLICATION_DOCUMENTS_PER_FOLDER', 1000);
// Server of ProcessMaker Library
2017-12-04 13:25:35 +00:00
define('PML_SERVER', 'http://library.processmaker.com');
define('PML_WSDL_URL', PML_SERVER . '/syspmLibrary/en/green/services/wsdl');
define('PML_UPLOAD_URL', PML_SERVER . '/syspmLibrary/en/green/services/uploadProcess');
define('PML_DOWNLOAD_URL', PML_SERVER . '/syspmLibrary/en/green/services/download');
G::defineConstants();
$config = Bootstrap::getSystemConfiguration();
// starting session
if (isset($config['session.gc_maxlifetime'])) {
$timelife = $config['session.gc_maxlifetime'];
} else {
$timelife = ini_get('session.gc_maxlifetime');
}
if (is_null($timelife)) {
$timelife = 1440;
}
ini_set('session.gc_maxlifetime', $timelife);
if ((preg_match("/msie/i", $_SERVER ['HTTP_USER_AGENT']) != 1 ||
2017-12-04 13:25:35 +00:00
$config['ie_cookie_lifetime'] == 1) &&
(!(preg_match("/safari/i", $_SERVER ['HTTP_USER_AGENT']) == 1 && preg_match("/chrome/i",
$_SERVER ['HTTP_USER_AGENT']) == 0) ||
$config['safari_cookie_lifetime'] == 1)) {
ini_set('session.cookie_lifetime', $timelife);
}
if (!(array_key_exists('REMOTE_USER', $_SERVER) && (string) ($_SERVER['REMOTE_USER']) != '')) {
ini_set('session.cookie_httponly', 1);
if (G::is_https()) {
ini_set('session.cookie_secure', 1);
}
}
session_start();
2019-02-22 13:02:21 -04:00
//Set Time Zone
/*----------------------------------********---------------------------------*/
$_SESSION['__SYSTEM_UTC_TIME_ZONE__'] = (int)($config['system_utc_time_zone']) == 1;
/*----------------------------------********---------------------------------*/
// Do not change any of these settings directly, use env.ini instead
2017-12-04 13:25:35 +00:00
ini_set('display_errors', $config['display_errors']);
ini_set('error_reporting', $config['error_reporting']);
ini_set('short_open_tag', 'On');
ini_set('default_charset', "UTF-8");
ini_set('soap.wsdl_cache_enabled', $config['wsdl_cache']);
2019-02-22 13:02:21 -04:00
ini_set('date.timezone',
(isset($_SESSION['__SYSTEM_UTC_TIME_ZONE__']) && $_SESSION['__SYSTEM_UTC_TIME_ZONE__']) ? 'UTC' : $config['time_zone']); //Set Time Zone
2017-12-04 13:25:35 +00:00
define('DEBUG_SQL_LOG', $config['debug_sql']);
define('DEBUG_SQL', $config['debug']);
define('DEBUG_TIME_LOG', $config['debug_time']);
define('DEBUG_CALENDAR_LOG', $config['debug_calendar']);
define('MEMCACHED_ENABLED', $config['memcached']);
define('MEMCACHED_SERVER', $config['memcached_server']);
define('WS_IN_LOGIN', isset($config['WS_IN_LOGIN']) ? $config['WS_IN_LOGIN'] : 'serverconf');
2016-11-22 11:47:41 -05:00
define('LOAD_HEADERS_IE', $config['load_headers_ie']);
2016-12-02 14:14:18 -04:00
define('LEAVE_CASE_WARNING', $config['leave_case_warning']);
2016-12-06 10:58:25 -05:00
define('REDIRECT_TO_MOBILE', $config['redirect_to_mobile']);
2017-02-08 16:01:52 -04:00
define('DISABLE_PHP_UPLOAD_EXECUTION', $config['disable_php_upload_execution']);
2017-03-10 10:59:49 -04:00
define('DISABLE_DOWNLOAD_DOCUMENTS_SESSION_VALIDATION', $config['disable_download_documents_session_validation']);
2018-06-13 15:28:25 -04:00
define('LOGS_MAX_FILES', $config['logs_max_files']);
define('LOGS_LOCATION', $config['logs_location']);
define('LOGGING_LEVEL', $config['logging_level']);
2020-09-08 16:02:57 -04:00
define('EXT_AJAX_TIMEOUT', $config['ext_ajax_timeout']);
2019-02-22 13:02:21 -04:00
define('TIME_ZONE', ini_get('date.timezone'));
2020-01-30 16:26:32 -04:00
/*----------------------------------********---------------------------------*/
define('HIGHLIGHT_HOME_FOLDER_ENABLE', $config['highlight_home_folder_enable'] === "1");
define('HIGHLIGHT_HOME_FOLDER_REFRESH_TIME', $config['highlight_home_folder_refresh_time']);
define('HIGHLIGHT_HOME_FOLDER_SCOPE', $config['highlight_home_folder_scope']);
/*----------------------------------********---------------------------------*/
2021-01-19 19:54:07 +00:00
define('DISABLE_TASK_MANAGER_ROUTING_ASYNC', $config['disable_task_manager_routing_async'] === "1");
2016-12-02 14:14:18 -04:00
// IIS Compatibility, SERVER_ADDR doesn't exist on that env, so we need to define it.
2017-12-04 13:25:35 +00:00
$_SERVER['SERVER_ADDR'] = isset($_SERVER['SERVER_ADDR']) ? $_SERVER['SERVER_ADDR'] : $_SERVER['SERVER_NAME'];
//to do: make different environments. sys
//check if it is a installation instance
2017-12-04 13:25:35 +00:00
if (!defined('PATH_C')) {
// is a intallation instance, so we need to define PATH_C and PATH_LANGUAGECONT constants temporarily
define('PATH_C', (rtrim(Bootstrap::sys_get_temp_dir(), PATH_SEP) . PATH_SEP));
define('PATH_LANGUAGECONT', PATH_HOME . 'engine/content/languages/');
}
2015-04-10 14:34:40 -04:00
//Load filter class
$skinPathErrors = G::skinGetPathToSrcByVirtualUri("errors", $config);
$skinPathUpdate = G::skinGetPathToSrcByVirtualUri("update", $config);
// defining Virtual URLs
2017-12-04 13:25:35 +00:00
$virtualURITable = [];
$virtualURITable['/plugin/(*)'] = 'plugin';
$virtualURITable['/(sys\w{0,})/(\w{0,}.js)'] = 'jsMethod';
$virtualURITable['/js/(*)'] = PATH_GULLIVER_HOME . 'js/';
$virtualURITable['/jscore/(*)'] = PATH_CORE . 'js/';
2017-12-04 13:25:35 +00:00
if (defined('PATH_C')) {
$virtualURITable['/jsform/(*.js)'] = PATH_C . 'xmlform/';
$virtualURITable['/extjs/(*)'] = PATH_C . 'ExtJs/';
}
$virtualURITable['/htmlarea/(*)'] = PATH_THIRDPARTY . 'htmlarea/';
//$virtualURITable['/sys[a-zA-Z][a-zA-Z0-9]{0,}()/'] = 'sysNamed';
2017-12-04 13:25:35 +00:00
$virtualURITable['/(sys*)'] = false;
$virtualURITable["/errors/(*)"] = ($skinPathErrors != "") ? $skinPathErrors : PATH_GULLIVER_HOME . "methods" . PATH_SEP . "errors" . PATH_SEP;
$virtualURITable['/gulliver/(*)'] = PATH_GULLIVER_HOME . 'methods/';
$virtualURITable['/controls/(*)'] = PATH_GULLIVER_HOME . 'methods/controls/';
//$virtualURITable['/images/'] = 'errorFile';
//$virtualURITable['/skins/'] = 'errorFile';
//$virtualURITable['/files/'] = 'errorFile';
2017-12-04 13:25:35 +00:00
$virtualURITable["/update/(*)"] = ($skinPathUpdate != "") ? $skinPathUpdate : PATH_GULLIVER_HOME . "methods" . PATH_SEP . "update" . PATH_SEP;
//$virtualURITable['/(*)'] = PATH_HTML;
$virtualURITable['/css/(*)'] = PATH_HTML . 'css/'; //ugly
$virtualURITable['/skin/(*)'] = PATH_HTML;
$virtualURITable['/skins/(*)'] = PATH_HTML . 'skins/'; //ugly
$virtualURITable['/images/(*)'] = PATH_HTML . 'images/'; //ugly
$virtualURITable['/[a-zA-Z][a-zA-Z0-9]{0,}/'] = 'errorFile';
// Verify if we need to redirect or stream the file, if G:VirtualURI returns true means we are going to redirect the page
2017-12-04 13:25:35 +00:00
if (Bootstrap::virtualURI($_SERVER['REQUEST_URI'], $virtualURITable, $realPath)) {
// review if the file requested belongs to public_html plugin
2017-12-04 13:25:35 +00:00
if (substr($realPath, 0, 6) == 'plugin') {
// Another way to get the path of Plugin public_html and stream the correspondent file, By JHL Jul 14, 08
// TODO: $pathsQuery will be used?
$pathsQuery = '';
// Get the query side
// Did we use this variable $pathsQuery for something??
2017-12-04 13:25:35 +00:00
$forQuery = explode("?", $realPath);
if (isset($forQuery[1])) {
$pathsQuery = $forQuery[1];
}
//Get that path in array
2017-12-04 13:25:35 +00:00
$paths = explode(PATH_SEP, $forQuery[0]);
//remove the "plugin" word from
2017-12-04 13:25:35 +00:00
$paths[0] = substr($paths[0], 6);
//Get the Plugin Folder, always the first element
2017-12-04 13:25:35 +00:00
$pluginFolder = array_shift($paths);
//The other parts are the realpath into public_html (no matter how many elements)
2017-12-04 13:25:35 +00:00
$filePath = implode(PATH_SEP, $paths);
$pluginFilename = PATH_PLUGINS . $pluginFolder . PATH_SEP . 'public_html' . PATH_SEP . $filePath;
2017-12-04 13:25:35 +00:00
if (file_exists($pluginFilename)) {
//NewRelic Snippet - By JHL
transactionLog($pluginFilename);
2017-12-04 13:25:35 +00:00
Bootstrap::streamFile($pluginFilename, false, '', true);
}
die();
}
2010-12-02 23:34:41 +00:00
2017-12-04 13:25:35 +00:00
$requestUriArray = explode("/", $_SERVER['REQUEST_URI']);
2017-12-04 13:25:35 +00:00
if ((isset($requestUriArray[1])) && ($requestUriArray[1] == 'skin')) {
// This will allow to public images of Custom Skins, By JHL Feb 28, 11
$pathsQuery = "";
// Get the query side
// This way we remove garbage
2017-12-04 13:25:35 +00:00
$forQuery = explode("?", $realPath);
if (isset($forQuery[1])) {
$pathsQuery = $forQuery[1];
}
//Get that path in array
2017-12-04 13:25:35 +00:00
$paths = explode(PATH_SEP, $forQuery[0]);
$url = (preg_match("/^(.*)\?.*$/", $_SERVER["REQUEST_URI"],
$arrayMatch)) ? $arrayMatch[1] : $_SERVER["REQUEST_URI"];
$fileToBeStreamed = str_replace("/skin/", PATH_CUSTOM_SKINS, $url);
2017-12-04 13:25:35 +00:00
if (file_exists($fileToBeStreamed)) {
//NewRelic Snippet - By JHL
transactionLog($fileToBeStreamed);
2017-12-04 13:25:35 +00:00
Bootstrap::streamFile($fileToBeStreamed);
2013-08-23 10:03:45 -04:00
}
die();
}
2010-12-02 23:34:41 +00:00
switch ($realPath) {
case 'jsMethod':
2017-12-04 13:25:35 +00:00
Bootstrap::parseURI(getenv("REQUEST_URI"));
$filename = PATH_METHODS . SYS_COLLECTION . '/' . SYS_TARGET . '.js';
//NewRelic Snippet - By JHL
transactionLog($filename);
2017-12-04 13:25:35 +00:00
Bootstrap::streamFile($filename);
die();
break;
case 'errorFile':
2025-03-27 12:06:06 +00:00
ob_start();
2017-12-04 13:25:35 +00:00
header("location: /errors/error404.php?url=" . urlencode($_SERVER['REQUEST_URI']));
if (DEBUG_TIME_LOG) {
Bootstrap::logTimeByPage();
} //log this page
die();
break;
default:
//Process files loaded with tag head in HTML
2017-12-04 13:25:35 +00:00
$realPath = explode('?', $realPath);
$realPath[0] .= strpos(basename($realPath[0]), '.') === false ? '.php' : '';
2014-03-14 13:12:48 -04:00
//NewRelic Snippet - By JHL
transactionLog($realPath[0]);
2017-12-04 13:25:35 +00:00
Bootstrap::streamFile($realPath[0]);
2014-03-14 13:12:48 -04:00
die();
}
} //virtual URI parser
2010-12-02 23:34:41 +00:00
// the request correspond to valid php page, now parse the URI
$arrayFriendlyUri = [];
$arrayFriendlyUri['cases/opencase'] = '/^[\w\-]{32}$/';
Bootstrap::parseURI(getenv('REQUEST_URI'), $arrayFriendlyUri);
if (SYS_TARGET === false) {
header('Location: /errors/error404.php?url=' . urlencode($_SERVER['REQUEST_URI']));
exit(0);
}
// Bootstrap::mylog("sys_temp: ".SYS_TEMP);
$arrayUpdating = Bootstrap::isPMUnderUpdating();
if (isset($arrayUpdating['action']) && $arrayUpdating['action']) {
if ($arrayUpdating['workspace'] == "true" || $arrayUpdating['workspace'] == SYS_TEMP) {
header("location: /update/updating.php");
2017-12-04 13:25:35 +00:00
if (DEBUG_TIME_LOG) {
Bootstrap::logTimeByPage();
2017-12-04 13:25:35 +00:00
}
die();
}
}
// verify if index.html exists
2017-12-04 13:25:35 +00:00
if (!file_exists(PATH_HTML . 'index.html')) { // if not, create it from template
file_put_contents(PATH_HTML . 'index.html', Bootstrap::parseTemplate(PATH_TPL . 'index.html', array(
'lang' => ((defined('SYS_LANG') && SYS_LANG != '') ? SYS_LANG : 'en'),
'skin' => SYS_SKIN
)));
}
2017-12-04 13:25:35 +00:00
define('SYS_URI', '/sys' . SYS_TEMP . '/' . SYS_LANG . '/' . SYS_SKIN . '/');
// defining the serverConf singleton
2017-12-04 13:25:35 +00:00
if (defined('PATH_DATA') && file_exists(PATH_DATA)) {
//Instance Server Configuration Singleton
2017-12-04 13:25:35 +00:00
$oServerConf = ServerConf::getSingleton();
}
// Create headPublisher singleton
2017-12-04 13:25:35 +00:00
$oHeadPublisher = headPublisher::getSingleton();
// Installer, redirect to install if we don't have a valid shared data folder
2017-12-04 13:25:35 +00:00
if (!defined('PATH_DATA') || !file_exists(PATH_DATA)) {
// new installer, extjs based
define( 'PATH_DATA', PATH_C );
2017-10-31 08:33:47 -04:00
//important to start laravel classes
app()->useStoragePath(realpath(PATH_DATA));
app()->make(Kernel::class)->bootstrap();
restore_error_handler();
//NewRelic Snippet - By JHL
2018-01-08 16:09:45 -04:00
transactionLog(PATH_CONTROLLERS . 'InstallerModule.php');
$pathFile = PATH_CONTROLLERS . 'InstallerModule.php';
2015-04-10 14:34:40 -04:00
require_once ($pathFile);
$controller = InstallerModule::class;
// if the method name is empty set default to index method
2017-12-04 13:25:35 +00:00
if (strpos(SYS_TARGET, '/') !== false) {
list($controller, $controllerAction) = explode('/', SYS_TARGET);
} else {
$controllerAction = SYS_TARGET;
2013-08-23 10:03:45 -04:00
}
$controllerAction = ($controllerAction != '' && $controllerAction != 'login') ? $controllerAction : 'index';
// create the installer controller and call its method
2022-06-09 10:33:21 -04:00
if (method_exists(InstallerModule::class, $controllerAction)) {
$installer = new $controller();
2017-12-04 13:25:35 +00:00
$installer->setHttpRequestData($_REQUEST);
//NewRelic Snippet - By JHL
transactionLog($controllerAction);
2017-12-04 13:25:35 +00:00
$installer->call($controllerAction);
} else {
$_SESSION['phpFileNotFound'] = $_SERVER['REQUEST_URI'];
2017-12-04 13:25:35 +00:00
header("location: /errors/error404.php?url=" . urlencode($_SERVER['REQUEST_URI']));
}
die();
}
app()->useStoragePath(realpath(PATH_DATA));
app()->make(Kernel::class)->bootstrap();
restore_error_handler();
//Overwrite with the Processmaker env.ini configuration used in production environments
//@todo: move env.ini configuration to .env
2017-12-04 13:25:35 +00:00
ini_set('display_errors', $config['display_errors']);
ini_set('error_reporting', $config['error_reporting']);
ini_set('short_open_tag', 'On');
ini_set('default_charset', "UTF-8");
ini_set('soap.wsdl_cache_enabled', $config['wsdl_cache']);
2019-02-22 13:02:21 -04:00
ini_set('date.timezone', TIME_ZONE); //Set Time Zone
date_default_timezone_set(TIME_ZONE);
config(['app.timezone' => TIME_ZONE]);
// Load Language Translation
2017-12-04 13:25:35 +00:00
Bootstrap::LoadTranslationObject(defined('SYS_LANG') ? SYS_LANG : "en");
// look for a disabled workspace
2017-12-04 13:25:35 +00:00
if ($oServerConf->isWSDisabled(SYS_TEMP)) {
$aMessage['MESSAGE'] = Bootstrap::LoadTranslation('ID_DISB_WORKSPACE');
$G_PUBLISH = new Publisher();
2017-12-04 13:25:35 +00:00
$G_PUBLISH->AddContent('xmlform', 'xmlform', 'login/showMessage', '', $aMessage);
Bootstrap::RenderPage('publish');
die();
}
// database and workspace definition
// if SYS_TEMP exists, the URL has a workspace, now we need to verify if exists their db.php file
2017-12-04 13:25:35 +00:00
if (defined('SYS_TEMP') && SYS_TEMP != '') {
//this is the default, the workspace db.php file is in /shared/workflow/sites/SYS_SYS
2015-04-10 14:34:40 -04:00
$pathFile = PATH_DB . SYS_TEMP . '/db.php';
2017-12-04 13:25:35 +00:00
if (file_exists($pathFile)) {
require_once($pathFile);
define('SYS_SYS', SYS_TEMP);
2017-10-10 12:33:25 -04:00
config(["system.workspace" => SYS_TEMP]);
// defining constant for workspace shared directory
2017-12-04 13:25:35 +00:00
define('PATH_WORKSPACE', PATH_DB . config("system.workspace") . PATH_SEP);
// including workspace shared classes -> particularlly for pmTables
2017-12-04 13:25:35 +00:00
set_include_path(get_include_path() . PATH_SEPARATOR . PATH_WORKSPACE);
} else {
if (SYS_LANG != '' && SYS_SKIN != '') {
2017-12-04 13:25:35 +00:00
Bootstrap::SendTemporalMessage('ID_NOT_WORKSPACE', "error");
Bootstrap::header('location: /sys/' . SYS_LANG . '/' . SYS_SKIN . '/main/sysLogin?errno=2');
} else {
header('location: /errors/error404.php?url=' . urlencode($_SERVER['REQUEST_URI']));
}
die();
2010-12-02 23:34:41 +00:00
}
} else { //when we are in global pages, outside any valid workspace
if (SYS_TARGET === 'newSite') {
2017-12-04 13:25:35 +00:00
$phpFile = G::ExpandPath('methods') . SYS_COLLECTION . "/" . SYS_TARGET . '.php';
//NewRelic Snippet - By JHL
transactionLog($phpFile);
2017-12-04 13:25:35 +00:00
require_once($phpFile);
die();
} else {
if (SYS_TARGET == "dbInfo") { //Show dbInfo when no SYS_SYS
2015-04-10 14:34:40 -04:00
$pathFile = PATH_METHODS . "login/dbInfo.php";
2017-12-04 13:25:35 +00:00
require_once($pathFile);
} else {
2017-12-04 13:25:35 +00:00
if (substr(SYS_SKIN, 0,
2) === 'ux' && SYS_TARGET != 'sysLoginVerify') { // new ux sysLogin - extjs based form
2017-02-07 12:29:35 -04:00
$pathFile = PATH_CONTROLLERS . 'main.php';
2015-04-10 14:34:40 -04:00
require_once $pathFile;
$controllerClass = 'Main';
$controllerAction = SYS_TARGET == 'sysLoginVerify' ? SYS_TARGET : 'sysLogin';
//if the method exists
2022-06-09 10:33:21 -04:00
if (method_exists(
2017-12-04 13:25:35 +00:00
$controllerClass,
$controllerAction
2022-06-09 10:33:21 -04:00
)) {
$controller = new $controllerClass();
2017-12-04 13:25:35 +00:00
$controller->setHttpRequestData($_REQUEST);
$controller->call($controllerAction);
}
} else { // classic sysLogin interface
2017-02-07 12:29:35 -04:00
$pathFile = PATH_METHODS . "login/sysLogin.php";
2017-12-04 13:25:35 +00:00
require_once($pathFile);
die();
}
}
2017-12-04 13:25:35 +00:00
if (DEBUG_TIME_LOG) {
Bootstrap::logTimeByPage();
} //log this page
die();
2010-12-02 23:34:41 +00:00
}
}
// PM Paths DATA
2017-12-04 13:25:35 +00:00
define('PATH_DATA_SITE', PATH_DATA . 'sites/' . config("system.workspace") . '/');
define('PATH_DOCUMENT', PATH_DATA_SITE . 'files/');
define('PATH_DATA_MAILTEMPLATES', PATH_DATA_SITE . 'mailTemplates/');
define('PATH_DATA_PUBLIC', PATH_DATA_SITE . 'public/');
define('PATH_DATA_REPORTS', PATH_DATA_SITE . 'reports/');
define('PATH_DYNAFORM', PATH_DATA_SITE . 'xmlForms/');
define('PATH_IMAGES_ENVIRONMENT_FILES', PATH_DATA_SITE . 'usersFiles' . PATH_SEP);
define('PATH_IMAGES_ENVIRONMENT_USERS', PATH_DATA_SITE . 'usersPhotographies' . PATH_SEP);
define('SERVER_NAME', $_SERVER['SERVER_NAME']);
define('SERVER_PORT', $_SERVER['SERVER_PORT']);
// create memcached singleton
2017-12-04 13:25:35 +00:00
$memcache = PMmemcached::getSingleton(config("system.workspace"));
// load Plugins base class
// setup propel definitions and logging
//changed to autoloader
2013-08-23 10:03:45 -04:00
2017-12-04 13:25:35 +00:00
if (defined('DEBUG_SQL_LOG') && DEBUG_SQL_LOG) {
define('PM_PID', mt_rand(1, 999999));
require_once 'Log.php';
2013-08-23 10:03:45 -04:00
// register debug connection decorator driver
2017-12-04 13:25:35 +00:00
Creole::registerDriver('*', 'creole.contrib.DebugConnection');
2013-08-23 10:03:45 -04:00
// initialize Propel with converted config file
2017-12-04 13:25:35 +00:00
Propel::init(PATH_CORE . "config/databases.php");
2013-08-23 10:03:45 -04:00
// unified log file for all databases
$logFile = PATH_DATA . 'log' . PATH_SEP . 'propel.log';
2017-12-04 13:25:35 +00:00
$logger = Log::singleton('file', $logFile, 'wf ' . config("system.workspace"), null, PEAR_LOG_INFO);
Propel::setLogger($logger);
// log file for workflow database
2017-12-04 13:25:35 +00:00
$con = Propel::getConnection('workflow');
if ($con instanceof DebugConnection) {
2017-12-04 13:25:35 +00:00
$con->setLogger($logger);
}
// log file for rbac database
2017-12-04 13:25:35 +00:00
$con = Propel::getConnection('rbac');
2013-08-23 10:03:45 -04:00
if ($con instanceof DebugConnection) {
2017-12-04 13:25:35 +00:00
$con->setLogger($logger);
}
2010-12-02 23:34:41 +00:00
// log file for report database
2017-12-04 13:25:35 +00:00
$con = Propel::getConnection('rp');
if ($con instanceof DebugConnection) {
2017-12-04 13:25:35 +00:00
$con->setLogger($logger);
}
} else {
2017-12-04 13:25:35 +00:00
Propel::init(PATH_CORE . "config/databases.php");
}
2010-12-02 23:34:41 +00:00
/**
* JobsManager
*/
JobsManager::getSingleton()->init();
2017-07-21 16:56:44 -04:00
//here we are loading all plugins registered
//the singleton has a list of enabled plugins
2017-08-10 16:55:51 -04:00
$oPluginRegistry = PluginRegistry::loadSingleton();
2017-07-21 16:56:44 -04:00
$attributes = $oPluginRegistry->getAttributes();
2018-01-25 09:57:49 -04:00
Bootstrap::LoadTranslationPlugins(defined('SYS_LANG') ? SYS_LANG : "en", $attributes);
// Initialization functions plugins
$oPluginRegistry->init();
2017-07-21 16:56:44 -04:00
/*----------------------------------********---------------------------------*/
$_GET = \ProcessMaker\Util\DateTime::convertDataToUtc($_GET);
$_POST = \ProcessMaker\Util\DateTime::convertDataToUtc($_POST);
$_REQUEST = \ProcessMaker\Util\DateTime::convertDataToUtc($_REQUEST);
/*----------------------------------********---------------------------------*/
2017-12-04 13:25:35 +00:00
Creole::registerDriver('dbarray', 'creole.contrib.DBArrayConnection');
2010-12-02 23:34:41 +00:00
// Session Initializations
2017-12-04 13:25:35 +00:00
ini_set('session.auto_start', '1');
// The register_globals feature has been DEPRECATED as of PHP 5.3.0. default value Off.
// ini_set( 'register_globals', 'Off' );
//session_start();
ob_start();
// Rebuild the base Workflow translations if not exists
2017-12-04 13:25:35 +00:00
if (!is_file(PATH_LANGUAGECONT . 'translation.en')) {
2017-02-07 12:29:35 -04:00
$pathFile = PATH_CLASSES . "model" . PATH_SEP . "Translation.php";
2017-12-04 13:25:35 +00:00
require_once($pathFile);
$pmTranslation = new Translation();
$fields = $pmTranslation->generateFileTranslation("en");
2017-05-15 13:34:14 -04:00
// Load Language Translation
Bootstrap::LoadTranslationObject("en");
}
// TODO: Verify if the language set into url is defined in translations env.
2017-12-04 13:25:35 +00:00
if (SYS_LANG != 'en' && !is_file(PATH_LANGUAGECONT . 'translation.' . SYS_LANG)) {
2017-02-07 12:29:35 -04:00
$pathFile = PATH_CLASSES . "model" . PATH_SEP . "Translation.php";
2017-12-04 13:25:35 +00:00
require_once($pathFile);
$pmTranslation = new Translation();
$fields = $pmTranslation->generateFileTranslation(SYS_LANG);
2017-05-15 13:34:14 -04:00
// Load Language Translation
Bootstrap::LoadTranslationObject(SYS_LANG);
}
2017-07-26 16:15:32 -04:00
// Setup plugins
$oPluginRegistry->setupPlugins(); //get and setup enabled plugins
$avoidChangedWorkspaceValidation = false;
// Load custom Classes and Model from Plugins.
Bootstrap::LoadAllPluginModelClasses();
// jump to php file in methods directory
$collectionPlugin = '';
2017-12-04 13:25:35 +00:00
if ($oPluginRegistry->isRegisteredFolder(SYS_COLLECTION)) {
$phpFile = PATH_PLUGINS . SYS_COLLECTION . PATH_SEP . SYS_TARGET . '.php';
2017-12-04 13:25:35 +00:00
$targetPlugin = explode('/', SYS_TARGET);
$collectionPlugin = $targetPlugin[0];
$avoidChangedWorkspaceValidation = true;
} else {
2017-12-04 13:25:35 +00:00
$phpFile = Bootstrap::ExpandPath('methods') . SYS_COLLECTION . PATH_SEP . SYS_TARGET . '.php';
}
2010-12-02 23:34:41 +00:00
// services is a special folder,
if (SYS_COLLECTION == 'services') {
$avoidChangedWorkspaceValidation = true;
2017-12-04 13:25:35 +00:00
$targetPlugin = explode('/', SYS_TARGET);
if ($targetPlugin[0] == 'webdav') {
2017-12-04 13:25:35 +00:00
$phpFile = Bootstrap::ExpandPath('methods') . SYS_COLLECTION . PATH_SEP . 'webdav.php';
2010-12-02 23:34:41 +00:00
}
}
if (SYS_COLLECTION == 'login' && SYS_TARGET == 'login') {
$avoidChangedWorkspaceValidation = true;
}
$bWE = false;
$isControllerCall = false;
$isPluginController = false;
2017-12-04 13:25:35 +00:00
if (substr(SYS_COLLECTION, 0, 8) === 'gulliver') {
$phpFile = PATH_GULLIVER_HOME . 'methods/' . substr(SYS_COLLECTION, 8) . SYS_TARGET . '.php';
} else {
//when the file is part of the public directory of any PROCESS, this a ProcessMaker feature
2017-12-04 13:25:35 +00:00
if (preg_match('/^[0-9][[:alnum:]]+$/', SYS_COLLECTION) == 1) { //the pattern is /sysSYS/LANG/SKIN/PRO_UID/file
$auxPart = explode('/', $_SERVER['REQUEST_URI']);
$aAux = explode('?', $auxPart[count($auxPart) - 1]);
//$extPart = explode ( '.' , $auxPart[ count($auxPart)-1] );
2017-12-04 13:25:35 +00:00
$extPart = explode('.', $aAux[0]);
$queryPart = isset($aAux[1]) ? $aAux[1] : "";
$extension = $extPart[count($extPart) - 1];
$phpFile = PATH_DATA_SITE . 'public' . PATH_SEP . SYS_COLLECTION . PATH_SEP . urldecode($auxPart[count($auxPart) - 1]);
$aAux = explode('?', $phpFile);
$phpFile = $aAux[0];
if ($extension != 'php') {
//NewRelic Snippet - By JHL
transactionLog($phpFile);
2017-03-09 18:24:34 -04:00
Bootstrap::streamFile($phpFile);
die();
}
2017-03-09 18:24:34 -04:00
$isWebEntry = \ProcessMaker\BusinessModel\WebEntry::isWebEntry(SYS_COLLECTION, $phpFile);
if (\Bootstrap::getDisablePhpUploadExecution() === 1 && !$isWebEntry) {
2018-08-28 09:34:11 -04:00
$message = \G::LoadTranslation('ID_THE_PHP_FILES_EXECUTION_WAS_DISABLED');
$context = [
'filename' => $phpFile,
'url' => $_SERVER["REQUEST_URI"] ?? ''
];
Log::channel(':phpExecution')->alert($message, \Bootstrap::context($context));
2017-02-08 16:01:52 -04:00
echo $message;
die();
} else {
//Backward compatibility: Preload PmDynaform for old generated webentry files.
class_exists('PmDynaform');
$message = 'Php Execution';
$context = [
'filename' => $phpFile,
'url' => $_SERVER["REQUEST_URI"] ?? ''
];
Log::channel(':phpExecution')->info($message, \Bootstrap::context($context));
2017-02-08 16:01:52 -04:00
}
$avoidChangedWorkspaceValidation = true;
$bWE = true;
//$phpFile = PATH_DATA_SITE . 'public' . PATH_SEP . SYS_COLLECTION . PATH_SEP . $auxPart[ count($auxPart)-1];
2010-12-02 23:34:41 +00:00
}
//erik: verify if it is a Controller Class or httpProxyController Class
2017-12-04 13:25:35 +00:00
if (is_file(PATH_CONTROLLERS . SYS_COLLECTION . '.php')) {
2017-02-07 12:29:35 -04:00
$pathFile = PATH_CONTROLLERS . SYS_COLLECTION . '.php';
2015-04-10 14:34:40 -04:00
require_once $pathFile;
$controllerClass = SYS_COLLECTION;
//if the method name is empty set default to index method
$controllerAction = SYS_TARGET != '' ? SYS_TARGET : 'index';
//if the method exists
2022-06-06 16:56:29 -04:00
if (method_exists($controllerClass, $controllerAction)) {
$isControllerCall = true;
}
if (substr(SYS_SKIN, 0, 2) != "ux" && $controllerClass == "main") {
$isControllerCall = false;
}
}
if (is_dir(PATH_PLUGINS . SYS_COLLECTION) && $oPluginRegistry->isRegisteredFolder(SYS_COLLECTION)) {
$pluginName = SYS_COLLECTION;
$pluginResourceRequest = explode('/', rtrim(SYS_TARGET, '/'));
$isPluginController = true;
if ($pluginResourceRequest > 0) {
$controllerClass = $pluginResourceRequest[0];
if (count($pluginResourceRequest) == 1) {
$controllerAction = 'index';
} else {
$controllerAction = $pluginResourceRequest[1];
}
}
$pluginControllerPath = PATH_PLUGINS . $pluginName . PATH_SEP . 'controllers' . PATH_SEP;
2017-12-04 13:25:35 +00:00
$pathFile = $pluginControllerPath . $controllerClass . '.php';
if (is_file($pathFile)) {
require_once $pathFile;
2017-12-04 13:25:35 +00:00
} elseif (is_file($pluginControllerPath . ucfirst($controllerClass) . '.php')) {
$controllerClass = ucfirst($controllerClass);
require_once $pathFile;
2017-12-04 13:25:35 +00:00
} elseif (is_file($pluginControllerPath . ucfirst($controllerClass) . 'Controller.php')) {
$controllerClass = ucfirst($controllerClass) . 'Controller';
require_once $pathFile;
}
//if the method exists
2022-06-09 10:33:21 -04:00
if (method_exists($controllerClass, $controllerAction)) {
$isControllerCall = true;
}
}
2017-12-04 13:25:35 +00:00
if (!$isControllerCall && !file_exists($phpFile)) {
$_SESSION['phpFileNotFound'] = $_SERVER['REQUEST_URI'];
2017-12-04 13:25:35 +00:00
header("location: /errors/error404.php?url=" . urlencode($_SERVER['REQUEST_URI']));
die();
2010-12-02 23:34:41 +00:00
}
}
//redirect to login, if user changed the workspace in the URL
2017-12-04 13:25:35 +00:00
if (!$avoidChangedWorkspaceValidation && isset($_SESSION['WORKSPACE']) && $_SESSION['WORKSPACE'] != config("system.workspace")) {
2017-10-10 12:33:25 -04:00
$_SESSION['WORKSPACE'] = config("system.workspace");
2017-12-04 13:25:35 +00:00
Bootstrap::SendTemporalMessage('ID_USER_HAVENT_RIGHTS_SYSTEM', "error");
// verify if the current skin is a 'ux' variant
2017-12-04 13:25:35 +00:00
$urlPart = substr(SYS_SKIN, 0, 2) == 'ux' && SYS_SKIN != 'uxs' ? '/main/login' : '/login/login';
2017-12-04 13:25:35 +00:00
header('Location: /sys' . config("system.workspace") . '/' . SYS_LANG . '/' . SYS_SKIN . $urlPart);
die();
}
// enable rbac
2017-12-04 13:25:35 +00:00
$RBAC = RBAC::getSingleton(PATH_DATA, session_id());
$RBAC->sSystem = 'PROCESSMAKER';
// define and send Headers for all pages
2017-12-04 13:25:35 +00:00
if (!defined('EXECUTE_BY_CRON')) {
header("Expires: " . gmdate("D, d M Y H:i:s", mktime(0, 0, 0, date('m'), date('d') - 1, date('Y'))) . " GMT");
header("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT");
header("Cache-Control: no-store, no-cache, must-revalidate");
header("Cache-Control: post-check=0, pre-check=0", false);
header("Pragma: no-cache");
// get the language direction from ServerConf
2017-12-04 13:25:35 +00:00
define('SYS_LANG_DIRECTION', $oServerConf->getLanDirection());
2017-12-04 13:25:35 +00:00
if ((isset($_SESSION['USER_LOGGED'])) && (!(isset($_GET['sid'])))) {
if ((preg_match("/msie/i", $_SERVER ['HTTP_USER_AGENT']) != 1 ||
2017-12-04 13:25:35 +00:00
$config['ie_cookie_lifetime'] == 1) &&
(!(preg_match("/safari/i", $_SERVER ['HTTP_USER_AGENT']) == 1 && preg_match("/chrome/i",
$_SERVER ['HTTP_USER_AGENT']) == 0) ||
$config['safari_cookie_lifetime'] == 1)) {
2021-11-26 15:58:35 +00:00
$cookieOptions = Bootstrap::buildCookieOptions(['expires' => time() + $timelife, 'httponly' => true]);
setcookie(session_name(), session_id(), $cookieOptions);
}
$RBAC->initRBAC();
//using optimization with memcache, the user data will be in memcache 8 hours, or until session id goes invalid
$memKey = 'rbacSession' . session_id();
2017-12-04 13:25:35 +00:00
if (($RBAC->aUserInfo = $memcache->get($memKey)) === false) {
$RBAC->loadUserRolePermission($RBAC->sSystem, $_SESSION['USER_LOGGED']);
2018-02-19 19:23:51 +00:00
$RBAC->verifyDueDateUserLogged();
2017-12-04 13:25:35 +00:00
$memcache->set($memKey, $RBAC->aUserInfo, PMmemcached::EIGHT_HOURS);
}
} else {
// this is the blank list to allow execute scripts with no login (without session started)
2017-12-04 13:25:35 +00:00
$noLoginFiles = $noLoginFolders = [];
$noLoginFiles[] = 'login';
$noLoginFiles[] = 'authentication';
$noLoginFiles[] = 'authenticationSso';
$noLoginFiles[] = 'login_Ajax';
$noLoginFiles[] = 'dbInfo';
$noLoginFiles[] = 'sysLoginVerify';
$noLoginFiles[] = 'processes_Ajax';
$noLoginFiles[] = 'showLogoFile';
$noLoginFiles[] = 'forgotPassword';
$noLoginFiles[] = 'retrivePassword';
$noLoginFiles[] = 'steps_Ajax';
$noLoginFiles[] = 'proxyCasesList';
$noLoginFiles[] = 'proxyNewCasesList';
$noLoginFiles[] = 'casesStartPage_Ajax';
$noLoginFiles[] = 'cases_Ajax';
$noLoginFiles[] = 'casesList_Ajax';
$noLoginFiles[] = 'proxyReassignCasesList';
$noLoginFiles[] = 'ajaxListener';
$noLoginFiles[] = 'cases_Step';
$noLoginFiles[] = 'cases_ShowOutputDocument';
2017-03-10 10:59:49 -04:00
$noLoginFiles[] = 'cases_ShowDocument';
$noLoginFiles[] = 'cases_CatchExecute';
$noLoginFiles[] = 'cases_SaveData';
$noLoginFiles[] = 'cases_Derivate';
$noLoginFiles[] = 'cases_NextStep';
2020-06-10 17:27:27 -04:00
$noLoginFiles[] = 'casesShowCaseNotes';
$noLoginFiles[] = 'genericAjax';
$noLoginFiles[] = 'casesSaveDataView';
$noLoginFiles[] = 'propelTableAjax';
$noLoginFiles[] = 'licenseUpdate';
$noLoginFiles[] = 'casesStreamingFile';
$noLoginFiles[] = 'opencase';
2017-05-05 12:25:12 -04:00
$noLoginFiles[] = 'defaultAjaxDynaform';
$noLoginFolders[] = 'services';
$noLoginFolders[] = 'tracker';
2018-01-08 16:09:45 -04:00
$noLoginFolders[] = 'InstallerModule';
2018-09-27 13:16:40 -04:00
$data = new stdClass();
$data->noLoginFiles = &$noLoginFiles;
$data->noLoginFolders = &$noLoginFolders;
AppEvent::getAppEvent()->dispatch(AppEvent::SCRIPTS_WITH_NO_LOGIN, $data);
// This sentence is used when you lost the Session
2017-12-04 13:25:35 +00:00
if (!in_array(SYS_TARGET, $noLoginFiles) && !in_array(SYS_COLLECTION,
$noLoginFolders) && $bWE != true && $collectionPlugin != 'services') {
$bRedirect = true;
2017-12-04 13:25:35 +00:00
if (isset($_GET['sid'])) {
$oSessions = new Sessions();
2017-12-04 13:25:35 +00:00
if ($aSession = $oSessions->verifySession($_GET['sid'])) {
require_once 'classes/model/Users.php';
$oUser = new Users();
2017-12-04 13:25:35 +00:00
$aUser = $oUser->load($aSession['USR_UID']);
2017-10-13 07:57:22 -04:00
initUserSession(
$aUser['USR_UID'],
2017-10-13 07:57:22 -04:00
$aUser['USR_USERNAME']
);
$bRedirect = false;
if ((preg_match("/msie/i", $_SERVER ['HTTP_USER_AGENT']) != 1 ||
2017-12-04 13:25:35 +00:00
$config['ie_cookie_lifetime'] == 1) &&
(!(preg_match("/safari/i", $_SERVER ['HTTP_USER_AGENT']) == 1 && preg_match("/chrome/i",
$_SERVER ['HTTP_USER_AGENT']) == 0) ||
$config['safari_cookie_lifetime'] == 1)) {
2021-11-26 15:58:35 +00:00
$cookieOptions = Bootstrap::buildCookieOptions(['expires' => time() + $timelife, 'httponly' => true]);
setcookie(session_name(), session_id(), $cookieOptions);
}
$RBAC->initRBAC();
2017-12-04 13:25:35 +00:00
$RBAC->loadUserRolePermission($RBAC->sSystem, $_SESSION['USER_LOGGED']);
$memKey = 'rbacSession' . session_id();
2017-12-04 13:25:35 +00:00
$memcache->set($memKey, $RBAC->aUserInfo, PMmemcached::EIGHT_HOURS);
}
}
if (isset($_GET['tracker_designer']) && intval($_GET['tracker_designer']) !== 1) {
unset($_GET['tracker_designer']);
}
if ($bRedirect && (!isset($_GET['tracker_designer']) || (!isset($_SESSION['CASE']) && !isset($_SESSION['PIN'])))) {
if (substr(SYS_SKIN, 0, 2) === 'ux' && SYS_SKIN !== 'uxs') { // verify if the current skin is a 'ux' variant
$loginUrl = 'main/login';
} else if (strpos($_SERVER['REQUEST_URI'], '/home') !== false) { //verify is it is using the uxs skin for simplified interface
$loginUrl = 'home/login';
} else {
$loginUrl = 'login/login'; // just set up the classic login
}
if (empty($_POST)) {
2018-09-27 13:16:40 -04:00
$headerString = 'location: ' . SYS_URI . $loginUrl . '?u=' . urlencode($_SERVER['REQUEST_URI']);
AppEvent::getAppEvent()->dispatch(AppEvent::LOGIN, $headerString);
header($headerString);
} else {
if ($isControllerCall) {
header("HTTP/1.0 302 session lost in controller");
} else {
header('location: ' . SYS_URI . $loginUrl);
}
}
die();
}
2010-12-02 23:34:41 +00:00
}
}
$_SESSION['phpLastFileFound'] = $_SERVER['REQUEST_URI'];
2018-06-04 14:39:57 -04:00
/*----------------------------------********---------------------------------*/
// Check if the timezone for the user is valid
if (!empty($_SESSION['USER_LOGGED']) && isset($_SESSION['__TIME_ZONE_FAILED__']) && $_SESSION['__TIME_ZONE_FAILED__'] &&
(SYS_COLLECTION != 'login' && SYS_TARGET != 'login')) {
$userTimeZone = $_SESSION['USR_TIME_ZONE'];
$browserTimeZone = $_SESSION['BROWSER_TIME_ZONE'];
$dateTime = new \ProcessMaker\Util\DateTime();
$userTimeZoneOffset = $dateTime->getTimeZoneOffsetByTimeZoneId($userTimeZone);
$browserTimeZoneOffset = $dateTime->getTimeZoneOffsetByTimeZoneId($browserTimeZone);
$userUtcOffset = $dateTime->getUtcOffsetByTimeZoneOffset($userTimeZoneOffset);
$browserUtcOffset = $dateTime->getUtcOffsetByTimeZoneOffset($browserTimeZoneOffset);
$arrayTimeZoneId = $dateTime->getTimeZoneIdByTimeZoneOffset($browserTimeZoneOffset);
array_unshift($arrayTimeZoneId, 'false');
array_walk($arrayTimeZoneId, function (&$value, $key, $parameter) { $value = ['TZ_UID' => $value, 'TZ_NAME' => '(UTC ' . $parameter . ') ' . $value]; }, $browserUtcOffset);
$_SESSION['_DBArray'] = ['TIME_ZONE' => $arrayTimeZoneId];
$arrayData = [
'USR_TIME_ZONE' => '(UTC ' . $userUtcOffset . ') ' . $userTimeZone,
'BROWSER_TIME_ZONE' => $browserTimeZone
];
global $G_PUBLISH;
$G_PUBLISH = new Publisher();
$G_PUBLISH->AddContent('xmlform', 'xmlform', 'login' . PATH_SEP . 'TimeZoneAlert', '', $arrayData, SYS_URI . 'login/updateTimezone');
G::RenderPage('publish');
exit(0);
}
/*----------------------------------********---------------------------------*/
2017-08-23 16:14:48 -04:00
// Initialization functions plugins
$oPluginRegistry->init();
2018-06-04 14:39:57 -04:00
if ($isControllerCall) { //Instance the Controller object and call the request method
2018-08-28 09:34:11 -04:00
ValidationUploadedFiles::getValidationUploadedFiles()
->runRulesToAllUploadedFiles();
$controller = new $controllerClass();
$controller->setHttpRequestData($_REQUEST);//NewRelic Snippet - By JHL
transactionLog($controllerAction);
if ($isPluginController) {
$controller->setPluginName($pluginName);
$controller->setPluginHomeDir(PATH_PLUGINS . $pluginName . PATH_SEP);
2013-08-23 10:03:45 -04:00
}
$controller->call($controllerAction);
} else {
//NewRelic Snippet - By JHL
transactionLog($phpFile);
2018-06-11 09:58:48 -04:00
/*----------------------------------********---------------------------------*/
2018-06-04 12:33:56 -04:00
ChangeLog::getChangeLog()
->setSourceId(ChangeLog::FromWeb)
->setSkin(SYS_SKIN)
->setLanguage(SYS_LANG)
->getUsrIdByUsrUid(empty($_SESSION['USER_LOGGED']) ? '' : $_SESSION['USER_LOGGED']);
2018-06-11 09:58:48 -04:00
/*----------------------------------********---------------------------------*/
2018-08-28 09:34:11 -04:00
ValidationUploadedFiles::getValidationUploadedFiles()
->runRulesToAllUploadedFiles();
require_once $phpFile;
}
2017-12-04 13:25:35 +00:00
if (defined('SKIP_HEADERS')) {
header("Expires: " . gmdate("D, d M Y H:i:s", mktime(0, 0, 0, date('m'), date('d'), date('Y') + 1)) . " GMT");
header('Cache-Control: public');
header('Pragma: ');
}
2022-10-03 10:21:36 -04:00
@ob_end_flush();
if (DEBUG_TIME_LOG) {
bootstrap::logTimeByPage(); //log this page
}
}