Find this useful? Enter your email to receive occasional updates for securing PHP code.
Signing you up...
Thank you for signing up!
PHP Decode
<?php /* Copyright (c) Nicsoft LLC */ eval( '?>' . base64_decode('PD9waHANCg0KaWYgKGZpbGVf..
Decoded Output download
?>b'<?php
if (file_exists ( \'../../../../../config.php\' )) {
include_once \'../../../../../config.php\';
include_once \'../../../../../inc/auth_header.php\';
include_once \'../../../../../classes/Database.php\';
include_once \'../../SessionManager.php\';
include_once \'../../WorkflowAPI.php\';
}
if(!session_id())
session_start();
$sm = new SessionManager();
$job_controls = "";
$job_timeline = "";
$job_task_mamangment = "";
$job_content = "";
$active_task_id = -1;
$active_task_master_id = -1;
$_SESSION[\'_workflow_debug\'] = true;
if (isset ( $_POST [\'request\'] ) && $_POST [\'request\'] != \'\') {
$_SESSION[\'FB_WORKFLOW\'][\'IS_FORMBOSS_WORKFLOW_LOADER\'] = true;
$wapi = new WorkflowAPI();
switch ($_POST [\'request\']) {
case \'load-new-job\' :
$_SESSION[\'FB_WORKFLOW\'][\'IS_FORMBOSS_WORKFLOW_NEW_JOB\'] = true;
$_SESSION[\'FB_WORKFLOW\'][\'IS_FORMBOSS_WORKFLOW_EXISTING_JOB\'] = false;
$workflow_job_id = isset ( $_POST [\'workflow_job_id\'] ) ? $_POST [\'workflow_job_id\'] : \'\';
$formboss_job_name = isset ( $_POST [\'job_name\'] ) ? $_POST [\'job_name\'] : \'\';
if($workflow_job_id == \'\' || $formboss_job_name == \'\')
return;
$sql = "SELECT workflow_data FROM fb_workflow_jobs WHERE id = ?";
$params = array ($workflow_job_id);
$result = Database::pdo_procedure_params ( $sql, $params, 0 );
$workflow_data = json_decode(base64_decode($result[1][0][\'workflow_data\']));
$current_stage_name = \'\';
foreach($workflow_data->stages as $stage_name => $stage_data){
if(count($stage_data->parents) == 0){
$current_stage_name = $stage_name;
break;
}
}
if($current_stage_name == \'\')
return \'ERROR|This job contains no start stage.\';
$task_data = new stdClass();
$active_task = array();
$active_task[\'task_master_id\'] = \'\';
$active_task[\'id\'] = \'\';
$active_task[\'workflow_job_id\'] = $workflow_job_id;
$task_data->current_stage = $current_stage_name;
$task_data->active_task = $active_task;
$job_controls = load_job_controls($task_data_faux = array(\'\', $task_data));
$job_content = load_job_data(-1, $formboss_job_name, $workflow_job_id, \'\');
break;
case \'load-existing-job\' :
$_SESSION[\'FB_WORKFLOW\'][\'IS_FORMBOSS_WORKFLOW_NEW_JOB\'] = false;
$_SESSION[\'FB_WORKFLOW\'][\'IS_FORMBOSS_WORKFLOW_EXISTING_JOB\'] = true;
$workflow_job_id = isset ( $_POST [\'workflow_job_id\'] ) ? $_POST [\'workflow_job_id\'] : \'\';
$formboss_job_name = isset ( $_POST [\'job_name\'] ) ? $_POST [\'job_name\'] : \'\';
$task_master_id = isset ( $_POST [\'task_master_id\'] ) ? $_POST [\'task_master_id\'] : \'\';
$active_task_id = isset ( $_POST [\'active_task_id\'] ) ? $_POST [\'active_task_id\'] : \'\';
if($workflow_job_id == \'\' || $formboss_job_name == \'\')
return;
$task_data = has_task_access($workflow_job_id, $formboss_job_name, $task_master_id, $active_task_id);
if($task_data[0]){
$task = $task_data[1];
$sql = "UPDATE fb_workflow_active_tasks SET task_locked = 1 WHERE task_master_id = ?";
$params = array ((int)$task->active_task[\'task_master_id\']);
$result = Database::pdo_procedure_params ($sql, $params, 1);
$active_task_master_id = (int)$task->active_task[\'task_master_id\'];
if($sm->job_already_open($active_task_master_id)){
echo \'ERROR|Job/Task Already Open.\';
return;
}
$sm->add_workflow_task($active_task_master_id);
$_SESSION[\'FB_WORKFLOW\'][\'active_task_master_id\'] = $task->active_task[\'task_master_id\'];
$_SESSION[\'FB_WORKFLOW\'][\'active_task_id\'] = $task->active_task[\'id\'];
$_SESSION[\'FB_WORKFLOW\'][\'formboss_job_id\'] = $task->active_task[\'formboss_job_id\'];
$_SESSION[\'FB_WORKFLOW\'][\'workflow_job_id\'] = $task->active_task[\'workflow_job_id\'];
$_SESSION[\'FB_WORKFLOW\'][\'workflow_stage_name\'] = $task->active_task[\'workflow_stage_name\'];
$_SESSION[\'FB_WORKFLOW\'][\'task_master_id\'] = $task->active_task[\'task_master_id\'];
$job_controls = load_job_controls($task_data);
$timeline_access_test = $wapi->has_timeline_access($task->active_task[\'formboss_job_name\'], $task->active_task[\'workflow_stage_name\'], $task->active_task[\'task_master_id\'], $task->active_task[\'id\']);
if($timeline_access_test[0] == true){
$job_timeline = load_job_timeline($task->active_task[\'task_master_id\'], $workflow_job_id, $task_data);
}
$job_task_mamangment = load_job_task_management($task->active_task[\'task_master_id\'], $workflow_job_id, $task_data);
$job_content = load_job_data($task->active_task[\'task_master_id\'], $task->active_task[\'formboss_job_name\'], $task->active_task[\'workflow_job_id\'], $task->stage->stage_target, $task->active_task[\'workflow_stage_name\']);
} else {
echo "ERROR|{$task_data[1]}";
return;
}
break;
case \'load-archived-job\' :
$_SESSION[\'FB_WORKFLOW\'][\'IS_FORMBOSS_WORKFLOW_NEW_JOB\'] = false;
$_SESSION[\'FB_WORKFLOW\'][\'IS_FORMBOSS_WORKFLOW_EXISTING_JOB\'] = true;
$workflow_job_id = isset ( $_POST [\'workflow_job_id\'] ) ? $_POST [\'workflow_job_id\'] : \'\';
$formboss_job_name = isset ( $_POST [\'job_name\'] ) ? $_POST [\'job_name\'] : \'\';
$task_master_id = isset ( $_POST [\'task_master_id\'] ) ? $_POST [\'task_master_id\'] : \'\';
$active_task_id = isset ( $_POST [\'active_task_id\'] ) ? $_POST [\'active_task_id\'] : \'\';
if($workflow_job_id == \'\' || $formboss_job_name == \'\')
return;
$task_data = has_archived_task_access($workflow_job_id, $formboss_job_name, $task_master_id, $active_task_id);
if($task_data[0]){
$active_task_master_id = $task_master_id;
$task = $task_data[1];
$_SESSION[\'FB_WORKFLOW\'][\'active_task_master_id\'] = $task->active_task[\'task_master_id\'];
$_SESSION[\'FB_WORKFLOW\'][\'active_task_id\'] = $task->active_task[\'id\'];
$_SESSION[\'FB_WORKFLOW\'][\'formboss_job_id\'] = $task->active_task[\'formboss_job_id\'];
$_SESSION[\'FB_WORKFLOW\'][\'workflow_job_id\'] = $task->active_task[\'workflow_job_id\'];
$_SESSION[\'FB_WORKFLOW\'][\'workflow_stage_name\'] = $task->active_task[\'workflow_stage_name\'];
$_SESSION[\'FB_WORKFLOW\'][\'task_master_id\'] = $task->active_task[\'task_master_id\'];
$job_controls = load_job_controls($task_data);
$timeline_access_test = $wapi->has_timeline_access($task->active_task[\'formboss_job_name\'], $task->active_task[\'workflow_stage_name\'], $task->active_task[\'task_master_id\'], $task->active_task[\'id\']);
if($timeline_access_test[0] == true){
$job_timeline = load_job_timeline($task->active_task[\'task_master_id\'], $workflow_job_id, $task_data);
}
$job_task_mamangment = load_job_task_management($task->active_task[\'task_master_id\'], $workflow_job_id, $task_data);
$job_content = load_job_data($task->active_task[\'task_master_id\'], $task->active_task[\'formboss_job_name\'], $task->active_task[\'workflow_job_id\'], $task->stage->stage_target, $task->active_task[\'workflow_stage_name\']);
} else {
echo "ERROR|{$task_data[1]}";
return;
}
break;
case \'load-job-timeline\' :
$_SESSION[\'FB_WORKFLOW\'][\'IS_FORMBOSS_WORKFLOW_NEW_JOB\'] = false;
$_SESSION[\'FB_WORKFLOW\'][\'IS_FORMBOSS_WORKFLOW_EXISTING_JOB\'] = true;
$formboss_job_name = isset ( $_POST [\'formboss_job_name\'] ) ? $_POST [\'formboss_job_name\'] : \'\';
$workflow_stage_name = isset ( $_POST [\'workflow_stage_name\'] ) ? $_POST [\'workflow_stage_name\'] : \'\';
$workflow_job_id = isset ( $_POST [\'workflow_job_id\'] ) ? $_POST [\'workflow_job_id\'] : \'\';
$task_master_id = isset ( $_POST [\'task_master_id\'] ) ? $_POST [\'task_master_id\'] : \'\';
$active_task_id = isset ( $_POST [\'active_task_id\'] ) ? $_POST [\'active_task_id\'] : \'\';
$load_most_recent = isset ( $_POST [\'load_most_recent\'] ) ? $_POST [\'load_most_recent\'] : \'\';
if($workflow_job_id == \'\' || $workflow_stage_name == \'\')
return;
if($load_most_recent == \'true\'){
$task_data = has_task_access($workflow_job_id, $formboss_job_name, $task_master_id, $active_task_id);
$timeline_load = \'false\';
} else {
$task_data = has_timeline_task_access($formboss_job_name, $workflow_stage_name, $workflow_job_id, $task_master_id, $active_task_id);
$timeline_load = \'true\';
}
if($task_data[0]){
$active_task_master_id = (int)$task_master_id;
$task = $task_data[1];
$_SESSION[\'FB_WORKFLOW\'][\'active_task_master_id\'] = $task->active_task[\'task_master_id\'];
$_SESSION[\'FB_WORKFLOW\'][\'active_task_id\'] = $task->active_task[\'id\'];
$_SESSION[\'FB_WORKFLOW\'][\'formboss_job_id\'] = $task->active_task[\'formboss_job_id\'];
$_SESSION[\'FB_WORKFLOW\'][\'workflow_job_id\'] = $task->active_task[\'workflow_job_id\'];
$_SESSION[\'FB_WORKFLOW\'][\'workflow_stage_name\'] = $task->active_task[\'workflow_stage_name\'];
$_SESSION[\'FB_WORKFLOW\'][\'task_master_id\'] = $task->active_task[\'task_master_id\'];
$job_controls = load_job_controls($task_data, $timeline_load);
$job_timeline = load_job_timeline($task->active_task[\'task_master_id\'], $workflow_job_id, $task_data);
$job_task_mamangment = load_job_task_management($task->active_task[\'task_master_id\'], $workflow_job_id, $task_data);
$job_content = load_job_data_timeline($task->active_task[\'workflow_data\'],
$task->active_task[\'task_master_id\'],
$task->active_task[\'id\'],
$task->active_task[\'formboss_job_name\'],
$task->active_task[\'workflow_job_id\'],
$task->stage->stage_target,
$task->active_task[\'workflow_stage_name\']);
} else {
if($task_data[1] != ""){
echo $task_data[1];
} else {
echo \'ERROR|You do not have access to this resource.\';
}
die;
}
break;
case \'load-job-timeline-print-view\' :
$_SESSION[\'FB_WORKFLOW\'][\'IS_FORMBOSS_WORKFLOW_NEW_JOB\'] = false;
$_SESSION[\'FB_WORKFLOW\'][\'IS_FORMBOSS_WORKFLOW_EXISTING_JOB\'] = true;
$formboss_job_name = isset ( $_POST [\'formboss_job_name\'] ) ? $_POST [\'formboss_job_name\'] : \'\';
$workflow_stage_name = isset ( $_POST [\'workflow_stage_name\'] ) ? $_POST [\'workflow_stage_name\'] : \'\';
$workflow_job_id = isset ( $_POST [\'workflow_job_id\'] ) ? $_POST [\'workflow_job_id\'] : \'\';
$task_master_id = isset ( $_POST [\'task_master_id\'] ) ? $_POST [\'task_master_id\'] : \'\';
$active_task_id = isset ( $_POST [\'active_task_id\'] ) ? $_POST [\'active_task_id\'] : \'\';
$load_most_recent = isset ( $_POST [\'load_most_recent\'] ) ? $_POST [\'load_most_recent\'] : \'\';
$load_location = isset ( $_POST [\'load_location\'] ) ? $_POST [\'load_location\'] : \'inline\';
$print_type = isset($_POST[\'print_type\']) ? $_POST[\'print_type\'] : \'print_all\';
if($workflow_job_id == \'\' || $workflow_stage_name == \'\')
return;
if($load_most_recent == \'true\'){
$task_data = has_task_access($workflow_job_id, $formboss_job_name, $task_master_id, $active_task_id);
$timeline_load = \'false\';
} else {
$task_data = has_timeline_task_access($formboss_job_name, $workflow_stage_name, $workflow_job_id, $task_master_id, $active_task_id);
$timeline_load = \'true\';
}
if($task_data[0]){
$active_task_master_id = (int)$task_master_id;
$task = $task_data[1];
$_SESSION[\'FB_WORKFLOW\'][\'active_task_master_id\'] = $task->active_task[\'task_master_id\'];
$_SESSION[\'FB_WORKFLOW\'][\'active_task_id\'] = $task->active_task[\'id\'];
$_SESSION[\'FB_WORKFLOW\'][\'formboss_job_id\'] = $task->active_task[\'formboss_job_id\'];
$_SESSION[\'FB_WORKFLOW\'][\'workflow_job_id\'] = $task->active_task[\'workflow_job_id\'];
$_SESSION[\'FB_WORKFLOW\'][\'workflow_stage_name\'] = $task->active_task[\'workflow_stage_name\'];
$_SESSION[\'FB_WORKFLOW\'][\'task_master_id\'] = $task->active_task[\'task_master_id\'];
$job_controls = \'\';
$job_timeline = \'\';
$job_task_mamangment = \'\';
$job_content = load_job_data_timeline($task->active_task[\'workflow_data\'],
$task->active_task[\'task_master_id\'],
$task->active_task[\'id\'],
$task->active_task[\'formboss_job_name\'],
$task->active_task[\'workflow_job_id\'],
$task->stage->stage_target,
$task->active_task[\'workflow_stage_name\'],
$load_location,
$print_type);
} else {
echo \'ERROR|You do not have access to this resource.\';
die;
}
break;
}
}
function has_task_access($workflow_job_id, $formboss_job_name, $task_master_id, $active_task_id){
$sql = "SELECT fb_workflow_active_tasks.id AS id
, fb_workflow_task_master.task_originator_user_id
, fb_workflow_active_tasks.workflow_stage_name
, fb_workflow_active_tasks.workflow_stage_to_load
, fb_workflow_active_tasks.task_master_id
, fb_workflow_active_tasks.task_user_id
, fb_workflow_jobs.formboss_job_id
, fb_workflow_jobs.formboss_job_name
, fb_workflow_jobs.id AS workflow_job_id
, fb_workflow_jobs.workflow_data
, fb_jobs.job_name
FROM
fb_workflow_active_tasks
INNER JOIN fb_workflow_jobs
ON fb_workflow_active_tasks.workflow_job_id = fb_workflow_jobs.id
INNER JOIN fb_workflow_task_master
ON fb_workflow_active_tasks.task_master_id = fb_workflow_task_master.id
INNER JOIN fb_jobs
ON fb_workflow_jobs.formboss_job_id = fb_jobs.id
WHERE fb_jobs.job_name = ? AND fb_workflow_active_tasks.task_master_id = ? AND fb_workflow_active_tasks.id = ? AND fb_workflow_task_master.workflow_complete = 0
ORDER BY id DESC LIMIT 1";
$params = array ($formboss_job_name, $task_master_id, $active_task_id);
$active_tasks = Database::pdo_procedure_params ( $sql, $params, 0 );
if(!$active_tasks){
echo \'No pending tasks\';
}
if($active_tasks[1][0][\'id\'] == \'\'){
unset($active_tasks[1][0]);
return array(false, "ERROR|This stage cannot be loaded as the workflow is already complete.");
}
$pending_tasks = array();
$sql = "SELECT fb_admin.user_name, fb_workflow_groups.group_name FROM fb_admin
INNER JOIN fb_workflow_groups ON fb_workflow_groups.id = fb_admin.workflow_group_id
WHERE fb_admin.user_id = ?";
$params = array ($_SESSION[\'fb_user_id\']);
$users_and_groups = Database::pdo_procedure_params ( $sql, $params, 0 );
$associations = array($users_and_groups[1][0][\'user_name\'], $users_and_groups[1][0][\'group_name\']);
foreach($active_tasks[1] as $active_task){
$workflow_data = json_decode(base64_decode($active_task[\'workflow_data\']));
$found = false; $next_stage = null; $current_stage = null;
if(isset($active_task[\'workflow_stage_to_load\']) && $active_task[\'workflow_stage_to_load\'] != \'\'){
foreach($workflow_data->stages as $key => $stage){
if($key == $active_task[\'workflow_stage_to_load\']){
$next_stage = $stage;
$current_stage = $active_task[\'workflow_stage_to_load\'];
}
}
} else {
foreach($workflow_data->stages as $key => $stage){
if($found){
$next_stage = $stage;
$current_stage = $key;
break;
}
if($key == $active_task[\'workflow_stage_name\']){
$found = true;
$next_stage = $stage;
$current_stage = $key;
}
}
}
if($next_stage != null){
foreach($next_stage->users as $user){
if(!isset($user->name)){
foreach($associations as $u){
if(trim($next_stage->users->name) == $u){
$task_tmp = new stdClass();
$task_tmp->active_task = $active_task;
$task_tmp->stage = $next_stage;
$task_tmp->current_stage = $current_stage;
$task_tmp->matching_user = $next_stage->users;
$pending_tasks[] = $task_tmp;
}
}
break;
} else {
foreach($associations as $u){
if(trim($user->name) == $u){
$task_tmp = new stdClass();
$task_tmp->active_task = $active_task;
$task_tmp->stage = $next_stage;
$task_tmp->current_stage = $current_stage;
$task_tmp->matching_user = $user;
$pending_tasks[] = $task_tmp;
}
}
}
}
}
}
if(count($pending_tasks) == 0){
return array(false, "Warning: Cannot load this task because the task has become corrupted, or the task workflow is already complete.
In the case of the former, this usually means a bad Stage Override has been set, which can happen if the job parameters have been changed since creation.");
} else if(count($pending_tasks) == 1) {
if($pending_tasks == \'\'){
return array(false, \'Warning: Cannot load this task because the task has become corrupted, or the workflow is already complete.\');
} else {
return array(true, $pending_tasks[0]);
}
}
}
function has_archived_task_access($workflow_job_id, $formboss_job_name, $task_master_id, $active_task_id){
$sql = "SELECT fb_workflow_active_tasks.id AS id
, fb_workflow_task_master.task_originator_user_id
, fb_workflow_active_tasks.workflow_stage_name
, fb_workflow_active_tasks.workflow_stage_to_load
, fb_workflow_active_tasks.task_master_id
, fb_workflow_active_tasks.task_user_id
, fb_workflow_jobs.formboss_job_id
, fb_workflow_jobs.formboss_job_name
, fb_workflow_jobs.id AS workflow_job_id
, fb_workflow_jobs.workflow_data
, fb_jobs.job_name
FROM
fb_workflow_active_tasks
INNER JOIN fb_workflow_jobs
ON fb_workflow_active_tasks.workflow_job_id = fb_workflow_jobs.id
INNER JOIN fb_workflow_task_master
ON fb_workflow_active_tasks.task_master_id = fb_workflow_task_master.id
INNER JOIN fb_jobs
ON fb_workflow_jobs.formboss_job_id = fb_jobs.id
WHERE fb_jobs.job_name = ? AND fb_workflow_active_tasks.task_master_id = ?
AND fb_workflow_active_tasks.id = ?
AND fb_workflow_task_master.workflow_complete = 1
ORDER BY id DESC LIMIT 1";
$params = array ($formboss_job_name, $task_master_id, $active_task_id);
$active_tasks = Database::pdo_procedure_params ( $sql, $params, 0 );
if(!$active_tasks){
echo \'No pending tasks\';
}
if($active_tasks[1][0][\'id\'] == \'\'){
unset($active_tasks[1][0]);
}
$archived_tasks = array();
$sql = "SELECT fb_admin.user_name, fb_workflow_groups.group_name FROM fb_admin
INNER JOIN fb_workflow_groups ON fb_workflow_groups.id = fb_admin.workflow_group_id
WHERE fb_admin.user_id = ?";
$params = array ($_SESSION[\'fb_user_id\']);
$users_and_groups = Database::pdo_procedure_params ( $sql, $params, 0 );
$associations = array($users_and_groups[1][0][\'user_name\'], $users_and_groups[1][0][\'group_name\']);
foreach($active_tasks[1] as $active_task){
$workflow_data = json_decode(base64_decode($active_task[\'workflow_data\']));
$last_stage = null;
$current_stage = \'\';
foreach($workflow_data->stages as $key => $stage){
$last_stage = $stage;
$current_stage = $key;
}
if($last_stage != null){
$task_tmp = new stdClass();
$task_tmp->active_task = $active_task;
$task_tmp->stage = $last_stage;
$task_tmp->current_stage = $current_stage;
$archived_tasks[] = $task_tmp;
}
}
if(count($archived_tasks) == 0){
return array(false, "Warning: Cannot load this task because the task has become corrupted, or the task workflow is already complete.
In the case of the former, this usually means a bad Stage Override has been set, which can happen if the job parameters have been changed since creation.");
} else if(count($archived_tasks) == 1) {
if($archived_tasks == \'\'){
return array(false, \'Warning: Cannot load this task because the task has become corrupted, or the workflow is already complete.\');
} else {
return array(true, $archived_tasks[0]);
}
}
}
function has_timeline_task_access($formboss_job_name, $workflow_stage_name, $workflow_job_id, $task_master_id, $active_task_id){
$sql = "SELECT fb_workflow_active_tasks.id AS id
, fb_workflow_task_master.task_originator_user_id
, fb_workflow_active_tasks.workflow_stage_name
, fb_workflow_active_tasks.workflow_stage_to_load
, fb_workflow_active_tasks.task_master_id
, fb_workflow_active_tasks.task_user_id
, fb_workflow_jobs.formboss_job_id
, fb_workflow_jobs.formboss_job_name
, fb_workflow_jobs.id AS workflow_job_id
, fb_workflow_jobs.workflow_data
, fb_jobs.job_name
FROM
fb_workflow_active_tasks
INNER JOIN fb_workflow_jobs
ON fb_workflow_active_tasks.workflow_job_id = fb_workflow_jobs.id
INNER JOIN fb_workflow_task_master
ON fb_workflow_active_tasks.task_master_id = fb_workflow_task_master.id
INNER JOIN fb_jobs
ON fb_workflow_jobs.formboss_job_id = fb_jobs.id
WHERE fb_jobs.job_name = ? AND fb_workflow_active_tasks.task_master_id = ? AND fb_workflow_active_tasks.id = ?";
$params = array ($formboss_job_name, $task_master_id, $active_task_id);
$active_task = Database::pdo_procedure_params ( $sql, $params, 0 );
if(!$active_task){
echo \'No pending tasks\';
}
$sql = "SELECT fb_admin.user_name, fb_workflow_groups.group_name FROM fb_admin
INNER JOIN fb_workflow_groups ON fb_workflow_groups.id = fb_admin.workflow_group_id
WHERE fb_admin.user_id = ?";
$params = array ($_SESSION[\'fb_user_id\']);
$users_and_groups = Database::pdo_procedure_params ( $sql, $params, 0 );
$associations = array($users_and_groups[1][0][\'user_name\'], $users_and_groups[1][0][\'group_name\']);
$workflow_data = json_decode(base64_decode($active_task[1][0][\'workflow_data\']));
$stage = $workflow_data->stages->$workflow_stage_name;
$pending_task = \'\';
foreach($stage->users as $user){
if(!isset($user->name)){
if(trim($user->name) == \'[Task Originator]\'){
if($active_task[1][0][\'task_originator_user_id\'] == $_SESSION[\'fb_user_id\'] && (int)$user->timeline_access == 1){
$task_tmp = new stdClass();
$task_tmp->active_task = $active_task[1][0];
$task_tmp->stage = $stage;
$task_tmp->current_stage = $workflow_stage_name;
$task_tmp->matching_user = $user;
$pending_task = $task_tmp;
}
} else {
foreach($associations as $u){
if(trim($user->name) == $u){
if(trim($user->timeline_access) == 1){
$task_tmp = new stdClass();
$task_tmp->active_task = $active_task[1][0];
$task_tmp->stage = $stage;
$task_tmp->current_stage = $workflow_stage_name;
$task_tmp->matching_user = $user;
$pending_task = $task_tmp;
}
}
}
}
} else {
if(trim($user->name) == \'[Task Originator]\'){
if($active_task[1][0][\'task_originator_user_id\'] == $_SESSION[\'fb_user_id\'] && (int)$user->timeline_access == 1){
$task_tmp = new stdClass();
$task_tmp->active_task = $active_task[1][0];
$task_tmp->stage = $stage;
$task_tmp->current_stage = $workflow_stage_name;
$task_tmp->matching_user = $user;
$pending_task = $task_tmp;
}
} else {
foreach($associations as $u){
if(trim($user->name) == $u){
if(trim($user->timeline_access) == 1){
$task_tmp = new stdClass();
$task_tmp->active_task = $active_task[1][0];
$task_tmp->stage = $stage;
$task_tmp->current_stage = $workflow_stage_name;
$task_tmp->matching_user = $user;
$pending_task = $task_tmp;
}
}
}
}
}
}
return array($pending_task != \'\' ? true : false, $pending_task);
}
function load_job_controls($task_data = \'\', $timeline_load = \'false\'){
if($task_data == \'\')
return;
$task = $task_data[1];
$html = "";
$html .= <<<EOF
<div class="job-viewer-task-controls-wrapper">
<input type="hidden" name="current_task_master_id" value="{$task->active_task[\'task_master_id\']}" />
<input type="hidden" name="current_active_task_id" value="{$task->active_task[\'id\']}" />
<input type="hidden" name="current_stage_name" value="{$task->current_stage}" />
<input type="hidden" name="workflow_job_id" value="{$task->active_task[\'workflow_job_id\']}" />
<input type="hidden" name="timeline_load" value="{$timeline_load}" />
</div>
EOF;
return $html;
}
function load_job_task_management($task_master_id, $workflow_job_id, $task_data){
if($task_master_id == 0)
return \'\';
$task_data = $task_data[1];
$sql = "SELECT id, comment FROM fb_workflow_active_tasks WHERE task_master_id = ? ORDER BY id DESC";
$params = array ($task_master_id);
$comments = Database::pdo_procedure_params ( $sql, $params, 0 );
$comment_index = 0;
$has_overflow_html = false;
$existing_comments_html = "<div class=\"comments-html-wrapper\">";
foreach($comments[1] as $comment){
if($comment_index == 0){
$existing_comments_html = "<div class=\"workflow-stage-comment-most-recent-header\">Stage Comments</div>";
$existing_comments_html .= "<div class=\"workflow-stage-comment-most-recent\">{$comment[\'comment\']}</div>";
$existing_comments_html .= "<div class=\"workflow-stage-commens-overflow\">";
$has_overflow_html = true;
$comment_index++;
} else {
$existing_comments_html .= "<div class=\"workflow-stage-comment-most-recent\">{$comment[\'comment\']}</div>";
}
}
if($has_overflow_html){
$existing_comments_html .= "</div>";
}
$existing_comments_html .= "</div>";
$add_comments_html = <<<EOF
<textarea class="task-management-comment" style="width:100%;" onkeyup=""></textarea>
EOF;
$stage_select = "";
if(isset($task_data->matching_user) && $task_data->matching_user->name != \'\' && (int)$task_data->matching_user->can_change_stages == 1){
$sql = "SELECT workflow_data, formboss_job_name FROM fb_workflow_jobs WHERE id = ?";
$params = array ($workflow_job_id);
$workflow_data = Database::pdo_procedure_params ( $sql, $params, 0 );
$workflow_data = json_decode(base64_decode($workflow_data[1][0][\'workflow_data\']));
$stage_select_option = "<option value\"\">--SELECT A STAGE--</option>";
foreach($workflow_data->stages as $name => $stage){
if($name != (string)$task_data->current_stage){
$stage_select_option .= "<option value=\"{$name}\">{$stage->name}</option>";
} else {
break;
}
}
$stage_select .= <<<EOT
<select class="task-management-stage-select" name="">
{$stage_select_option}
</select>
EOT;
}
$cancel_workflow = "";
if(isset($task_data->matching_user) && $task_data->matching_user->name != \'\' && (int)$task_data->matching_user->can_cancel_workflow == 1){
$formboss_job_name = $task_data->active_task[\'formboss_job_name\'];
$workflow_stage_name = $task_data->active_task[\'workflow_stage_name\'];
$task_master_id = $task_data->active_task[\'task_master_id\'];
$active_task_id = $task_data->active_task[\'id\'];
$cancel_workflow .= <<<EOT
<input type="button" name="" onclick="query_workflow_cancel(event, this, \'{$formboss_job_name}\', \'{$workflow_stage_name}\', {$task_master_id}, {$active_task_id}, true);" value="Cancel This Worfklow Task" />
EOT;
}
$html = <<<EOF
<div class="task-management-wrapper">
<div class="task-management-header">Task Management</div>
<div class="task-management-wrapper-padding">
{$existing_comments_html}
{$add_comments_html}
{$stage_select}
{$cancel_workflow}
</div>
</div>
EOF;
return $html;
}
function load_job_timeline($task_master_id, $workflow_job_id, $task_data){
if($task_master_id == 0)
return \'\';
$sql = "SELECT workflow_data, formboss_job_name FROM fb_workflow_jobs WHERE id = ?";
$params = array ($workflow_job_id);
$workflow_data = Database::pdo_procedure_params ( $sql, $params, 0 );
$formboss_job_name = $workflow_data[1][0][\'formboss_job_name\'];
$workflow_data = json_decode(base64_decode($workflow_data[1][0][\'workflow_data\']));
$stages = array();
foreach($workflow_data->stages as $stage_name => $stage_data){
$stages["{$stage_name}"] = $stage_data;
}
$sql = "SELECT fb_workflow_active_tasks.*,
fb_workflow_task_master.workflow_complete
FROM fb_workflow_active_tasks
INNER JOIN fb_workflow_task_master ON fb_workflow_active_tasks.task_master_id = fb_workflow_task_master.id
WHERE task_master_id = ?
ORDER BY fb_workflow_active_tasks.id DESC";
$params = array ($task_master_id);
$task_history = Database::pdo_procedure_params ( $sql, $params, 0 );
$task_item_html = "";
$count = 0;
$most_recent_task_id = -1;
foreach($task_history[1] as $task){
$stage_display_name = $stages["{$task[\'workflow_stage_name\']}"]->name;
$date = new DateTime($task[\'ts\']);
$task_date = date_format($date, \'m/d/Y\');
if($most_recent_task_id == -1){
$most_recent_task_id = $task[\'id\'];
}
if($count == 0 && $task["workflow_complete"] == 0){
$use_code = true;
if($use_code){
$task_item_html .= <<<EOF
<div class="task-timeline-item" onclick="query_right_timline_job_loader(event, \'{$formboss_job_name}\', \'{$task[\'workflow_stage_name\']}\', {$task[\'workflow_job_id\']}, {$task[\'task_master_id\']}, {$task[\'id\']}, \'true\');">
<div class="task-timeline-item-arrow">>></div>
<span class="task-timeline-name">Most Recent Task</span><br>
<span class="task-timeline-date">{$task_date}</span>
</div>
EOF;
}
$count++;
}
$task_item_html .= <<<EOF
<div class="task-timeline-item" onclick="query_right_timline_job_loader(event, \'{$formboss_job_name}\', \'{$task[\'workflow_stage_name\']}\', {$task[\'workflow_job_id\']}, {$task[\'task_master_id\']}, {$task[\'id\']}, \'false\');">
<div class="task-timeline-item-arrow">>></div>
<span class="task-timeline-name">{$stage_display_name}</span><br>
<span class="task-timeline-date">{$task_date}</span>
</div>
EOF;
}
$print_timeline_html = <<<EOT
<input type="button" value="Print Timeline" onclick="query_right_timeline_print_timeline(event, \'{$formboss_job_name}\', \'{$task[\'workflow_stage_name\']}\', {$task[\'workflow_job_id\']}, {$task[\'task_master_id\']}, {$most_recent_task_id}, \'print_all\');" />
EOT;
$html = <<<EOF
<div class="task-timeline-wrapper">
<div class="task-timeline-header">Job Timeline</div>
<div class="task-timeline-wrapper-padding">
{$task_item_html}
{$print_timeline_html}
</div>
</div>
EOF;
return $html;
}
function load_job_data($task_master_id,
$formboss_job_name,
$workflow_job_id,
$stage_target = \'\',
$current_stage_name = \'\'){
$sql = "SELECT job_xml FROM fb_jobs WHERE job_name = ?";
$params = array ($formboss_job_name);
$result = Database::pdo_procedure_params ( $sql, $params, 0 );
if(!$result)
return;
$xml = $result[1][0][\'job_xml\'];
if(substr($xml, 0, 23) == \'PD94bWwgdmVyc2lvbj0iMS4\'){
$xml = base64_decode($xml);
}
$formboss_job = simplexml_load_string($xml);
$sql = "SELECT workflow_data FROM fb_workflow_jobs WHERE id = ?";
$params = array ($workflow_job_id);
$result = Database::pdo_procedure_params ( $sql, $params, 0 );
if(!$result)
return;
$workflow = json_decode(base64_decode($result[1][0][\'workflow_data\']));
if($stage_target == \'\'){
foreach($workflow->stages as $key => $stage){
$current_stage_name = $key;
$item_to_load = $workflow->stages->$key->stage_target;
break;
}
} else {
$item_to_load = $stage_target;
}
if(substr_count($item_to_load, \'.php\') == 1){
$dim = \'500,500\';
foreach($formboss_job->page as $page){
if((string)$page->name == $item_to_load){
$dim = $page->dim;
break;
}
}
$dims = explode(\',\', $dim);
if($_SESSION[\'_workflow_debug\']){
$dims[0] = $dims[0] + 450;
$dims[1] = $dims[1] + 650;
}
$job_content = \'<iframe class="fb-workflow-iframe" id="" name="" src="../output/forms/\'.$formboss_job_name.\'/\'.$item_to_load.\'" width="\'.$dims[0].\'" height="\'.$dims[1].\'" frameborder="0" scrolling="no" ALLOWTRANSPARENCY="true"></iframe>\';
if(isset($_SESSION[\'fb_user_id\'])){
$_SESSION[\'FB_WORKFLOW\'][\'task_user_id\'] = $_SESSION[\'fb_user_id\'];
$_SESSION[\'FB_WORKFLOW\'][\'formboss_user_id\'] = $_SESSION[\'fb_user_id\'];
} else {
$_SESSION[\'FB_WORKFLOW\'][\'task_user_id\'] = \'\';
$_SESSION[\'FB_WORKFLOW\'][\'formboss_user_id\'] = NULL;
}
if(!isset($_SESSION[\'FB_WORKFLOW\'][\'formboss_job_id\']))
$_SESSION[\'FB_WORKFLOW\'][\'formboss_job_id\'] = -1;
$_SESSION[\'FB_WORKFLOW\'][\'workflow_job_id\'] = $workflow_job_id;
$_SESSION[\'FB_WORKFLOW\'][\'workflow_stage_name\'] = $current_stage_name;
} else {
}
return $job_content;
}
function load_job_data_timeline($workflow_data,
$task_master_id,
$active_task_id,
$formboss_job_name,
$workflow_job_id,
$stage_target = \'\',
$current_stage_name = \'\',
$load_location = \'inline\',
$print_type = \'\'){
$sql = "SELECT job_xml FROM fb_jobs WHERE job_name = ?";
$params = array ($formboss_job_name);
$result = Database::pdo_procedure_params ( $sql, $params, 0 );
if(!$result)
return;
$xml = $result[1][0][\'job_xml\'];
if(substr($xml, 0, 23) == \'PD94bWwgdmVyc2lvbj0iMS4\'){
$xml = base64_decode($xml);
}
$formboss_job = simplexml_load_string($xml);
if($workflow_data == \'\')
return;
$workflow = json_decode(base64_decode($workflow_data));
if($stage_target == \'\'){
foreach($workflow->stages as $key => $stage){
$current_stage_name = $key;
$item_to_load = $workflow->stages->$key->stage_target;
break;
}
} else {
$item_to_load = $stage_target;
}
if(substr_count($item_to_load, \'.php\') == 1){
$dim = \'500,500\';
foreach($formboss_job->page as $page){
if((string)$page->name == $item_to_load){
$dim = $page->dim;
break;
}
}
$dims = explode(\',\', $dim);
$output_path = \'../output/forms/\';
$render_submit_button_code = "";
if($load_location == \'stand_alone\'){
$output_path = \'../../../../../../output/forms/\';
$render_submit_button_code = "?fb-workflow-print-view=true";
}
if($print_type != \'\'){
$render_submit_button_code = "?fb-workflow-print-view=true";
}
if ($_SESSION[\'_workflow_debug\']) {
$dims[0] = $dims[0] + 450;
$dims[1] = $dims[1] + 650;
}
$job_content = \'<iframe class="fb-workflow-iframe timeline-item" id="" name="fb-iframe-JobTitle" src="\'.$output_path.$formboss_job_name.\'/\'.$item_to_load.$render_submit_button_code.\'" width="\'.$dims[0].\'" height="\'.$dims[1].\'" frameborder="0" scrolling="no" ALLOWTRANSPARENCY="true"></iframe>\';
if(isset($_SESSION[\'fb_user_id\'])){
$_SESSION[\'FB_WORKFLOW\'][\'task_user_id\'] = $_SESSION[\'fb_user_id\'];
$_SESSION[\'FB_WORKFLOW\'][\'formboss_user_id\'] = $_SESSION[\'fb_user_id\'];
} else {
$_SESSION[\'FB_WORKFLOW\'][\'task_user_id\'] = \'\';
$_SESSION[\'FB_WORKFLOW\'][\'formboss_user_id\'] = NULL;
}
if(!isset($_SESSION[\'FB_WORKFLOW\'][\'formboss_job_id\']))
$_SESSION[\'FB_WORKFLOW\'][\'formboss_job_id\'] = -1;
$_SESSION[\'FB_WORKFLOW\'][\'workflow_job_id\'] = $workflow_job_id;
$_SESSION[\'FB_WORKFLOW\'][\'workflow_stage_name\'] = $current_stage_name;
} else {
}
return $job_content;
}
if(isset($_POST[\'request\']) && $_POST[\'request\'] == \'load-job-timeline-print-view\'){
$html = <<<EOF
{$job_content}
EOF;
} else {
$html = <<<EOF
{$job_timeline}
{$job_task_mamangment}
<div class="job-viewer-header">
<div class="job-viewer-title">{$formboss_job_name}</div>
<div class="job-viewer-controls">
{$job_controls}
<div class="job-viewer-controls-close-button" onclick="query_right_job_loader_close(event, this, {$active_task_master_id}, true)">Close Window</div>
</div>
</div>
<div class="job-viewer-content">{$job_content}</div>
<div class="job-viewer-footer"> </div>
EOF;
}
echo $html;
?>'
Did this file decode correctly?
Original Code
<?php /* Copyright (c) Nicsoft LLC */ eval( '?>' . base64_decode('<?php

if (file_exists ( '../../../../../config.php' )) {
	include_once '../../../../../config.php';
	include_once '../../../../../inc/auth_header.php';
	include_once '../../../../../classes/Database.php';
	include_once '../../SessionManager.php';
	include_once '../../WorkflowAPI.php';
}

if(!session_id()) 
	session_start();
	

$sm = new SessionManager();
	

$job_controls = "";
$job_timeline = "";
$job_task_mamangment = ""; 
$job_content = "";


$active_task_id = -1;
$active_task_master_id = -1;

$_SESSION['_workflow_debug'] = true;



if (isset ( $_POST ['request'] ) && $_POST ['request'] != '') {
	
	
	
	
	$_SESSION['FB_WORKFLOW']['IS_FORMBOSS_WORKFLOW_LOADER'] = true;
	
	$wapi = new WorkflowAPI();
	
	switch ($_POST ['request']) {

		case 'load-new-job' :
			
			$_SESSION['FB_WORKFLOW']['IS_FORMBOSS_WORKFLOW_NEW_JOB'] = true;
			$_SESSION['FB_WORKFLOW']['IS_FORMBOSS_WORKFLOW_EXISTING_JOB'] = false;
			
			
			$workflow_job_id = isset ( $_POST ['workflow_job_id'] ) ? $_POST ['workflow_job_id'] : '';
			$formboss_job_name = isset ( $_POST ['job_name'] ) ? $_POST ['job_name'] : '';
			
			
			if($workflow_job_id == '' || $formboss_job_name == '')
				return;
				
				
			
			$sql = "SELECT workflow_data FROM fb_workflow_jobs WHERE id = ?"; 
			$params = array ($workflow_job_id);
			$result = Database::pdo_procedure_params ( $sql, $params, 0 );
			
			
			$workflow_data = json_decode(base64_decode($result[1][0]['workflow_data']));
			
			$current_stage_name = '';
			
			
			foreach($workflow_data->stages as $stage_name => $stage_data){
				if(count($stage_data->parents) == 0){
					$current_stage_name = $stage_name;
					break;
				}
			}
			
			if($current_stage_name == '')
				return 'ERROR|This job contains no start stage.';
			
				
			
	
			$task_data = new stdClass();
			
			$active_task = array();
			$active_task['task_master_id'] = '';
			$active_task['id'] = '';
			$active_task['workflow_job_id'] = $workflow_job_id;
			
			$task_data->current_stage = $current_stage_name;
			$task_data->active_task = $active_task;
			
			$job_controls = load_job_controls($task_data_faux = array('', $task_data));
			
			$job_content = load_job_data(-1, $formboss_job_name, $workflow_job_id, ''); 
			
			break;
			
		case 'load-existing-job' :
			
			
			$_SESSION['FB_WORKFLOW']['IS_FORMBOSS_WORKFLOW_NEW_JOB'] = false;
			$_SESSION['FB_WORKFLOW']['IS_FORMBOSS_WORKFLOW_EXISTING_JOB'] = true;
			
			
			$workflow_job_id = isset ( $_POST ['workflow_job_id'] ) ? $_POST ['workflow_job_id'] : '';
			$formboss_job_name = isset ( $_POST ['job_name'] ) ? $_POST ['job_name'] : '';
			$task_master_id = isset ( $_POST ['task_master_id'] ) ? $_POST ['task_master_id'] : '';
			$active_task_id = isset ( $_POST ['active_task_id'] ) ? $_POST ['active_task_id'] : '';
			
			if($workflow_job_id == '' || $formboss_job_name == '')
				return;
			
			
			$task_data = has_task_access($workflow_job_id, $formboss_job_name, $task_master_id, $active_task_id);
			
			
			
			
			if($task_data[0]){
				
				$task = $task_data[1]; 
				
				
				$sql = "UPDATE fb_workflow_active_tasks SET task_locked = 1 WHERE task_master_id = ?";
				$params = array ((int)$task->active_task['task_master_id']);
				$result = Database::pdo_procedure_params ($sql, $params, 1);
				
				
				$active_task_master_id = (int)$task->active_task['task_master_id'];
				
				
				if($sm->job_already_open($active_task_master_id)){				
					echo 'ERROR|Job/Task Already Open.';
					return;					
				}
									
				
				$sm->add_workflow_task($active_task_master_id);
				
				
				$_SESSION['FB_WORKFLOW']['active_task_master_id'] = $task->active_task['task_master_id'];
				$_SESSION['FB_WORKFLOW']['active_task_id'] = $task->active_task['id'];
				$_SESSION['FB_WORKFLOW']['formboss_job_id'] = $task->active_task['formboss_job_id'];
				$_SESSION['FB_WORKFLOW']['workflow_job_id'] = $task->active_task['workflow_job_id'];
				$_SESSION['FB_WORKFLOW']['workflow_stage_name'] = $task->active_task['workflow_stage_name'];
				
				
				$_SESSION['FB_WORKFLOW']['task_master_id'] = $task->active_task['task_master_id'];
				
				
				
				$job_controls = load_job_controls($task_data);
				
				
				$timeline_access_test = $wapi->has_timeline_access($task->active_task['formboss_job_name'], $task->active_task['workflow_stage_name'], $task->active_task['task_master_id'], $task->active_task['id']);
				
				if($timeline_access_test[0] == true){
					
					$job_timeline = load_job_timeline($task->active_task['task_master_id'], $workflow_job_id, $task_data);
					
				}
				
				
				$job_task_mamangment = load_job_task_management($task->active_task['task_master_id'], $workflow_job_id, $task_data);
				
				$job_content = load_job_data($task->active_task['task_master_id'], $task->active_task['formboss_job_name'], $task->active_task['workflow_job_id'], $task->stage->stage_target, $task->active_task['workflow_stage_name']);
				
				
			} else {
				
				
				echo "ERROR|{$task_data[1]}";
					return;		
				
			}
			
			break;
			
		case 'load-archived-job' :
			
			
			$_SESSION['FB_WORKFLOW']['IS_FORMBOSS_WORKFLOW_NEW_JOB'] = false;
			$_SESSION['FB_WORKFLOW']['IS_FORMBOSS_WORKFLOW_EXISTING_JOB'] = true;
			
			
			$workflow_job_id = isset ( $_POST ['workflow_job_id'] ) ? $_POST ['workflow_job_id'] : '';
			$formboss_job_name = isset ( $_POST ['job_name'] ) ? $_POST ['job_name'] : '';
			$task_master_id = isset ( $_POST ['task_master_id'] ) ? $_POST ['task_master_id'] : '';
			$active_task_id = isset ( $_POST ['active_task_id'] ) ? $_POST ['active_task_id'] : '';
			
			if($workflow_job_id == '' || $formboss_job_name == '')
				return;
			
			
			$task_data = has_archived_task_access($workflow_job_id, $formboss_job_name, $task_master_id, $active_task_id);
			
			
			
			
			if($task_data[0]){

				
				$active_task_master_id = $task_master_id;
				
				$task = $task_data[1]; 
				
				
				
				
				$_SESSION['FB_WORKFLOW']['active_task_master_id'] = $task->active_task['task_master_id'];
				$_SESSION['FB_WORKFLOW']['active_task_id'] = $task->active_task['id'];
				$_SESSION['FB_WORKFLOW']['formboss_job_id'] = $task->active_task['formboss_job_id'];
				$_SESSION['FB_WORKFLOW']['workflow_job_id'] = $task->active_task['workflow_job_id'];
				$_SESSION['FB_WORKFLOW']['workflow_stage_name'] = $task->active_task['workflow_stage_name'];
				
				
				$_SESSION['FB_WORKFLOW']['task_master_id'] = $task->active_task['task_master_id'];
				
				
				
				$job_controls = load_job_controls($task_data);
				
				$timeline_access_test = $wapi->has_timeline_access($task->active_task['formboss_job_name'], $task->active_task['workflow_stage_name'], $task->active_task['task_master_id'], $task->active_task['id']);
				
				if($timeline_access_test[0] == true){
				
					$job_timeline = load_job_timeline($task->active_task['task_master_id'], $workflow_job_id, $task_data);
					
				}
				
				$job_task_mamangment = load_job_task_management($task->active_task['task_master_id'], $workflow_job_id, $task_data);
				
				$job_content = load_job_data($task->active_task['task_master_id'], $task->active_task['formboss_job_name'], $task->active_task['workflow_job_id'], $task->stage->stage_target, $task->active_task['workflow_stage_name']);
				
				
			} else {
				
				
				echo "ERROR|{$task_data[1]}";
					return;		
				
			}
			
			break;
			
			
		case 'load-job-timeline' :
			
			
			$_SESSION['FB_WORKFLOW']['IS_FORMBOSS_WORKFLOW_NEW_JOB'] = false;
			$_SESSION['FB_WORKFLOW']['IS_FORMBOSS_WORKFLOW_EXISTING_JOB'] = true;
			
			
			$formboss_job_name = isset ( $_POST ['formboss_job_name'] ) ? $_POST ['formboss_job_name'] : '';
			$workflow_stage_name = isset ( $_POST ['workflow_stage_name'] ) ? $_POST ['workflow_stage_name'] : '';
			$workflow_job_id = isset ( $_POST ['workflow_job_id'] ) ? $_POST ['workflow_job_id'] : '';
			$task_master_id = isset ( $_POST ['task_master_id'] ) ? $_POST ['task_master_id'] : '';
			$active_task_id = isset ( $_POST ['active_task_id'] ) ? $_POST ['active_task_id'] : '';
			$load_most_recent = isset ( $_POST ['load_most_recent'] ) ? $_POST ['load_most_recent'] : '';
			
			if($workflow_job_id == '' || $workflow_stage_name == '')
				return;
			
			
			
			
			
			
			
			
			
			
			
			
			
			
			if($load_most_recent == 'true'){
				$task_data = has_task_access($workflow_job_id, $formboss_job_name, $task_master_id, $active_task_id);
				$timeline_load = 'false';
			} else {
				
				$task_data = has_timeline_task_access($formboss_job_name, $workflow_stage_name, $workflow_job_id, $task_master_id, $active_task_id);
				$timeline_load = 'true';
			}
			
			
			
			
			
			if($task_data[0]){

				
				$active_task_master_id = (int)$task_master_id;
				
				$task = $task_data[1]; 
				
				
				
				
				$_SESSION['FB_WORKFLOW']['active_task_master_id'] = $task->active_task['task_master_id'];
				$_SESSION['FB_WORKFLOW']['active_task_id'] = $task->active_task['id'];
				$_SESSION['FB_WORKFLOW']['formboss_job_id'] = $task->active_task['formboss_job_id'];
				$_SESSION['FB_WORKFLOW']['workflow_job_id'] = $task->active_task['workflow_job_id'];
				$_SESSION['FB_WORKFLOW']['workflow_stage_name'] = $task->active_task['workflow_stage_name'];
				
				
				$_SESSION['FB_WORKFLOW']['task_master_id'] = $task->active_task['task_master_id'];
				
				
				$job_controls = load_job_controls($task_data, $timeline_load);
				
				$job_timeline = load_job_timeline($task->active_task['task_master_id'], $workflow_job_id, $task_data);
				
				
				
				
				$job_task_mamangment = load_job_task_management($task->active_task['task_master_id'], $workflow_job_id, $task_data);
				
				$job_content = load_job_data_timeline($task->active_task['workflow_data'], 
													  $task->active_task['task_master_id'], 
													  $task->active_task['id'], 
													  $task->active_task['formboss_job_name'], 
													  $task->active_task['workflow_job_id'], 
													  $task->stage->stage_target, 
													  $task->active_task['workflow_stage_name']);
				
				
			} else {
				
				
				
				
				
				
				
				
				
				if($task_data[1] != ""){
					echo $task_data[1];
				} else {
					echo 'ERROR|You do not have access to this resource.';
				}
				die;
			}

			break;
			
		
		
		
		case 'load-job-timeline-print-view' :
			
			
			$_SESSION['FB_WORKFLOW']['IS_FORMBOSS_WORKFLOW_NEW_JOB'] = false;
			$_SESSION['FB_WORKFLOW']['IS_FORMBOSS_WORKFLOW_EXISTING_JOB'] = true;
			
			
			$formboss_job_name = isset ( $_POST ['formboss_job_name'] ) ? $_POST ['formboss_job_name'] : '';
			$workflow_stage_name = isset ( $_POST ['workflow_stage_name'] ) ? $_POST ['workflow_stage_name'] : '';
			$workflow_job_id = isset ( $_POST ['workflow_job_id'] ) ? $_POST ['workflow_job_id'] : '';
			$task_master_id = isset ( $_POST ['task_master_id'] ) ? $_POST ['task_master_id'] : '';
			$active_task_id = isset ( $_POST ['active_task_id'] ) ? $_POST ['active_task_id'] : '';
			$load_most_recent = isset ( $_POST ['load_most_recent'] ) ? $_POST ['load_most_recent'] : '';
			
			
			$load_location = isset ( $_POST ['load_location'] ) ? $_POST ['load_location'] : 'inline'; 

			$print_type = isset($_POST['print_type']) ? $_POST['print_type'] : 'print_all'; 
			
			if($workflow_job_id == '' || $workflow_stage_name == '')
				return;
			
			
			
			
			
			
			
			
			
			
			
			if($load_most_recent == 'true'){
				$task_data = has_task_access($workflow_job_id, $formboss_job_name, $task_master_id, $active_task_id);
				$timeline_load = 'false';
			} else {
				$task_data = has_timeline_task_access($formboss_job_name, $workflow_stage_name, $workflow_job_id, $task_master_id, $active_task_id);
				$timeline_load = 'true';
			}
			
			
			
			
			
			if($task_data[0]){

				
				$active_task_master_id = (int)$task_master_id;
				
				$task = $task_data[1]; 
				
				
				
				
				$_SESSION['FB_WORKFLOW']['active_task_master_id'] = $task->active_task['task_master_id'];
				$_SESSION['FB_WORKFLOW']['active_task_id'] = $task->active_task['id'];
				$_SESSION['FB_WORKFLOW']['formboss_job_id'] = $task->active_task['formboss_job_id'];
				$_SESSION['FB_WORKFLOW']['workflow_job_id'] = $task->active_task['workflow_job_id'];
				$_SESSION['FB_WORKFLOW']['workflow_stage_name'] = $task->active_task['workflow_stage_name'];
				
				
				$_SESSION['FB_WORKFLOW']['task_master_id'] = $task->active_task['task_master_id'];
				
				
				$job_controls = '';
				
				$job_timeline = '';
				
				$job_task_mamangment = '';
				
				$job_content = load_job_data_timeline($task->active_task['workflow_data'], 
													  $task->active_task['task_master_id'], 
													  $task->active_task['id'], 
													  $task->active_task['formboss_job_name'], 
													  $task->active_task['workflow_job_id'], 
													  $task->stage->stage_target, 
													  $task->active_task['workflow_stage_name'],
													  $load_location,
													  $print_type);
				
				
			} else {
				
				echo 'ERROR|You do not have access to this resource.';
				die;
			}

			break;
		
	}
	
	
	
	
	
	
	
}


function has_task_access($workflow_job_id, $formboss_job_name, $task_master_id, $active_task_id){
	
	
	$sql = "SELECT fb_workflow_active_tasks.id AS id
			     , fb_workflow_task_master.task_originator_user_id
			     , fb_workflow_active_tasks.workflow_stage_name
			     , fb_workflow_active_tasks.workflow_stage_to_load
			     , fb_workflow_active_tasks.task_master_id
			     , fb_workflow_active_tasks.task_user_id
			     , fb_workflow_jobs.formboss_job_id
			     , fb_workflow_jobs.formboss_job_name
			     , fb_workflow_jobs.id AS workflow_job_id
			     , fb_workflow_jobs.workflow_data
			     , fb_jobs.job_name
			FROM
			  fb_workflow_active_tasks
			INNER JOIN fb_workflow_jobs
			ON fb_workflow_active_tasks.workflow_job_id = fb_workflow_jobs.id
			INNER JOIN fb_workflow_task_master
			ON fb_workflow_active_tasks.task_master_id = fb_workflow_task_master.id
			INNER JOIN fb_jobs
			ON fb_workflow_jobs.formboss_job_id = fb_jobs.id
			WHERE fb_jobs.job_name = ? AND fb_workflow_active_tasks.task_master_id = ? AND fb_workflow_active_tasks.id = ? AND fb_workflow_task_master.workflow_complete = 0
			ORDER BY id DESC LIMIT 1"; 
	
	
	$params = array ($formboss_job_name, $task_master_id, $active_task_id);
	$active_tasks = Database::pdo_procedure_params ( $sql, $params, 0 );
	
	if(!$active_tasks){
		echo 'No pending tasks';
	}
	
	
	if($active_tasks[1][0]['id'] == ''){
		
		unset($active_tasks[1][0]);
		
		
		
		
		return array(false, "ERROR|This stage cannot be loaded as the workflow is already complete.");
	}
	
	
	
	
	$pending_tasks = array();
	
	
	
	$sql = "SELECT fb_admin.user_name, fb_workflow_groups.group_name FROM fb_admin
			INNER JOIN fb_workflow_groups ON fb_workflow_groups.id = fb_admin.workflow_group_id
			WHERE fb_admin.user_id = ?";
	$params = array ($_SESSION['fb_user_id']);
	
	$users_and_groups = Database::pdo_procedure_params ( $sql, $params, 0 );
	

	
	$associations = array($users_and_groups[1][0]['user_name'], $users_and_groups[1][0]['group_name']);
	
	foreach($active_tasks[1] as $active_task){
		
		
		$workflow_data = json_decode(base64_decode($active_task['workflow_data']));
		
		
		$found = false; $next_stage = null; $current_stage = null;
		
		
		
		if(isset($active_task['workflow_stage_to_load']) && $active_task['workflow_stage_to_load'] != ''){
			
			foreach($workflow_data->stages as $key => $stage){
				
				if($key == $active_task['workflow_stage_to_load']){
					
					$next_stage = $stage;
					$current_stage = $active_task['workflow_stage_to_load'];
					
				}
				
			}
			
		} else { 
		
			foreach($workflow_data->stages as $key => $stage){
				if($found){
					$next_stage = $stage;
					$current_stage = $key; 
					break;
				}
				if($key == $active_task['workflow_stage_name']){
					$found = true;

					$next_stage = $stage;
					$current_stage = $key; 
				}
			}
			
		}
		
		
		
		
		if($next_stage != null){
			
			

			foreach($next_stage->users as $user){
				
				
				
				
				
				
				
				
				if(!isset($user->name)){

					foreach($associations as $u){
						
						
						if(trim($next_stage->users->name) == $u){
							
							
							$task_tmp = new stdClass();
							$task_tmp->active_task = $active_task; 
							$task_tmp->stage = $next_stage;
							$task_tmp->current_stage = $current_stage;
							$task_tmp->matching_user = $next_stage->users; 

							$pending_tasks[] = $task_tmp;

						}
					
					}

					break; 

				} else {
				
					
					foreach($associations as $u){
						
						
						if(trim($user->name) == $u){
							
							
							$task_tmp = new stdClass();
							$task_tmp->active_task = $active_task; 
							$task_tmp->stage = $next_stage;
							$task_tmp->current_stage = $current_stage;
							$task_tmp->matching_user = $user; 

							$pending_tasks[] = $task_tmp;
							
						}
						
					}
					
				}
				
			}
			
		}
		
		
	}
	
	
	
	if(count($pending_tasks) == 0){
		
		return array(false, "Warning: Cannot load this task because the task has become corrupted, or the task workflow is already complete.\n\nIn the case of the former, this usually means a bad Stage Override has been set, which can happen if the job parameters have been changed since creation.");
		
	} else if(count($pending_tasks) == 1) {
		
		if($pending_tasks == ''){
			
			return array(false, 'Warning: Cannot load this task because the task has become corrupted, or the workflow is already complete.');
			
		} else {
			
			
			return array(true, $pending_tasks[0]);
		
		}
		
	}
	
}



function has_archived_task_access($workflow_job_id, $formboss_job_name, $task_master_id, $active_task_id){
	
	
	$sql = "SELECT fb_workflow_active_tasks.id AS id
			     , fb_workflow_task_master.task_originator_user_id
			     , fb_workflow_active_tasks.workflow_stage_name
			     , fb_workflow_active_tasks.workflow_stage_to_load
			     , fb_workflow_active_tasks.task_master_id
			     , fb_workflow_active_tasks.task_user_id
			     , fb_workflow_jobs.formboss_job_id
			     , fb_workflow_jobs.formboss_job_name
			     , fb_workflow_jobs.id AS workflow_job_id
			     , fb_workflow_jobs.workflow_data
			     , fb_jobs.job_name
			FROM
			  fb_workflow_active_tasks
			INNER JOIN fb_workflow_jobs
			ON fb_workflow_active_tasks.workflow_job_id = fb_workflow_jobs.id
			INNER JOIN fb_workflow_task_master
			ON fb_workflow_active_tasks.task_master_id = fb_workflow_task_master.id
			INNER JOIN fb_jobs
			ON fb_workflow_jobs.formboss_job_id = fb_jobs.id
			WHERE fb_jobs.job_name = ? AND fb_workflow_active_tasks.task_master_id = ? 
			AND fb_workflow_active_tasks.id = ? 
			AND fb_workflow_task_master.workflow_complete = 1
			ORDER BY id DESC LIMIT 1"; 
	
	
	$params = array ($formboss_job_name, $task_master_id, $active_task_id);
	$active_tasks = Database::pdo_procedure_params ( $sql, $params, 0 );
	
	if(!$active_tasks){
		echo 'No pending tasks';
	}
	
	
	if($active_tasks[1][0]['id'] == ''){
		unset($active_tasks[1][0]);
	}
	
	
	
	
	$archived_tasks = array();
	
	
	
	$sql = "SELECT fb_admin.user_name, fb_workflow_groups.group_name FROM fb_admin
			INNER JOIN fb_workflow_groups ON fb_workflow_groups.id = fb_admin.workflow_group_id
			WHERE fb_admin.user_id = ?";
	$params = array ($_SESSION['fb_user_id']);
	
	$users_and_groups = Database::pdo_procedure_params ( $sql, $params, 0 );
	

	
	$associations = array($users_and_groups[1][0]['user_name'], $users_and_groups[1][0]['group_name']);
	
	
	foreach($active_tasks[1] as $active_task){
		
		
		$workflow_data = json_decode(base64_decode($active_task['workflow_data']));
		
		
		$last_stage = null; 
		$current_stage = '';
		
		foreach($workflow_data->stages as $key => $stage){
			$last_stage = $stage;
			$current_stage = $key; 
		}
		
		
		if($last_stage != null){
			
			
			$task_tmp = new stdClass();
			$task_tmp->active_task = $active_task; 
			$task_tmp->stage = $last_stage;
			$task_tmp->current_stage = $current_stage;
			
			$archived_tasks[] = $task_tmp;
							
							
		}
		
		
	}
	
	
	
	if(count($archived_tasks) == 0){
		
		return array(false, "Warning: Cannot load this task because the task has become corrupted, or the task workflow is already complete.\n\nIn the case of the former, this usually means a bad Stage Override has been set, which can happen if the job parameters have been changed since creation.");
		
	} else if(count($archived_tasks) == 1) {
		
		if($archived_tasks == ''){
			
			return array(false, 'Warning: Cannot load this task because the task has become corrupted, or the workflow is already complete.');
			
		} else {
			
			
			return array(true, $archived_tasks[0]);
		
		}
		
	}
	
}



function has_timeline_task_access($formboss_job_name, $workflow_stage_name, $workflow_job_id, $task_master_id, $active_task_id){
	
	
	$sql = "SELECT fb_workflow_active_tasks.id AS id
			     , fb_workflow_task_master.task_originator_user_id
			     , fb_workflow_active_tasks.workflow_stage_name
			     , fb_workflow_active_tasks.workflow_stage_to_load
			     , fb_workflow_active_tasks.task_master_id
			     , fb_workflow_active_tasks.task_user_id
			     , fb_workflow_jobs.formboss_job_id
			     , fb_workflow_jobs.formboss_job_name
			     , fb_workflow_jobs.id AS workflow_job_id
			     , fb_workflow_jobs.workflow_data
			     , fb_jobs.job_name
			FROM
			  fb_workflow_active_tasks
			INNER JOIN fb_workflow_jobs
			ON fb_workflow_active_tasks.workflow_job_id = fb_workflow_jobs.id
			INNER JOIN fb_workflow_task_master
			ON fb_workflow_active_tasks.task_master_id = fb_workflow_task_master.id
			INNER JOIN fb_jobs
			ON fb_workflow_jobs.formboss_job_id = fb_jobs.id
			WHERE fb_jobs.job_name = ? AND fb_workflow_active_tasks.task_master_id = ? AND fb_workflow_active_tasks.id = ?"; 
	
	
	$params = array ($formboss_job_name, $task_master_id, $active_task_id);
	$active_task = Database::pdo_procedure_params ( $sql, $params, 0 );
	
	if(!$active_task){
		echo 'No pending tasks';
	}
	
	
	
	
	$sql = "SELECT fb_admin.user_name, fb_workflow_groups.group_name FROM fb_admin
			INNER JOIN fb_workflow_groups ON fb_workflow_groups.id = fb_admin.workflow_group_id
			WHERE fb_admin.user_id = ?";
	$params = array ($_SESSION['fb_user_id']);
	
	$users_and_groups = Database::pdo_procedure_params ( $sql, $params, 0 );
	

	
	$associations = array($users_and_groups[1][0]['user_name'], $users_and_groups[1][0]['group_name']);
	

	
	$workflow_data = json_decode(base64_decode($active_task[1][0]['workflow_data']));
	
	$stage = $workflow_data->stages->$workflow_stage_name;

	$pending_task = '';
	
	

	foreach($stage->users as $user){
		
		
		if(!isset($user->name)){

			
			if(trim($user->name) == '[Task Originator]'){
					
				if($active_task[1][0]['task_originator_user_id'] == $_SESSION['fb_user_id'] && (int)$user->timeline_access == 1){
						
					
					$task_tmp = new stdClass();
					$task_tmp->active_task = $active_task[1][0]; 
					$task_tmp->stage = $stage;
					$task_tmp->current_stage = $workflow_stage_name;
					$task_tmp->matching_user = $user; 

					$pending_task = $task_tmp;
						
				}
					
			} else {
				
				foreach($associations as $u){
					
					
					if(trim($user->name) == $u){
						
						
						if(trim($user->timeline_access) == 1){
						
							
							$task_tmp = new stdClass();
							$task_tmp->active_task = $active_task[1][0]; 
							$task_tmp->stage = $stage;
							$task_tmp->current_stage = $workflow_stage_name;
							$task_tmp->matching_user = $user; 
							
							$pending_task = $task_tmp;
							
						}
	
					}
					
				}
			
			}					

		} else {
		
			
			if(trim($user->name) == '[Task Originator]'){
					
				if($active_task[1][0]['task_originator_user_id'] == $_SESSION['fb_user_id'] && (int)$user->timeline_access == 1){
						
					
					$task_tmp = new stdClass();
					$task_tmp->active_task = $active_task[1][0]; 
					$task_tmp->stage = $stage;
					$task_tmp->current_stage = $workflow_stage_name;
					$task_tmp->matching_user = $user; 

					$pending_task = $task_tmp;
						
				}
					
			} else {
				
				foreach($associations as $u){
					
					
					if(trim($user->name) == $u){
						
						
						if(trim($user->timeline_access) == 1){
						
							
							$task_tmp = new stdClass();
							$task_tmp->active_task = $active_task[1][0]; 
							$task_tmp->stage = $stage;
							$task_tmp->current_stage = $workflow_stage_name;
							$task_tmp->matching_user = $user; 
		
							$pending_task = $task_tmp;
							
						}
						
					}
					
				}
				
			}
			
		}
		
	}
	
	
	
	return array($pending_task != '' ? true : false, $pending_task);
	
}


function load_job_controls($task_data = '', $timeline_load = 'false'){
	
	if($task_data == '')
		return;
	
	$task = $task_data[1]; 
	
	$html = "";
	
$html .= <<<EOF
<div class="job-viewer-task-controls-wrapper">
	<input type="hidden" name="current_task_master_id" value="{$task->active_task['task_master_id']}" />
	<input type="hidden" name="current_active_task_id" value="{$task->active_task['id']}" />
	<input type="hidden" name="current_stage_name" value="{$task->current_stage}" />
	<input type="hidden" name="workflow_job_id" value="{$task->active_task['workflow_job_id']}" />
	<input type="hidden" name="timeline_load" value="{$timeline_load}" />
</div>		
EOF;
	
	
	return $html;
}



function load_job_task_management($task_master_id, $workflow_job_id, $task_data){
	
	if($task_master_id == 0)
		return '';
		
	$task_data = $task_data[1]; 
	
	
	
	
	
	
	$sql = "SELECT id, comment FROM fb_workflow_active_tasks WHERE task_master_id = ? ORDER BY id DESC";
	$params = array ($task_master_id);
	$comments = Database::pdo_procedure_params ( $sql, $params, 0 );
	
	$comment_index = 0;
	$has_overflow_html = false;
	
	$existing_comments_html = "<div class=\"comments-html-wrapper\">";
	
	foreach($comments[1] as $comment){
		
		
		if($comment_index == 0){
			
			$existing_comments_html = "<div class=\"workflow-stage-comment-most-recent-header\">Stage Comments</div>";

			$existing_comments_html .= "<div class=\"workflow-stage-comment-most-recent\">{$comment['comment']}</div>";
			
			
			$existing_comments_html .= "<div class=\"workflow-stage-commens-overflow\">";
			
			$has_overflow_html = true;
			
			$comment_index++;
			
		} else {
			
			$existing_comments_html .= "<div class=\"workflow-stage-comment-most-recent\">{$comment['comment']}</div>";
			
		}
		
	}
	
	if($has_overflow_html){
		
		$existing_comments_html .= "</div>"; 
		
	}
	
	$existing_comments_html .= "</div>";
	
		
	
	
	
	$add_comments_html = <<<EOF
<textarea class="task-management-comment" style="width:100%;" onkeyup=""></textarea>
	
EOF;

	$stage_select = "";
	
	if(isset($task_data->matching_user) && $task_data->matching_user->name != '' && (int)$task_data->matching_user->can_change_stages == 1){
		
		
		
		
		$sql = "SELECT workflow_data, formboss_job_name FROM fb_workflow_jobs WHERE id = ?";
		$params = array ($workflow_job_id);
		$workflow_data = Database::pdo_procedure_params ( $sql, $params, 0 );
		$workflow_data = json_decode(base64_decode($workflow_data[1][0]['workflow_data']));
		
		$stage_select_option = "<option value\"\">--SELECT A STAGE--</option>";
		
		
		foreach($workflow_data->stages as $name => $stage){
			
			if($name != (string)$task_data->current_stage){
				
				$stage_select_option .= "<option value=\"{$name}\">{$stage->name}</option>";
				
			} else {
				
				break; 
				
			}
			
		}
	
		
		
		$stage_select .= <<<EOT
<select class="task-management-stage-select" name="">
	{$stage_select_option}
</select>
EOT;
		
	} 
	
	
	
	
	
	
	
	$cancel_workflow = "";
	
	if(isset($task_data->matching_user) && $task_data->matching_user->name != '' && (int)$task_data->matching_user->can_cancel_workflow == 1){
		
		
		$formboss_job_name = $task_data->active_task['formboss_job_name'];
		$workflow_stage_name = $task_data->active_task['workflow_stage_name'];
		$task_master_id = $task_data->active_task['task_master_id']; 
		$active_task_id = $task_data->active_task['id'];
		
		
		$cancel_workflow .= <<<EOT
<input type="button" name="" onclick="query_workflow_cancel(event, this, '{$formboss_job_name}', '{$workflow_stage_name}', {$task_master_id}, {$active_task_id}, true);" value="Cancel This Worfklow Task" />
EOT;
		
	} 

	
	
	$html = <<<EOF
<div class="task-management-wrapper">
	<div class="task-management-header">Task Management</div>
	<div class="task-management-wrapper-padding">
		{$existing_comments_html}
		{$add_comments_html}
		{$stage_select}
		{$cancel_workflow}
	</div>
</div>

EOF;
	
	return $html;
	
}



function load_job_timeline($task_master_id, $workflow_job_id, $task_data){
	
	if($task_master_id == 0)
		return '';
		
	
	$sql = "SELECT workflow_data, formboss_job_name FROM fb_workflow_jobs WHERE id = ?";
	$params = array ($workflow_job_id);
	$workflow_data = Database::pdo_procedure_params ( $sql, $params, 0 );
	
	$formboss_job_name = $workflow_data[1][0]['formboss_job_name'];
	$workflow_data = json_decode(base64_decode($workflow_data[1][0]['workflow_data']));
	
	
	
	$stages = array();
	
	foreach($workflow_data->stages as $stage_name => $stage_data){		
		$stages["{$stage_name}"] = $stage_data;
	}
	
		
	
	$sql = "SELECT fb_workflow_active_tasks.*,
			fb_workflow_task_master.workflow_complete 
			FROM fb_workflow_active_tasks
			INNER JOIN fb_workflow_task_master ON fb_workflow_active_tasks.task_master_id = fb_workflow_task_master.id
			WHERE task_master_id = ?
			ORDER BY fb_workflow_active_tasks.id DESC";
	$params = array ($task_master_id);
	$task_history = Database::pdo_procedure_params ( $sql, $params, 0 );
	
	
	$task_item_html = "";


	
	$count = 0; 
	
	
	
	$most_recent_task_id = -1;
	
	foreach($task_history[1] as $task){
		
		$stage_display_name = $stages["{$task['workflow_stage_name']}"]->name;
		
		$date = new DateTime($task['ts']);
		$task_date = date_format($date, 'm/d/Y'); 
		
		
		
		

		
		
		
		
		if($most_recent_task_id == -1){
			$most_recent_task_id = $task['id'];
		}
			
		if($count == 0 && $task["workflow_complete"] == 0){
			
			$use_code = true;
			
			if($use_code){
			
			$task_item_html .= <<<EOF
		<div class="task-timeline-item" onclick="query_right_timline_job_loader(event, '{$formboss_job_name}', '{$task['workflow_stage_name']}', {$task['workflow_job_id']}, {$task['task_master_id']}, {$task['id']}, 'true');">
			<div class="task-timeline-item-arrow">&gt;&gt;</div>
			<span class="task-timeline-name">Most Recent Task</span><br>
			<span class="task-timeline-date">{$task_date}</span>
		</div>
EOF;
			}
			
			$count++;
		}
		
		$task_item_html .= <<<EOF
		<div class="task-timeline-item" onclick="query_right_timline_job_loader(event, '{$formboss_job_name}', '{$task['workflow_stage_name']}', {$task['workflow_job_id']}, {$task['task_master_id']}, {$task['id']}, 'false');">
			<div class="task-timeline-item-arrow">&gt;&gt;</div>
			<span class="task-timeline-name">{$stage_display_name}</span><br>
			<span class="task-timeline-date">{$task_date}</span>
		</div>
EOF;
	}
	
	
	
	
	$print_timeline_html = <<<EOT
<input type="button" value="Print Timeline" onclick="query_right_timeline_print_timeline(event, '{$formboss_job_name}', '{$task['workflow_stage_name']}', {$task['workflow_job_id']}, {$task['task_master_id']}, {$most_recent_task_id}, 'print_all');" />	
EOT;

	
	$html = <<<EOF
<div class="task-timeline-wrapper">
	<div class="task-timeline-header">Job Timeline</div>
	<div class="task-timeline-wrapper-padding">
		{$task_item_html}
		{$print_timeline_html}
	</div>
</div>

EOF;

	return $html;
	
}



function load_job_data($task_master_id,
					   $formboss_job_name, 
					   $workflow_job_id, 
					   $stage_target = '', 
					   $current_stage_name = ''){
	
	
	$sql = "SELECT job_xml FROM fb_jobs WHERE job_name = ?";
	$params = array ($formboss_job_name);
	$result = Database::pdo_procedure_params ( $sql, $params, 0 );
	
	if(!$result)
		return;
	
	$xml = $result[1][0]['job_xml'];
	
	
	if(substr($xml, 0, 23) == 'PD94bWwgdmVyc2lvbj0iMS4'){
		$xml = base64_decode($xml);
	}
	
	$formboss_job = simplexml_load_string($xml);
	

	
	$sql = "SELECT workflow_data FROM fb_workflow_jobs WHERE id = ?";
	$params = array ($workflow_job_id);
	$result = Database::pdo_procedure_params ( $sql, $params, 0 );
	
	if(!$result)
		return;
		
	
	$workflow = json_decode(base64_decode($result[1][0]['workflow_data']));
	
	

	
	if($stage_target == ''){ 
		foreach($workflow->stages as $key => $stage){
			$current_stage_name = $key;
			$item_to_load = $workflow->stages->$key->stage_target;
			break; 
		}
	} else {
		
		$item_to_load = $stage_target;
	}
	
	
	if(substr_count($item_to_load, '.php') == 1){

		
		$dim = '500,500'; 

		foreach($formboss_job->page as $page){
			if((string)$page->name == $item_to_load){
				$dim = $page->dim;
				break;
			}
		}

		$dims = explode(',', $dim);

		

		if($_SESSION['_workflow_debug']){
			$dims[0] = $dims[0] + 450;
			$dims[1] = $dims[1] + 650;
		}

		
		
		$job_content = '<iframe class="fb-workflow-iframe" id="" name="" src="../output/forms/'.$formboss_job_name.'/'.$item_to_load.'" width="'.$dims[0].'" height="'.$dims[1].'" frameborder="0" scrolling="no" ALLOWTRANSPARENCY="true"></iframe>';
	
		
		
		if(isset($_SESSION['fb_user_id'])){ 
			
			
			$_SESSION['FB_WORKFLOW']['task_user_id'] = $_SESSION['fb_user_id']; 
			$_SESSION['FB_WORKFLOW']['formboss_user_id'] = $_SESSION['fb_user_id'];
			
		} else {
			
			
			$_SESSION['FB_WORKFLOW']['task_user_id'] = ''; 
			$_SESSION['FB_WORKFLOW']['formboss_user_id'] = NULL; 
			
		}
		
		
		
		
		if(!isset($_SESSION['FB_WORKFLOW']['formboss_job_id']))
			$_SESSION['FB_WORKFLOW']['formboss_job_id'] = -1;
			
		$_SESSION['FB_WORKFLOW']['workflow_job_id'] = $workflow_job_id;
		$_SESSION['FB_WORKFLOW']['workflow_stage_name'] = $current_stage_name;
		
		
	} else {
		
	}
	
	return $job_content;
	
}



function load_job_data_timeline($workflow_data, 
								$task_master_id, 
								$active_task_id, 
								$formboss_job_name, 
								$workflow_job_id, 
								$stage_target = '', 
								$current_stage_name = '',
								$load_location = 'inline',
								$print_type = ''){
	
	
	$sql = "SELECT job_xml FROM fb_jobs WHERE job_name = ?";
	$params = array ($formboss_job_name);
	$result = Database::pdo_procedure_params ( $sql, $params, 0 );
	
	if(!$result)
		return;
	
	$xml = $result[1][0]['job_xml'];
	
	
	if(substr($xml, 0, 23) == 'PD94bWwgdmVyc2lvbj0iMS4'){
		$xml = base64_decode($xml);
	}
	
	$formboss_job = simplexml_load_string($xml);
	
	
	if($workflow_data == '')
		return;
		
	
	$workflow = json_decode(base64_decode($workflow_data));
	
	

	
	if($stage_target == ''){ 
		foreach($workflow->stages as $key => $stage){
			$current_stage_name = $key;
			$item_to_load = $workflow->stages->$key->stage_target;
			break; 
		}
	} else {
		
		$item_to_load = $stage_target;
	}
	
	
	if(substr_count($item_to_load, '.php') == 1){
		
		$dim = '500,500'; 
		foreach($formboss_job->page as $page){
			if((string)$page->name == $item_to_load){
				$dim = $page->dim;
				break;
			}
		}
		$dims = explode(',', $dim);
		
		
		
		
		
		$output_path = '../output/forms/';
		
		
		
		
		

		
		
		$render_submit_button_code = "";
		
		if($load_location == 'stand_alone'){
			$output_path = '../../../../../../output/forms/';
			$render_submit_button_code = "?fb-workflow-print-view=true";
		}

		if($print_type != ''){
			$render_submit_button_code = "?fb-workflow-print-view=true";
		}

		

		if ($_SESSION['_workflow_debug']) {
			$dims[0] = $dims[0] + 450;
			$dims[1] = $dims[1] + 650;
		}
		
		
		
		$job_content = '<iframe class="fb-workflow-iframe timeline-item" id="" name="fb-iframe-JobTitle" src="'.$output_path.$formboss_job_name.'/'.$item_to_load.$render_submit_button_code.'" width="'.$dims[0].'" height="'.$dims[1].'" frameborder="0" scrolling="no" ALLOWTRANSPARENCY="true"></iframe>';
	
		
		
		if(isset($_SESSION['fb_user_id'])){ 
			
			
			$_SESSION['FB_WORKFLOW']['task_user_id'] = $_SESSION['fb_user_id']; 
			$_SESSION['FB_WORKFLOW']['formboss_user_id'] = $_SESSION['fb_user_id'];
			
		} else {
			
			
			$_SESSION['FB_WORKFLOW']['task_user_id'] = ''; 
			$_SESSION['FB_WORKFLOW']['formboss_user_id'] = NULL; 
			
		}
		
		
		
		
		if(!isset($_SESSION['FB_WORKFLOW']['formboss_job_id']))
			$_SESSION['FB_WORKFLOW']['formboss_job_id'] = -1;
			
		$_SESSION['FB_WORKFLOW']['workflow_job_id'] = $workflow_job_id;
		$_SESSION['FB_WORKFLOW']['workflow_stage_name'] = $current_stage_name;
		
		
	} else {
		
	}
	
	return $job_content;
	
}










if(isset($_POST['request']) && $_POST['request'] == 'load-job-timeline-print-view'){
	
$html = <<<EOF
{$job_content}
EOF;
	
} else {
	
$html = <<<EOF
{$job_timeline}
{$job_task_mamangment}
<div class="job-viewer-header">
	<div class="job-viewer-title">{$formboss_job_name}</div>
	<div class="job-viewer-controls">
		{$job_controls}
		<div class="job-viewer-controls-close-button" onclick="query_right_job_loader_close(event, this, {$active_task_master_id}, true)">Close Window</div>
	</div>
</div>
<div class="job-viewer-content">{$job_content}</div>
<div class="job-viewer-footer">&nbsp;</div>

EOF;

}

echo $html;










?>')); ?>
Function Calls
base64_decode | 1 |
Stats
MD5 | 68cb74a518092941275d362592522359 |
Eval Count | 1 |
Decode Time | 168 ms |