Chamilo is a learning management system focused on ease of use and accessibility
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
chamilo-lms/main/inc/lib/SequenceManager.php

1278 lines
48 KiB

<?php
/* For licensing terms, see /license.txt */
/**
* Class SequenceManager
*/
class SequenceManager
{
const _debug = false;
/**
* @param $row_entity_id
* @return array|bool
*/
public static function get_pre_req_id_by_row_entity_id($row_entity_id)
{
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
$row_entity_id = intval($row_entity_id);
if ($row_entity_id > 0) {
$seq_table = Database::get_main_table(TABLE_MAIN_SEQUENCE);
$sql = "SELECT sequence_row_entity_id FROM $seq_table
WHERE sequence_row_entity_id_next = $row_entity_id";
$result = Database::query($sql);
if (Database::num_rows($result) > 0) {
while ($temp_pre_req = Database::fetch_array($result, 'ASSOC')){
$pre_req[] = intval($temp_pre_req['sequence_row_entity_id']);
}
return $pre_req;
}
}
return false;
}
/**
* @param int $entity_id
* @param int $row_entity_id
* @param int $course_id
* @return array|bool
*/
public static function get_next_by_row_id($entity_id, $row_entity_id, $course_id = null)
{
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
$row_entity_id = Database::escape_string($row_entity_id);
$entity_id = Database::escape_string($entity_id);
$course_id = Database::escape_string($course_id);
if (is_numeric($row_entity_id) && is_numeric($entity_id)) {
$row_entity_id = intval($row_entity_id);
$entity_id = intval($entity_id);
$course_id = is_numeric($course_id) ? intval($course_id) : api_get_course_int_id();
$seq_table = Database::get_main_table(TABLE_MAIN_SEQUENCE);
$row_table = Database::get_main_table(TABLE_SEQUENCE_ROW_ENTITY);
$sql = "SELECT row.id FROM $row_table row
WHERE
row.sequence_type_entity_id = $entity_id AND
row.row_id = $row_entity_id AND
row.c_id = $course_id LIMIT 0, 1";
$sql = "SELECT main.sequence_row_entity_id_next
FROM $seq_table main WHERE main.sequence_row_entity_id_next IN ($sql)";
$sql = "SELECT * FROM $row_table res
WHERE res.id IN ($sql)";
$result = Database::query($sql);
if (Database::num_rows($result) > 0) {
while ($temp_next = Database::fetch_array($result, 'ASSOC')){
$next[] = $temp_next;
}
return $next;
}
}
return false;
}
/**
* @param int $entity_id
* @return array|bool
*/
public static function get_entity_by_id($entity_id)
{
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
$entity_id = intval($entity_id);
if (is_numeric($entity_id)) {
$entity_id = intval($entity_id);
$ety_table = Database::get_main_table(TABLE_SEQUENCE_TYPE_ENTITY);
$sql = "SELECT * FROM $ety_table WHERE id = $entity_id LIMIT 0, 1";
$result = Database::query($sql);
if (Database::num_rows($result) > 0) {
while ($temp_entity = Database::fetch_array($result, 'ASSOC')){
$entity[] = $temp_entity;
}
return $entity;
}
}
return false;
}
/**
* @param int $row_entity_id
* @param int $user_id
* @param int $session_id
* @param int $rule_id
*
* @return bool
*/
public static function validate_rule_by_row_id(
$row_entity_id,
$user_id = null,
$session_id,
$rule_id = 1
) {
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
$condition = self::get_condition_by_rule_id($rule_id);
if ($condition !== false) {
$con = $condition[0];
while(isset($con)) {
$var = self::get_variable_by_condition_id($con['id']);
$val = self::get_value_by_user_id($row_entity_id, $user_id, $session_id, 1);
$statement = 'return ('.floatval($val[0][$var[0]["name"]]).' '.$con["mat_op"].' '.$con["param"].');';
if (eval($statement)) {
$go = (!isset($con['act_true']))? -1 : intval($con['act_true']);
} else {
$go = (!isset($con['act_false']))? -1 : intval($con['act_false']);
}
if ($go === 0) {
return true;
} else {
--$go;
$con = isset($condition[$go]) ? $condition[$go] : null;
}
}
}
return false;
}
/**
* @param int $rule_id
* @return array|bool
*/
public static function get_condition_by_rule_id($rule_id = 1)
{
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
$rule_id = intval($rule_id);
if (is_numeric($rule_id)) {
$rule_id = intval($rule_id);
$con_table = Database::get_main_table(TABLE_SEQUENCE_CONDITION);
$rul_con_table = Database::get_main_table(TABLE_SEQUENCE_RULE_CONDITION);
$sql = "SELECT rc.sequence_condition_id FROM $rul_con_table rc
WHERE rc.sequence_rule_id = $rule_id";
$sql = "SELECT * FROM $con_table co WHERE co.id IN ($sql)";
$result = Database::query($sql);
if (Database::num_rows($result) > 0) {
while ($temp_condition = Database::fetch_array($result, 'ASSOC')) {
$condition[] = $temp_condition;
}
return $condition;
}
}
return false;
}
/**
* @param int $rule_id
*
* @return array|bool
*/
public static function get_method_by_rule_id($rule_id = 1)
{
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
$rule_id = intval($rule_id);
if (is_numeric($rule_id)) {
$rule_id = intval($rule_id);
$met_table = Database::get_main_table(TABLE_SEQUENCE_METHOD);
$rul_met_table = Database::get_main_table(TABLE_SEQUENCE_RULE_METHOD);
$sql = "SELECT rm.sequence_method_id
FROM $rul_met_table rm
WHERE rc.sequence_rule_id = $rule_id";
$sql = "SELECT * FROM $met_table co
WHERE co.id IN ($sql)";
$result = Database::query($sql);
if (Database::num_rows($result) > 0) {
while ($temp_method = Database::fetch_array($result, 'ASSOC')){
$method[] = $temp_method;
}
return $method;
}
}
return false;
}
/**
* @param int $row_entity_id
*
* @return array|bool
*/
public static function get_value_by_row_entity_id($row_entity_id)
{
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
$row_entity_id = intval($row_entity_id);
if ($row_entity_id > 0) {
$val_table = Database::get_main_table(TABLE_SEQUENCE_VALUE);
$sql = "SELECT * FROM $val_table val
WHERE val.sequence_row_entity_id = $row_entity_id";
$result = Database::query($sql);
if (Database::num_rows($result) > 0) {
while ($temp_value = Database::fetch_array($result, 'ASSOC')){
$value[] = $temp_value;
}
return $value;
}
}
return false;
}
/**
* @param int $condition_id
* @return array|bool
*/
public static function get_variable_by_condition_id($condition_id)
{
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
$condition_id = intval($condition_id);
if (is_numeric($condition_id)) {
$condition_id = intval($condition_id);
$var_table = Database::get_main_table(TABLE_SEQUENCE_VARIABLE);
$vld_table = Database::get_main_table(TABLE_SEQUENCE_VALID);
$sql = "SELECT DISTINCT vld.sequence_variable_id
FROM $vld_table vld
WHERE vld.sequence_condition_id = $condition_id";
$sql = "SELECT * FROM $var_table var WHERE var.id IN ($sql)";
$result = Database::query($sql);
if (Database::num_rows($result) > 0) {
while ($temp_variable = Database::fetch_array($result, 'ASSOC')) {
$variable[] = $temp_variable;
}
return $variable;
}
}
return false;
}
/**
* @param int $row_entity_id
* @param int $user_id
* @param $session_id
* @param string $met_type
* @param int $available
* @param int $complete_items
* @param int $total_items
* @param null $available_end_date
* @return bool
*/
public static function execute_formulas_by_user_id(
$row_entity_id = null,
$user_id = null,
$session_id,
$met_type = '',
$available = 1,
$complete_items = 1,
$total_items = 1,
$available_end_date = null
) {
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
$value = self::get_value_by_user_id($row_entity_id, $user_id, $session_id, $available);
$met_type = Database::escape_string($met_type);
if ($value !== false) {
if (empty($met_type)) {
$met_filter = " AND met.met_type NOT IN ('success', 'pre', 'update') ";
} else {
$met_filter = " AND met.met_type = '$met_type' ";
}
$val_table = Database::get_main_table(TABLE_SEQUENCE_VALUE);
$rul_table = Database::get_main_table(TABLE_SEQUENCE_RULE);
$rul_met_table = Database::get_main_table(TABLE_SEQUENCE_RULE_METHOD);
$met_table = Database::get_main_table(TABLE_SEQUENCE_METHOD);
$var_table = Database::get_main_table(TABLE_SEQUENCE_VARIABLE);
$sql = "SELECT var.id, var.name FROM $var_table var";
$result = Database::query($sql);
$variable = [];
while ($temp_var = Database::fetch_row($result)) {
$variable[$temp_var['0']] = $temp_var['1'];
}
$sql = "SELECT rul.id FROM $rul_table rul";
$sql = "SELECT met.formula, met.assign assign
FROM $met_table met, $rul_met_table rm
WHERE
met.id = rm.sequence_method_id $met_filter
ORDER BY rm.method_order";
$result = Database::query($sql);
while ($temp_fml = Database::fetch_array($result, 'ASSOC')) {
$formula[] = $temp_fml;
}
$pat = "/v#(\d+)/";
if (isset($formula) && isset($variable)) {
if (is_array($value[0])) {
$rep = '$val[$variable[$1]]';
foreach ($value as $val) {
$sql_array = array(
'UPDATE' => " $val_table SET "
);
foreach ($formula as $fml) {
$assign_key = $variable[$fml['assign']];
$assign_val = &$val[$variable[$fml['assign']]];
$fml_exe = preg_replace($pat, $rep, $fml['formula']);
$fml_exe = 'return '.$fml_exe;
$assign_val = eval($fml_exe);
$sql_array[$assign_key] = " = '$assign_val', ";
}
$sql_array['WHERE'] = ' id = '.$val['id'];
$sql = '';
foreach ($sql_array as $sql_key => $sql_val) {
$sql .= $sql_key;
$sql .= $sql_val;
}
$sql = preg_replace('/, WHERE/', ' WHERE', $sql);
$result = Database::query($sql);
}
}
return true;
}
}
return false;
}
/**
* @param int $row_entity_id
* @param int $user_id
* @param int $session_id
* @param int $available
* @param int $success
* @return array|bool
*/
public static function get_value_by_user_id(
$row_entity_id = null,
$user_id = null,
$session_id = null,
$available = -1,
$success = -1
) {
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
$user_id = (isset($user_id))? intval($user_id) : api_get_user_id();
if ($user_id > 0) {
$available = Database::escape_string($available);
$available = (is_numeric($available))? intval($available) : -1;
if ($available < 0) {
$available_filter = '';
} else {
$available_filter = " AND available = $available ";
}
$success = Database::escape_string($success);
$success = (is_numeric($success))? intval($success) : -1;
if ($success < 0) {
$success_filter = '';
} else {
$success_filter = " AND success = $success ";
}
$row_entity_id = Database::escape_string($row_entity_id);
$row_entity_id = (is_numeric($row_entity_id))? intval($row_entity_id) : 0;
if ($row_entity_id !== 0) {
$row_entity_filter = " AND sequence_row_entity_id = $row_entity_id ";
} else {
$row_entity_filter = '';
}
$session_id = Database::escape_string($session_id);
$session_id = (is_numeric($session_id))? intval($session_id) : -1;
if ($session_id < 0) {
$session_filter = '';
} else {
$session_filter = " AND session_id = $session_id ";
}
$val_table = Database::get_main_table(TABLE_SEQUENCE_VALUE);
$sql = "SELECT * FROM $val_table
WHERE
user_id = $user_id
$available_filter
$success_filter
$row_entity_filter
$session_filter
";
$result = Database::query($sql);
if (Database::num_rows($result) > 0) {
while($temp_value = Database::fetch_array($result,'ASSOC')) {
$value[] = $temp_value;
}
return $value;
}
}
return false;
}
/**
* @param $formula
* @return array|bool
*/
public static function find_variables_in_formula($formula)
{
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
$formula = Database::escape_string($formula);
if (isset($formula)) {
$pat = "/v#(\d+)/";
preg_match_all($pat, $formula, $v_array);
if (isset($v_array)){
$var_array = array_unique($v_array[1]);
sort($var_array);
return $var_array;
}
}
return false;
}
/**
* @param int $row_entity_id
* @return array|bool
*/
public static function get_user_id_by_row_entity_id($row_entity_id = 0)
{
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
$row_entity_id = intval($row_entity_id);
if ($row_entity_id > 0) {
$row_entity_filter = "WHERE sequence_row_entity_id = $row_entity_id";
} else {
$row_entity_filter = '';
}
$val_table = Database::get_main_table(TABLE_SEQUENCE_VALUE);
$sql = "SELECT DISTINCT user_id, session_id
FROM $val_table $row_entity_filter";
$result = Database::query($sql);
if (Database::num_rows($result) > 0) {
while ($temp_user = Database::fetch_array($result, 'ASSOC')) {
$user[] = $temp_user;
}
return $user;
}
return false;
}
/**
* @param $row_entity_id
* @param $user_id
* @param $session_id
* @param null $available_end_date
* @return bool
*/
public static function action_pre_init(
$row_entity_id,
$user_id,
$session_id,
$available_end_date = null
) {
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
$user_id = intval($user_id);
$session_id = intval($session_id);
$row_entity_id = intval($row_entity_id);
$seq_table = Database::get_main_table(TABLE_MAIN_SEQUENCE);
$val_table = Database::get_main_table(TABLE_SEQUENCE_VALUE);
$sql = "SELECT DISTINCT seq.sequence_row_entity_id, val.user_id
FROM $seq_table seq, $val_table val
WHERE
seq.is_part != 1
AND val.success = 0
AND val.user_id = $user_id
AND val.session_id = $session_id
AND val.sequence_row_entity_id = seq.sequence_row_entity_id
AND seq.sequence_row_entity_id_next = $row_entity_id";
$result = Database::query($sql);
while ($temp = Database::fetch_array($result, 'ASSOC')){
$pre_req[$temp['user_id']] = $temp['sequence_row_entity_id'];
}
if (empty($pre_req)) {
if (self::get_value_by_user_id($row_entity_id, $user_id, $session_id) === false) {
self::temp_hack_4_insert(1, $row_entity_id, $user_id, 0, $session_id);
}
self::execute_formulas_by_user_id(
$row_entity_id,
$user_id,
$session_id,
'pre',
0,
null,
null,
$available_end_date
);
return true;
} else {
self::temp_hack_4_set_aval($row_entity_id, $user_id, $session_id, 0);
}
return false;
}
/**
* @param int $row_entity_id
* @param int $user_id
* @param $session_id
* @param null $available_end_date
*/
public static function action_post_success_by_user_id($row_entity_id, $user_id, $session_id, $available_end_date = null)
{
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
if (self::execute_formulas_by_user_id(
$row_entity_id,
$user_id,
$session_id,
'success',
1,
null,
null,
null
)
) {
$seq_table = Database::get_main_table(TABLE_MAIN_SEQUENCE);
$value = self::get_value_by_user_id($row_entity_id, $user_id, $session_id, 1, 1);
//$check_array = []; Update later
foreach ($value as $val) {
$row_entity_id_prev = $val['sequence_row_entity_id'];
$sql = "SELECT seq.sequence_row_entity_id_next
FROM $seq_table seq
WHERE seq.sequence_row_entity_id = $row_entity_id_prev";
$result = Database::query($sql);
while ($temp_next = Database::fetch_array($result, 'ASSOC')) {
$next[] = $temp_next['sequence_row_entity_id_next'];
}
foreach ($next as $nx) {
self::action_pre_init(
$nx,
$user_id,
$session_id,
$available_end_date
);
}
}
}
}
/**
* @param int $entity_id
* @param int $row_id
* @param int $c_id
*/
public static function getAllRowEntityIdByRowId($entity_id, $row_id, $c_id)
{
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
$row_id = intval($row_id);
$entity_id = intval($entity_id);
$c_id = intval($c_id);
$row_entity_id_prev = self::get_row_entity_id_by_row_id($entity_id, $row_id, $c_id);
if ($row_id > 0 && $entity_id > 0 && $c_id > 0) {
$table = Database::get_main_table(TABLE_MAIN_SEQUENCE);
$tableRow = Database::get_main_table(TABLE_SEQUENCE_ROW_ENTITY);
$sql = "SELECT DISTINCT r.* FROM $table s
INNER JOIN $tableRow r
ON (r.id = s.sequence_row_entity_id)
WHERE sequence_row_entity_id_next = $row_entity_id_prev";
$result = Database::query($sql);
if (Database::num_rows($result) > 0) {
$row_entity = array();
while ($temp_row_entity = Database::fetch_array($result, 'ASSOC')) {
$row_entity[] = $temp_row_entity;
}
return $row_entity;
}
}
return array();
}
/**
* @param int $entity_id
* @param int $row_id
* @param int $c_id
* @return array
*/
public static function getRowEntityByRowId($entity_id, $row_id, $c_id)
{
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
$row_id = intval($row_id);
$entity_id = intval($entity_id);
$c_id = intval($c_id);
if ($row_id > 0 && $entity_id > 0 && $c_id > 0) {
$row_table = Database::get_main_table(TABLE_SEQUENCE_ROW_ENTITY);
$sql = "SELECT row.*
FROM $row_table row
WHERE
row.sequence_type_entity_id = $entity_id AND
row.row_id = $row_id AND
row.c_id = $c_id
LIMIT 0, 1";
$result = Database::query($sql);
if (Database::num_rows($result) > 0) {
return Database::fetch_array($result, 'ASSOC');
}
}
return array();
}
/**
* @param int $row_entity_id
* @param int $user_id
* @param int $session_id
* @return mixed
*/
public static function getValIdByRowEntityId($row_entity_id, $user_id, $session_id)
{
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
$row_entity_id = intval($row_entity_id);
$user_id = intval($user_id);
$session_id = intval($session_id);
if ($row_entity_id > 0 && $user_id > 0 && $session_id >= 0) {
$val_table = Database::get_main_table(TABLE_SEQUENCE_VALUE);
$seq_table = Database::get_main_table(TABLE_MAIN_SEQUENCE);
//check if exists value row
$sql = "SELECT val.id FROM $val_table val
WHERE
val.sequence_row_entity_id = $row_entity_id
AND val.user_id = $user_id
AND val.session_id = $session_id
LIMIT 0, 1";
$result = Database::query($sql);
if (Database::num_rows($result) > 0) {
$temp_row_entity = Database::fetch_array($result, 'ASSOC');
return $temp_row_entity['id'];
} else {
$sql = "SELECT sequence_row_entity_id FROM $seq_table
WHERE sequence_row_entity_id_next = $row_entity_id";
$result = Database::query($sql);
$available = 0;
if (Database::num_rows($result)) {
while ($temp_row_entity = Database::fetch_row($result)) {
if ($temp_row_entity[0] == 0) {
$available = 1;
break;
}
}
// Val row starts not available
} else {
// Val row starts available
$available = 1;
}
return self::temp_hack_4_insert(1, $row_entity_id, $user_id, $available, $session_id);
}
}
return 0;
}
/**
* @param int $entity_id
* @param int $row_id
* @param int $c_id
* @param string $name
* @return int
*/
public static function get_row_entity_id_by_row_id($entity_id, $row_id, $c_id, $name = '')
{
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
error_log('......................................');
error_log('entity_id: '.$entity_id.'.............');
error_log('row_id: '.$row_id.'...................');
error_log('c_id: '.$c_id.'.......................');
}
$row_id = intval($row_id);
$entity_id = intval($entity_id);
$c_id = intval($c_id);
$name = Database::escape_string($name);
if ($row_id > 0 && $entity_id > 0 && $c_id > 0) {
$row_table = Database::get_main_table(TABLE_SEQUENCE_ROW_ENTITY);
$clp_table = Database::get_course_table(TABLE_LP_MAIN);
$sql = "SELECT row.id
FROM $row_table row
WHERE
row.sequence_type_entity_id = $entity_id AND
row.row_id = $row_id AND
row.c_id = $c_id
LIMIT 0, 1";
$result = Database::query($sql);
if (Database::num_rows($result) > 0) {
while ($temp_row_entity = Database::fetch_array($result, 'ASSOC')) {
$row_entity[] = $temp_row_entity;
}
if (self::_debug) {
error_log('Return in '.__FUNCTION__.' in '.__FILE__);
error_log('...............................'.$row_entity[0]['id']);
}
return $row_entity[0]['id'];
} elseif ($entity_id == 1) {
$sql = "SELECT name, prerequisite FROM $clp_table
WHERE c_id = $c_id
AND id = $row_id
LIMIT 0, 1";
$result = Database::query($sql);
if (Database::num_rows($result) > 0) {
$temp_arr = Database::fetch_array($result, 'ASSOC');
$name = $temp_arr['name'];
$name = Database::escape_string($name);
$pre = ($temp_arr['prerequisite'] > 0)? self::get_row_entity_id_by_row_id($entity_id, $temp_arr['prerequisite'], $c_id) : 0 ;
$sql = "INSERT INTO $row_table (sequence_type_entity_id, c_id, row_id, name)
VALUES ($entity_id, $c_id, $row_id, '$name')";
Database::query($sql);
$id = Database::insert_id();
if ($id != 0) {
$seq_table = Database::get_main_table(TABLE_MAIN_SEQUENCE);
$sql = "INSERT INTO $seq_table (sequence_row_entity_id, sequence_row_entity_id_next, is_part) VALUES
($pre, $id, 0)";
Database::query($sql);
if (self::_debug) {
error_log('Return in '.__FUNCTION__.' in '.__FILE__);
error_log('................................'.$id);
}
return $id;
} else {
if (self::_debug) {
error_log('Fail and Return in '.__FUNCTION__.' in '.__FILE__);
error_log('................................');
error_log($sql);
error_log('................................');
error_log('......................................0');
}
}
} else {
if (self::_debug) {
error_log('No result for query in '.__FUNCTION__.' in '.__FILE__);
error_log('................................');
error_log($sql);
}
}
} else {
if (self::_debug) {
error_log('Fail and Return in '.__FUNCTION__.' in '.__FILE__);
error_log('................................');
error_log($sql);
error_log('................................');
error_log('......................................0');
}
}
}
if (self::_debug) {
error_log('Fail and Return in '.__FUNCTION__.' in '.__FILE__);
error_log('......................................');
error_log('entity_id: '.$entity_id.'.............');
error_log('row_id: '.$row_id.'...................');
error_log('c_id: '.$c_id.'.......................');
error_log('......................................0');
}
return 0;
}
/**
* @param $entity_id
* @param $row_id
* @param $c_id
* @param $session_id
* @param $user_id
* @param $rule_id
* @param int $items_completed
* @param int $total_items
* @param null $available_end_date
*/
public static function temp_hack_4_update($entity_id, $row_id, $c_id, $session_id, $user_id, $rule_id, $items_completed = 1, $total_items = 1, $available_end_date =null )
{
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
$row_entity_id = self::get_row_entity_id_by_row_id($entity_id, $row_id, $c_id);
if (!empty($row_entity_id)) {
self::execute_formulas_by_user_id($row_entity_id, $user_id, $session_id, 'update', 1, $items_completed, $total_items);
if (self::validate_rule_by_row_id($row_entity_id, $user_id, $session_id, $rule_id) && (self::get_value_by_user_id($row_entity_id, $user_id, $session_id, 1, 1) === false)) {
self::action_post_success_by_user_id($row_entity_id, $user_id, $session_id, $available_end_date);
}
}
}
/**
* @param $entity_name
* @return bool
*/
public static function get_table_by_entity_name($entity_name)
{
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
$entity_name = Database::escape_string($entity_name);
$ety_table = Database::get_main_table(TABLE_SEQUENCE_TYPE_ENTITY);
$sql = "SELECT ety.ent_table
FROM $ety_table ety
WHERE ety.name = $entity_name
LIMIT 0, 1";
$result = Database::query($sql);
if (Database::num_rows($result) > 0) {
while ($temp_entity = Database::fetch_array($result, 'ASSOC')) {
$entity[] = $temp_entity;
}
return $entity[0]['ent_table'];
}
return false;
}
/**
* @param $entity_name
* @return array|bool
*/
public static function get_entity_by_entity_name($entity_name)
{
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
$entity_name = Database::escape_string($entity_name);
$ety_table = Database::get_main_table(TABLE_SEQUENCE_TYPE_ENTITY);
$sql = "SELECT ety.* FROM $ety_table ety WHERE ety.name = $entity_name LIMIT 0, 1";
$result = Database::query($sql);
if (Database::num_rows($result) > 0) {
while ($temp_entity = Database::fetch_array($result,'ASSOC')) {
$entity[] = $temp_entity;
}
return $entity;
}
return false;
}
/**
* @param $entity_id
* @param $row_id
* @param $c_id
* @param string $name
* @return bool|string
*/
public static function temp_hack_2_insert($entity_id, $row_id, $c_id, $name = '')
{
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
$row_id = intval(Database::escape_string($row_id));
$c_id = intval(Database::escape_string($c_id));
$entity_id = intval(Database::escape_string($entity_id));
$name = Database::escape_string($name);
if ($entity_id > 0 && $row_id > 0 && $c_id >0) {
$row_table = Database::get_main_table(TABLE_SEQUENCE_ROW_ENTITY);
$sql = "INSERT INTO $row_table (sequence_type_entity_id, c_id, row_id, name) VALUES
($entity_id, $c_id, $row_id, '$name')";
Database::query($sql);
if (Database::affected_rows() > 0) {
return Database::insert_id();
}
}
return false;
}
/**
* @param $entity_id_prev
* @param $entity_id_next
* @param int $row_id_prev
* @param int $row_id_next
* @param int $c_id
* @param int $is_part
* @return bool|string
*/
public static function temp_hack_3_insert($entity_id_prev, $entity_id_next, $row_id_prev = 0, $row_id_next = 0, $c_id = 1, $is_part = 0)
{
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
$is_part = intval($is_part);
$seq_table = Database::get_main_table(TABLE_MAIN_SEQUENCE);
$prev = self::get_row_entity_id_by_row_id($entity_id_prev, $row_id_prev, $c_id);
$next = self::get_row_entity_id_by_row_id($entity_id_next, $row_id_next, $c_id);
if ($prev != 0 || $next != 0) {
$sql = "INSERT INTO $seq_table (sequence_row_entity_id, sequence_row_entity_id_next, is_part) VALUES
($prev, $next, $is_part)";
Database::query($sql);
if (Database::affected_rows() > 0) {
return Database::insert_id();
}
}
return false;
}
/**
* @param $total_items
* @param $row_entity_id
* @param int $user_id
* @param int $available
* @param $session_id
* @return string
*/
public static function temp_hack_4_insert($total_items, $row_entity_id, $user_id = 0, $available = -1, $session_id)
{
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
$user_id = intval($user_id);
$session_id = intval($session_id);
$total_items = intval($total_items);
$available = intval($available);
if ($available === -1) {
$pre_req = self::get_pre_req_id_by_row_entity_id($row_entity_id);
foreach ($pre_req as $pr) {
if($pr === 0) {
$available = 1;
break;
}
}
}
if (self::get_value_by_user_id($row_entity_id, $user_id, $session_id) === false) {
$val_table = Database::get_main_table(TABLE_SEQUENCE_VALUE);
$sql = "INSERT INTO $val_table (user_id, sequence_row_entity_id, total_items, available, session_id)
VALUES ($user_id, $row_entity_id, $total_items, $available, $session_id)";
Database::query($sql);
return Database::insert_id();
}
}
/**
* Cleans the sequence table by sequence_row_entity_id_next
* @param int $id
* @param int $c_id
*/
public function cleanPrerequisites($id, $c_id)
{
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
$table = Database::get_main_table(TABLE_MAIN_SEQUENCE);
$row_entity_id_next = self::get_row_entity_id_by_row_id(1, $id, $c_id);
$sql = "DELETE FROM $table
WHERE sequence_row_entity_id_next = $row_entity_id_next";
Database::query($sql);
}
/**
* @param $entity_id_prev
* @param $entity_id_next
* @param int $row_id_prev
* @param int $row_id_next
* @param int $c_id
* @param int $user_id
*/
public static function temp_hack_3_update(
$entity_id_prev,
$entity_id_next,
$row_id_prev = 0,
$row_id_next = 0,
$c_id = 0,
$user_id = 0
) {
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
$user_id = intval($user_id);
$row_entity_id_prev = self::get_row_entity_id_by_row_id($entity_id_prev, $row_id_prev, $c_id);
$row_entity_id_next = self::get_row_entity_id_by_row_id($entity_id_next, $row_id_next, $c_id);
if ($row_entity_id_prev !== 0 || $row_entity_id_next !== 0) {
$seq_table = Database::get_main_table(TABLE_MAIN_SEQUENCE);
// Old code
/*$sql = "UPDATE $seq_table SET sequence_row_entity_id = $row_entity_id_prev WHERE sequence_row_entity_id_next = $row_entity_id_next";
Database::query($sql);*/
// Check if exists.
$sql = "SELECT count(*) as count FROM $seq_table
WHERE sequence_row_entity_id = $row_entity_id_prev AND sequence_row_entity_id_next = $row_entity_id_next";
$result = Database::query($sql);
$countRow = Database::fetch_array($result);
$count = $countRow['count'];
if (empty($count)) {
// Insert
$sql = "INSERT INTO $seq_table SET sequence_row_entity_id = $row_entity_id_prev, sequence_row_entity_id_next = $row_entity_id_next";
Database::query($sql);
} else {
// Update.
$data = self::getRowEntityByRowId($entity_id_next, $row_id_next, $c_id);
$sql = "UPDATE $seq_table SET sequence_row_entity_id = $row_entity_id_prev
WHERE sequence_row_entity_id_next = $row_entity_id_next AND id = {$data['id']}";
Database::query($sql);
}
if ($row_entity_id_prev === 0) {
if ($user_id === 0) {
$user_id = self::get_user_id_by_row_entity_id($row_entity_id_next);
foreach ($user_id as $us_id) {
self::action_pre_init($row_entity_id_next, $us_id['user_id'], $us_id['session_id']);
}
} else {
$sessions = self::get_sessions_by_user_id($user_id,$row_entity_id_next);
foreach ($sessions as $session) {
self::action_pre_init($row_entity_id_next, $user_id, $session);
}
}
} else {
if ($user_id === 0) {
$user_id = self::get_user_id_by_row_entity_id($row_entity_id_prev);
foreach ($user_id as $us_id) {
self::action_pre_init($row_entity_id_next, $us_id['user_id'], $us_id['session_id'], 0);
}
} else {
$sessions = self::get_sessions_by_user_id($user_id,$row_entity_id_next);
foreach ($sessions as $session) {
self::action_pre_init($row_entity_id_next, $user_id, $session['session_id']);
}
}
}
}
}
public static function get_sessions_by_user_id($user_id, $row_entity_id)
{
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
$val_table = Database::get_main_table(TABLE_SEQUENCE_VALUE);
$row_entity_id = intval($row_entity_id);
$sessions = [];
$sql = "SELECT session_id FROM $val_table
WHERE user_id = $user_id
AND row_entity_id = $row_entity_id";
$res = Database::query($sql);
while ($temp_array = Database::fetch_array($res, 'ASSOC')) {
$sessions[] = $temp_array;
}
return $sessions;
}
public static function temp_hack_4_delete($entity_id, $row_id, $c_id)
{
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
$row_entity_id = self::get_row_entity_id_by_row_id($entity_id, $row_id, $c_id);
if ($row_entity_id !== false) {
$val_table = Database::get_main_table(TABLE_SEQUENCE_VALUE);
$sql = "DELETE FROM $val_table WHERE sequence_row_entity_id = $row_entity_id";
$result = Database::query($sql);
if (Database::affected_rows() > 0) {
return Database::affected_rows();
}
}
return false;
}
public static function temp_hack_3_delete($entity_id, $row_id, $c_id, $rule_id)
{
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
$row_entity_id = self::get_row_entity_id_by_row_id($entity_id, $row_id, $c_id);
$seq_array = array();
if ($row_entity_id !== false) {
$seq_table = Database::get_main_table(TABLE_MAIN_SEQUENCE);
$sql = "SELECT * FROM $seq_table WHERE sequence_row_entity_id = $row_entity_id";
$result = Database::query($sql);
while ($temp_seq_array = Database::fetch_array($result, 'ASSOC')){
$seq_array[] = $temp_seq_array;
}
if (is_array($seq_array)) {
foreach ($seq_array as $seq) {
$sql = "SELECT id FROM $seq_table
WHERE sequence_row_entity_id_next = ".$seq['sequence_row_entity_id_next'];
$result = Database::query($sql);
if (Database::num_rows($result) > 1){
$value = self::get_value_by_row_entity_id($seq['sequence_row_entity_id_next']);
foreach ($value as $val) {
if ($seq['is_part'] === 1) {
self::execute_formulas_by_user_id($seq['sequence_row_entity_id_next'], $val['user_id'], $val['session_id'], '', 1, 0, -1, null);
}
if (self::validate_rule_by_row_id($seq['sequence_row_entity_id_next'], $val['user_id'], $val['session_id'], $rule_id) && $val['success'] !== 1) {
self::action_post_success_by_user_id($seq['sequence_row_entity_id_next'], $val['user_id'], $val['session_id'], null);
}
}
} else {
$sql = "UPDATE $seq_table SET sequence_row_entity_id = 0 WHERE sequence_row_entity_id_next = ".$seq['sequence_row_entity_id_next'];
Database::query($sql);
$user = self::get_user_id_by_row_entity_id($seq['sequence_row_entity_id_next']);
foreach ($user as $us) {
self::temp_hack_4_set_aval($seq['sequence_row_entity_id_next'], $us['user_id'], $us['session_id'], 1);
}
}
}
}
$sql = "DELETE FROM $seq_table
WHERE
(sequence_row_entity_id = $row_entity_id AND sequence_row_entity_id_next = 0 ) OR
(sequence_row_entity_id_next = $row_entity_id)";
Database::query($sql);
if (Database::affected_rows() > 0) {
return (!empty($seq_array))? $seq_array : true;
}
}
return false;
}
public static function temp_hack_2_delete($entity_id, $row_id, $c_id)
{
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
$row_entity_id = self::get_row_entity_id_by_row_id($entity_id, $row_id, $c_id);
if ($row_entity_id !== false) {
$row_table = Database::get_main_table(TABLE_SEQUENCE_ROW_ENTITY);
$sql = "DELETE FROM $row_table WHERE id = $row_entity_id";
$result = Database::query($sql);
if (Database::affected_rows() > 0) {
return Database::affected_rows();
}
}
return false;
}
public static function temp_hack_5($entity_id, $row_id, $c_id, $rule_id)
{
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
if (self::temp_hack_3_delete($entity_id, $row_id, $c_id, $rule_id)) {
if (self::temp_hack_4_delete($entity_id, $row_id, $c_id)) {
if (self::temp_hack_2_delete($entity_id, $row_id, $c_id)) {
return true;
}
}
}
return false;
}
public static function temp_hack_4_set_aval($row_entity_id, $user_id, $session_id, $available, $available_end_date = null)
{
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
$available_end_date = Database::escape_string($available_end_date);
$available = intval(Database::escape_string($available));
$val_table = Database::get_main_table(TABLE_SEQUENCE_VALUE);
if ($available == 1) {
$available_date = api_get_utc_datetime();
$available_date = ", available_start_date = '$available_date'";
if (!empty($available_end_date)) {
$available_end_date = api_get_utc_datetime($available_end_date);
$available_date .= "available_end_date = '$available_end_date'";
}
} else {
$available_date = '';
}
$sql = "UPDATE $val_table SET available = $available
$available_date
WHERE sequence_row_entity_id = $row_entity_id
AND user_id = $user_id
AND session_id = $session_id";
Database::query($sql);
}
/**
* @param $user_id
* @return array|bool
*/
public static function get_row_entity_id_by_user_id($user_id)
{
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
$user_id = intval($user_id);
if ($user_id > 0) {
$user_filter = "WHERE user_id = $user_id";
} else {
$user_filter = '';
}
$val_table = Database::get_main_table(TABLE_SEQUENCE_VALUE);
$sql = "SELECT sequence_row_entity_id FROM $val_table $user_filter";
$result = Database::query($sql);
if (Database::num_rows($result) > 0) {
while ($temp = Database::fetch_array($result, 'ASSOC')) {
$row_entity[] = $temp;
}
return $row_entity;
}
return false;
}
/**
* Bool Available for LP
*/
public static function get_state_lp_by_row_entity_id($row_entity_id, $user_id, $session_id)
{
if (self::_debug) {
error_log('Entering '.__FUNCTION__.' in '.__FILE__);
}
$row_entity_id = intval($row_entity_id);
$user_id = intval($user_id);
$session_id = intval($session_id);
$val_table = Database::get_main_table(TABLE_SEQUENCE_VALUE);
if ($row_entity_id > 0 && $user_id > 0 && $session_id >= 0) {
$val_id = self::getValIdByRowEntityId($row_entity_id, $user_id, $session_id);
$sql_seq = "SELECT val.available, val.success FROM $val_table val
WHERE val.id = $val_id
LIMIT 0, 1";
$result_seq = Database::query($sql_seq);
$arr_seq = Database::fetch_array($result_seq, 'ASSOC');
if (intval($arr_seq['available']) === 1) {
if (intval($arr_seq['success']) === 1) {
return "completed";
} else {
return "process";
}
} else {
return "closed";
}
}
return false;
}
}