Files
luos/workflow/engine/methods/mails/emailsAjax.php

193 lines
8.5 KiB
PHP
Raw Normal View History

<?php
2017-08-04 09:32:25 -04:00
2021-04-12 20:17:16 +00:00
use ProcessMaker\Model\Application;
use ProcessMaker\Model\Process;
use ProcessMaker\Model\Task;
2017-08-04 09:32:25 -04:00
use ProcessMaker\Plugins\PluginRegistry;
2017-08-07 02:20:05 -04:00
use ProcessMaker\Exception\RBACException;
use ProcessMaker\Util\DateTime;
2017-08-04 09:32:25 -04:00
2017-08-08 13:41:30 -04:00
$req = (isset($_REQUEST['request']) ? $_REQUEST['request'] : '');
2017-08-06 14:46:40 -04:00
/** @var RBAC $RBAC */
global $RBAC;
switch ($RBAC->userCanAccess('PM_LOGIN')) {
case -2:
2017-08-07 02:20:05 -04:00
throw new RBACException('ID_USER_HAVENT_RIGHTS_SYSTEM', -2);
2017-08-06 14:46:40 -04:00
break;
case -1:
2017-08-07 02:20:05 -04:00
throw new RBACException('ID_USER_HAVENT_RIGHTS_PAGE', -1);
2017-08-06 14:46:40 -04:00
break;
}
$RBAC->allows(basename(__FILE__), $req);
2017-08-08 13:41:30 -04:00
switch ($req) {
case 'MessageList':
2017-08-08 13:41:30 -04:00
$start = (isset($_REQUEST['start'])) ? $_REQUEST['start'] : '0';
$limit = (isset($_REQUEST['limit'])) ? $_REQUEST['limit'] : '25';
2018-04-04 09:21:59 -04:00
$proId = (isset($_REQUEST['process'])) ? $_REQUEST['process'] : '';
2017-08-08 13:41:30 -04:00
$eventype = (isset($_REQUEST['type'])) ? $_REQUEST['type'] : '';
2018-04-04 09:21:59 -04:00
$msgStatusId = (isset($_REQUEST['status'])) ? $_REQUEST['status'] : '';
2017-08-08 13:41:30 -04:00
$sort = isset($_REQUEST['sort']) ? $_REQUEST['sort'] : '';
$dir = isset($_REQUEST['dir']) ? $_REQUEST['dir'] : 'ASC';
$dateFrom = isset($_POST["dateFrom"]) ? substr($_POST["dateFrom"], 0, 10) : "";
$dateTo = isset($_POST["dateTo"]) ? substr($_POST["dateTo"], 0, 10) : "";
$filterBy = (isset($_REQUEST['filterBy'])) ? $_REQUEST['filterBy'] : 'ALL';
$criteria = new Criteria();
2021-04-12 20:17:16 +00:00
$criteria->addSelectColumn(AppMessagePeer::APP_MSG_ID);
$criteria->addSelectColumn(AppMessagePeer::APP_UID);
$criteria->addSelectColumn(AppMessagePeer::DEL_INDEX);
$criteria->addSelectColumn(AppMessagePeer::APP_MSG_TYPE);
$criteria->addSelectColumn(AppMessagePeer::APP_MSG_SUBJECT);
$criteria->addSelectColumn(AppMessagePeer::APP_MSG_FROM);
$criteria->addSelectColumn(AppMessagePeer::APP_MSG_TO);
$criteria->addSelectColumn(AppMessagePeer::APP_MSG_BODY);
$criteria->addSelectColumn(AppMessagePeer::APP_MSG_STATUS);
$criteria->addSelectColumn(AppMessagePeer::APP_MSG_DATE);
$criteria->addSelectColumn(AppMessagePeer::APP_MSG_SEND_DATE);
$criteria->addSelectColumn(AppMessagePeer::APP_MSG_SHOW_MESSAGE);
$criteria->addSelectColumn(AppMessagePeer::APP_MSG_ERROR);
2021-04-12 20:17:16 +00:00
$criteria->addSelectColumn(AppMessagePeer::APP_NUMBER);
$criteria->addSelectColumn(AppMessagePeer::PRO_ID);
$criteria->addSelectColumn(AppMessagePeer::TAS_ID);
2018-04-04 09:21:59 -04:00
//Status can be: All, Participated, Pending, Failed
if (!empty($msgStatusId)) {
$criteria->add(AppMessagePeer::APP_MSG_STATUS_ID, $msgStatusId);
}
2017-11-06 14:27:06 -04:00
//Process uid
2018-04-04 09:21:59 -04:00
if (!empty($proId)) {
$criteria->add(AppMessagePeer::PRO_ID, $proId);
}
2017-11-06 14:27:06 -04:00
//Filter by can be: All, Cases, Test
2016-08-03 13:15:16 -04:00
switch ($filterBy) {
2018-04-04 09:21:59 -04:00
case 'CASES': //TRIGGER and DERIVATION
$criteria->add(AppMessagePeer::APP_MSG_TYPE_ID, [AppMessage::TYPE_TRIGGER, AppMessage::TYPE_DERIVATION], Criteria::IN);
2016-08-03 13:15:16 -04:00
break;
case 'TEST':
2018-04-04 09:21:59 -04:00
$criteria->add(AppMessagePeer::APP_MSG_TYPE_ID, AppMessage::TYPE_TEST, Criteria::EQUAL);
2016-08-03 13:15:16 -04:00
break;
case 'EXTERNAL-REGISTRATION':
2018-04-04 09:21:59 -04:00
$criteria->add(AppMessagePeer::APP_MSG_TYPE_ID, AppMessage::TYPE_EXTERNAL_REGISTRATION, Criteria::EQUAL);
2016-08-03 13:15:16 -04:00
break;
default:
2018-04-04 09:21:59 -04:00
//Review the External Registration
$pluginRegistry = PluginRegistry::loadSingleton();
if (!$pluginRegistry->isEnable('externalRegistration')) {
$criteria->add(AppMessagePeer::APP_MSG_TYPE_ID, AppMessage::TYPE_EXTERNAL_REGISTRATION, Criteria::NOT_EQUAL);
2016-08-03 13:15:16 -04:00
}
break;
}
2017-11-06 14:27:06 -04:00
//Date from and to
if (!empty($dateFrom) && !empty($dateTo)) {
2018-03-22 12:04:14 -04:00
$dateTo = $dateTo . " 23:59:59";
2017-11-06 14:27:06 -04:00
$criteria->add($criteria->getNewCriterion(AppMessagePeer::APP_MSG_DATE, $dateFrom, Criteria::GREATER_EQUAL)->addAnd($criteria->getNewCriterion(AppMessagePeer::APP_MSG_DATE, $dateTo, Criteria::LESS_EQUAL)));
} else {
if (!empty($dateFrom)) {
2017-08-08 13:41:30 -04:00
$criteria->add(AppMessagePeer::APP_MSG_DATE, $dateFrom, Criteria::GREATER_EQUAL);
}
2017-11-06 14:27:06 -04:00
if (!empty($dateTo)) {
$dateTo = $dateTo . " 23:59:59";
$criteria->add(AppMessagePeer::APP_MSG_DATE, $dateTo, Criteria::LESS_EQUAL);
}
}
2017-11-06 14:27:06 -04:00
//Number records total
$criteriaCount = clone $criteria;
$criteriaCount->clearSelectColumns();
$criteriaCount->addSelectColumn('COUNT(' . AppMessagePeer::APP_MSG_UID . ') AS NUM_REC');
$rsCriteriaCount = AppMessagePeer::doSelectRS($criteriaCount);
$rsCriteriaCount->setFetchmode(ResultSet::FETCHMODE_ASSOC);
$resultCount = $rsCriteriaCount->next();
$rowCount = $rsCriteriaCount->getRow();
$totalCount = (int)($rowCount['NUM_REC']);
if (!empty($sort)) {
2017-08-08 13:41:30 -04:00
if (!in_array($sort, AppMessagePeer::getFieldNames(BasePeer::TYPE_FIELDNAME))) {
throw new Exception(G::LoadTranslation('ID_INVALID_VALUE_FOR', array('$sort')));
}
if ($dir == 'ASC') {
$criteria->addAscendingOrderByColumn($sort);
} else {
$criteria->addDescendingOrderByColumn($sort);
}
} else {
2021-04-12 20:45:50 +00:00
$oCriteria->addDescendingOrderByColumn(AppMessagePeer::APP_MSG_DATE);
}
2017-11-06 14:27:06 -04:00
if (!empty($limit)) {
$criteria->setLimit($limit);
$criteria->setOffset($start);
}
2016-08-03 13:15:16 -04:00
$result = AppMessagePeer::doSelectRS($criteria);
$result->setFetchmode(ResultSet::FETCHMODE_ASSOC);
$data = Array();
$dataPro = array();
$index = 1;
$content = new Content();
$tasTitleDefault = G::LoadTranslation('ID_TASK_NOT_RELATED');
2021-04-12 20:17:16 +00:00
$cases = [];
$processes = [];
$tasks = [];
2017-08-08 13:41:30 -04:00
while ($result->next()) {
$row = $result->getRow();
2017-08-08 13:41:30 -04:00
$row['APP_MSG_STATUS'] = ucfirst($row['APP_MSG_STATUS']);
$row['APP_MSG_DATE'] = DateTime::convertUtcToTimeZone($row['APP_MSG_DATE']);
2021-04-12 20:17:16 +00:00
// Complete data with information from another tables
if ($row['APP_NUMBER'] > 0) {
if (!isset($cases[$row['APP_NUMBER']])) {
$record = Application::query()->select(['APP_TITLE'])->where('APP_NUMBER', '=', $row['APP_NUMBER'])->get()->toArray();
if (!empty($record[0]['APP_TITLE'])) {
$cases[$row['APP_NUMBER']] = $record[0]['APP_TITLE'];
}
}
$row['APP_TITLE'] = $cases[$row['APP_NUMBER']] ?? '';
}
if ($row['PRO_ID'] > 0) {
if (!isset($processes[$row['PRO_ID']])) {
$record = Process::query()->select(['PRO_TITLE'])->where('PRO_ID', '=', $row['PRO_ID'])->get()->toArray();
if (!empty($record[0]['PRO_TITLE'])) {
$processes[$row['PRO_ID']] = $record[0]['PRO_TITLE'];
}
}
$row['PRO_TITLE'] = $processes[$row['PRO_ID']] ?? '';
}
if ($row['TAS_ID'] > 0) {
if (!isset($tasks[$row['TAS_ID']])) {
$record = Task::query()->select(['TAS_TITLE'])->where('TAS_ID', '=', $row['TAS_ID'])->get()->toArray();
if (!empty($record[0]['TAS_TITLE'])) {
$tasks[$row['TAS_ID']] = $record[0]['TAS_TITLE'];
}
}
$row['TAS_TITLE'] = $tasks[$row['TAS_ID']] ?? '';
}
2016-08-03 13:15:16 -04:00
switch ($filterBy) {
2017-08-08 13:41:30 -04:00
case 'CASES':
if ($row['DEL_INDEX'] != 0) {
$index = $row['DEL_INDEX'];
}
if ($row['DEL_INDEX'] == 0) {
$row['TAS_TITLE'] = $tasTitleDefault;
}
break;
}
2016-08-03 13:15:16 -04:00
$data[] = $row;
}
2017-11-06 14:27:06 -04:00
$response = [];
$response['totalCount'] = $totalCount;
2017-08-08 13:41:30 -04:00
$response['data'] = $data;
die(G::json_encode($response));
break;
case 'updateStatusMessage':
2018-04-04 09:21:59 -04:00
if (isset($_REQUEST['APP_MSG_UID']) && isset($_REQUEST['APP_MSG_STATUS_ID'])) {
$message = new AppMessage();
2018-04-04 09:21:59 -04:00
$result = $message->updateStatus($_REQUEST['APP_MSG_UID'], $_REQUEST['APP_MSG_STATUS_ID']);
}
break;
}