vtenext/modules/PickList/SaveAssignedValues.php
2021-04-28 20:10:26 +02:00

66 lines
2.1 KiB
PHP

<?php
/*************************************
* SPDX-FileCopyrightText: 2009-2020 Vtenext S.r.l. <info@vtenext.com>
* SPDX-License-Identifier: AGPL-3.0-only
************************************/
require_once 'modules/PickList/PickListUtils.php';
global $adb, $table_prefix;
$moduleName = vtlib_purify($_REQUEST['moduleName']);
$tableName = vtlib_purify($_REQUEST['fieldname']);
$roleid = vtlib_purify($_REQUEST['roleid']);
$values = vtlib_purify($_REQUEST['values']);
$otherRoles = vtlib_purify($_REQUEST['otherRoles']);
if(empty($tableName)){
echo "Table name is empty";
exit;
}
$values = Zend_Json::decode($values);
$sql = 'SELECT picklistid FROM '.$table_prefix.'_picklist WHERE name = ?';
$result = $adb->pquery($sql, array($tableName));
if($adb->num_rows($result) > 0){
$picklistid = $adb->query_result_no_html($result, 0, "picklistid");
}
if(!empty($roleid)){
assignValues($picklistid, $roleid, $values, $tableName);
}
$otherRoles = Zend_Json::decode($otherRoles);
if(!empty($otherRoles)){
foreach($otherRoles as $role){
assignValues($picklistid, $role, $values, $tableName);
}
}
echo "SUCCESS";
function assignValues($picklistid, $roleid, $values, $tableName){
global $adb,$table_prefix, $metaLogs; // crmv@49398
$count = count($values);
//delete older values
$sql = 'DELETE FROM '.$table_prefix.'_role2picklist WHERE roleid=? AND picklistid=?';
$adb->pquery($sql, array($roleid,$picklistid));
//insert the new values
for($i=0;$i<$count;$i++){
$pickVal = html_entity_decode($values[$i]); //crmv@30453
$tableName = $adb->sql_escape_string($tableName);
$sql = "SELECT * FROM ".$table_prefix."_$tableName WHERE $tableName=?";
$result = $adb->pquery($sql, array($pickVal));
if($adb->num_rows($result) > 0){
$picklistvalueid = $adb->query_result($result, 0, "picklist_valueid");
$sortid = $i+1;
$sql = 'INSERT INTO '.$table_prefix.'_role2picklist VALUES (?,?,?,?)';
$adb->pquery($sql, array($roleid, $picklistvalueid, $picklistid, $sortid));
}
}
if ($metaLogs) $metaLogs->log($metaLogs::OPERATION_EDITROLE, 0, array('roleid'=>$roleid)); // crmv@49398
}