Files
luos/workflow/engine/methods/dynaforms/dynaforms_PagedTableAjax.php
Victor Saisa Lopez 6d9858d6d0 HOR-1738 "Change folder permissions in ProcessMaker" SOLVED
Issue:
    Change folder permissions in ProcessMaker
Cause:
    Nuevo requerimiento
Solution:
    Se cambio los permisos de los files and directories
2016-08-30 13:03:35 -04:00

141 lines
5.2 KiB
PHP

<?php
/**
* dynaforms_PagedTableAjax.php
*
* ProcessMaker Open Source Edition
* Copyright (C) 2004 - 2008 Colosa Inc.23
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
* For more information, contact Colosa Inc, 2566 Le Jeune Rd.,
* Coral Gables, FL, 33134, USA, or email info@colosa.com.
*/
if (($RBAC_Response = $RBAC->userCanAccess( "PM_FACTORY" )) != 1) {
return $RBAC_Response;
}
function pagedTable_BeforeQuery (&$ntable)
{
$file = G::decrypt( $ntable->xmlForm->values['URL'], URL_KEY );
/* Start Block: Defines the virtual XMLDB*/
G::LoadClass( 'xmlDb' );
define( 'DB_XMLDB_HOST', PATH_DYNAFORM . $file . '.xml' );
define( 'DB_XMLDB_USER', '' );
define( 'DB_XMLDB_PASS', '' );
define( 'DB_XMLDB_NAME', '' );
define( 'DB_XMLDB_TYPE', 'myxml' );
/* End Block*/
}
require_once (PATH_GULLIVER_HOME . 'methods/pagedTableAjax.php');
die();
G::LoadSystem( 'pagedTable' );
G::LoadInclude( 'ajax' );
$id = get_ajax_value( 'ptID' );
$ntable = unserialize(base64_decode($_SESSION['pagedTable[' . $id . ']']));
$page = get_ajax_value( 'page' );
$function = get_ajax_value( 'function' );
if (isset( $ntable->filterForm_Id ) && ($ntable->filterForm_Id !== '')) {
$filterForm = new filterForm( G::getUIDName( $ntable->filterForm_Id ) );
$filterForm->values = $_SESSION[$filterForm->id];
parse_str( urldecode( get_ajax_value( 'filter' ) ), $newValues );
if (isset( $newValues['form'] )) {
$filterForm->setValues( $newValues['form'] );
$filter = array ();
foreach ($filterForm->fields as $fieldName => $field) {
if (($field->dataCompareField !== '') && (isset( $newValues['form'][$fieldName] ))) {
$filter[$field->dataCompareField] = $filterForm->values[$fieldName];
}
$ntable->filterType[$field->dataCompareField] = $field->dataCompareType;
}
$ntable->filter = $filter; //G::http_build_query($filter);
}
}
$fastSearch = get_ajax_value( 'fastSearch' );
if (isset( $fastSearch )) {
$ntable->fastSearch = urldecode( $fastSearch );
}
$orderBy = get_ajax_value( 'order' );
if (isset( $orderBy )) {
$orderBy = urldecode( $orderBy );
$ntable->orderBy = $orderBy;
}
if (isset( $page ) && $page !== '') {
$ntable->currentPage = (int) $page;
}
$file = G::decrypt( $ntable->xmlForm->values['URL'], URL_KEY );
/* Start Block: Defines the virtual XMLDB*/
G::LoadClass( 'xmlDb' );
define( 'DB_XMLDB_HOST', PATH_DYNAFORM . $file . '.xml' );
define( 'DB_XMLDB_USER', '' );
define( 'DB_XMLDB_PASS', '' );
define( 'DB_XMLDB_NAME', '' );
define( 'DB_XMLDB_TYPE', 'myxml' );
/* End Block*/
$ntable->prepareQuery();
switch ($function) {
case "showHideField":
$field = get_ajax_value( 'field' );
$ntable->style[$field]['showInTable'] = ($ntable->style[$field]['showInTable'] === '0') ? '1' : '0';
break;
case "paint":
break;
case "delete":
$ntable->prepareQuery();
parse_str( get_ajax_value( 'field' ), $field );
foreach ($field as $key => $value) {
$field[$key] = urldecode( $value );
}
$ntable->ses->execute( $ntable->replaceDataField( $ntable->sqlDelete, $field ) );
break;
case "update":
$ntable->prepareQuery();
parse_str( get_ajax_value( 'field' ), $field );
foreach ($field as $key => $value) {
$field[$key] = urldecode( $value );
}
parse_str( get_ajax_value( 'update' ), $fieldup );
foreach ($fieldup as $key => $value) {
$field['new' . $key] = urldecode( $value ); //join
}
$ntable->ses->execute( $ntable->replaceDataField( $ntable->sqlUpdate, $field ) );
break;
case "insert":
$ntable->prepareQuery();
parse_str( get_ajax_value( 'field' ), $field );
foreach ($field as $key => $value) {
$field[$key] = urldecode( $value );
}
$ntable->ses->execute( $ntable->replaceDataField( $ntable->sqlInsert, $field ) );
break;
case "printForm":
parse_str( get_ajax_value( 'field' ), $field );
parse_str( get_ajax_value( 'field' ), $field );
foreach ($field as $key => $value) {
$field[$key] = urldecode( $value );
}
$ntable->printForm( get_ajax_value( 'filename' ), $field );
return;
}
$ntable->renderTable( 'content' );
G::LoadClass( 'configuration' );
$dbc = new DBConnection();
$conf = new Configuration( $dbc, $ntable );
$conf->setConfig( $ntable->__Configuration, $ntable, $conf->aConfig );
$conf->saveConfig( 'pagedTable', $ntable->__OBJ_UID, '', $_SESSION['USER_LOGGED'], '' );