2015-03-13 09:58:54 -04:00
|
|
|
<?php
|
|
|
|
|
require_once 'classes/model/om/BaseAbeConfiguration.php';
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Skeleton subclass for representing a row from the 'ABE_CONFIGURATION' table.
|
|
|
|
|
*
|
|
|
|
|
*
|
|
|
|
|
*
|
|
|
|
|
* You should add additional methods to this class to meet the
|
|
|
|
|
* application requirements. This class will only be generated as
|
|
|
|
|
* long as it does not already exist in the output directory.
|
|
|
|
|
*
|
|
|
|
|
* @package classes.model
|
|
|
|
|
*/
|
|
|
|
|
class AbeConfiguration extends BaseAbeConfiguration
|
|
|
|
|
{
|
|
|
|
|
|
2016-05-19 14:52:24 -04:00
|
|
|
private $filterThisFields = [
|
|
|
|
|
'ABE_UID',
|
|
|
|
|
'PRO_UID',
|
|
|
|
|
'TAS_UID',
|
|
|
|
|
'ABE_TYPE',
|
|
|
|
|
'ABE_TEMPLATE',
|
|
|
|
|
'ABE_DYN_TYPE',
|
|
|
|
|
'DYN_UID',
|
|
|
|
|
'ABE_EMAIL_FIELD',
|
|
|
|
|
'ABE_ACTION_FIELD',
|
2018-11-14 15:00:10 -04:00
|
|
|
'ABE_ACTION_BODY_FIELD',
|
2016-05-19 14:52:24 -04:00
|
|
|
'ABE_CASE_NOTE_IN_RESPONSE',
|
|
|
|
|
'ABE_FORCE_LOGIN',
|
|
|
|
|
'ABE_CREATE_DATE',
|
|
|
|
|
'ABE_UPDATE_DATE',
|
|
|
|
|
'ABE_SUBJECT_FIELD',
|
|
|
|
|
'ABE_MAILSERVER_OR_MAILCURRENT',
|
2016-11-11 12:57:37 -05:00
|
|
|
'ABE_CUSTOM_GRID',
|
2018-11-14 15:00:10 -04:00
|
|
|
'ABE_EMAIL_SERVER_UID',
|
|
|
|
|
'ABE_EMAIL_SERVER_RECEIVER_UID'
|
2016-05-19 14:52:24 -04:00
|
|
|
];
|
2015-03-13 09:58:54 -04:00
|
|
|
|
|
|
|
|
public function load($abeUid)
|
|
|
|
|
{
|
|
|
|
|
try {
|
|
|
|
|
$abeConfigurationInstance = AbeConfigurationPeer::retrieveByPK($abeUid);
|
|
|
|
|
$fields = $abeConfigurationInstance->toArray(BasePeer::TYPE_FIELDNAME);
|
|
|
|
|
|
|
|
|
|
return $fields;
|
|
|
|
|
} catch (Exception $error) {
|
|
|
|
|
throw $error;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2019-02-13 15:53:21 -04:00
|
|
|
/**
|
|
|
|
|
* Create or update.
|
|
|
|
|
*
|
|
|
|
|
* @param array $data
|
|
|
|
|
* @throws Exception
|
|
|
|
|
*
|
|
|
|
|
* @see Processes->createActionsByEmail()
|
|
|
|
|
* @see ProcessMaker\BusinessModel\ActionsByEmail->saveConfiguration()
|
|
|
|
|
* @see ProcessMaker\BusinessModel\ActionsByEmail->saveConfiguration2()
|
|
|
|
|
* @link https://wiki.processmaker.com/3.3/Actions_by_Email#Configuration
|
|
|
|
|
*/
|
2015-03-13 09:58:54 -04:00
|
|
|
public function createOrUpdate($data)
|
|
|
|
|
{
|
|
|
|
|
foreach ($data as $field => $value) {
|
|
|
|
|
if (!in_array($field, $this->filterThisFields)) {
|
|
|
|
|
unset($data[$field]);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$connection = Propel::getConnection(AbeConfigurationPeer::DATABASE_NAME);
|
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
if (!isset($data['ABE_UID'])) {
|
|
|
|
|
$data['ABE_UID'] = '';
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if ($data['ABE_UID'] == '') {
|
|
|
|
|
$data['ABE_UID'] = G::generateUniqueID();
|
|
|
|
|
$data['ABE_CREATE_DATE'] = date('Y-m-d H:i:s');
|
|
|
|
|
$abeConfigurationInstance = new AbeConfiguration();
|
|
|
|
|
} else {
|
|
|
|
|
$abeConfigurationInstance = AbeConfigurationPeer::retrieveByPK($data['ABE_UID']);
|
|
|
|
|
}
|
2019-02-13 15:53:21 -04:00
|
|
|
//Only the 'FIELD' and 'LINK' types have a DYN_UID,
|
|
|
|
|
//the DYN_UID field is empty when the type is 'CUSTOM'.
|
|
|
|
|
if ($data['ABE_TYPE'] === 'CUSTOM') {
|
|
|
|
|
$data['DYN_UID'] = '';
|
|
|
|
|
}
|
2016-05-19 14:52:24 -04:00
|
|
|
|
2015-11-23 15:15:57 -04:00
|
|
|
if (isset($data['ABE_CUSTOM_GRID'])) {
|
|
|
|
|
$data['ABE_CUSTOM_GRID'] = serialize($data['ABE_CUSTOM_GRID']);
|
|
|
|
|
} else {
|
2016-05-19 14:52:24 -04:00
|
|
|
$data['ABE_CUSTOM_GRID'] = "";
|
2015-11-23 15:15:57 -04:00
|
|
|
}
|
2015-03-13 09:58:54 -04:00
|
|
|
|
|
|
|
|
$data['ABE_UPDATE_DATE'] = date('Y-m-d H:i:s');
|
|
|
|
|
$abeConfigurationInstance->fromArray($data, BasePeer::TYPE_FIELDNAME);
|
|
|
|
|
|
|
|
|
|
if ($abeConfigurationInstance->validate()) {
|
|
|
|
|
$connection->begin();
|
|
|
|
|
$result = $abeConfigurationInstance->save();
|
|
|
|
|
$connection->commit();
|
|
|
|
|
|
|
|
|
|
return $data['ABE_UID'];
|
|
|
|
|
} else {
|
|
|
|
|
$message = '';
|
|
|
|
|
$validationFailures = $abeConfigurationInstance->getValidationFailures();
|
|
|
|
|
|
|
|
|
|
foreach ($validationFailures as $validationFailure) {
|
|
|
|
|
$message .= $validationFailure->getMessage() . '. ';
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
throw (new Exception('Error trying to update: ' . $message));
|
|
|
|
|
}
|
|
|
|
|
} catch (Exception $error) {
|
|
|
|
|
$connection->rollback();
|
|
|
|
|
|
|
|
|
|
throw $error;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function deleteByTasUid($tasUid)
|
|
|
|
|
{
|
|
|
|
|
try {
|
|
|
|
|
$criteria = new Criteria('workflow');
|
|
|
|
|
$criteria->add(AbeConfigurationPeer::TAS_UID, $tasUid);
|
|
|
|
|
AbeConfigurationPeer::doDelete($criteria);
|
|
|
|
|
} catch (Exception $error) {
|
|
|
|
|
throw $error;
|
|
|
|
|
}
|
|
|
|
|
}
|
2018-04-04 09:21:59 -04:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Get configuration from ABE related to the task
|
|
|
|
|
*
|
|
|
|
|
* @param string $proUid
|
|
|
|
|
* @param string $tasUid
|
|
|
|
|
*
|
|
|
|
|
* @return array
|
|
|
|
|
*/
|
|
|
|
|
public function getTaskConfiguration ($proUid, $tasUid)
|
|
|
|
|
{
|
|
|
|
|
$criteria = new Criteria();
|
|
|
|
|
$criteria->addSelectColumn(AbeConfigurationPeer::ABE_UID);
|
|
|
|
|
$criteria->addSelectColumn(AbeConfigurationPeer::PRO_UID);
|
|
|
|
|
$criteria->addSelectColumn(AbeConfigurationPeer::ABE_TYPE);
|
|
|
|
|
$criteria->addSelectColumn(AbeConfigurationPeer::TAS_UID);
|
|
|
|
|
$criteria->addSelectColumn(TaskPeer::TAS_ID);
|
|
|
|
|
$criteria->addSelectColumn(ProcessPeer::PRO_ID);
|
|
|
|
|
$criteria->addSelectColumn(AbeConfigurationPeer::ABE_TEMPLATE);
|
|
|
|
|
$criteria->addSelectColumn(AbeConfigurationPeer::ABE_DYN_TYPE);
|
|
|
|
|
$criteria->addSelectColumn(AbeConfigurationPeer::DYN_UID);
|
|
|
|
|
$criteria->addSelectColumn(AbeConfigurationPeer::ABE_EMAIL_FIELD);
|
|
|
|
|
$criteria->addSelectColumn(AbeConfigurationPeer::ABE_ACTION_FIELD);
|
2018-11-14 15:00:10 -04:00
|
|
|
$criteria->addSelectColumn(AbeConfigurationPeer::ABE_ACTION_BODY_FIELD);
|
2018-04-04 09:21:59 -04:00
|
|
|
$criteria->addSelectColumn(AbeConfigurationPeer::ABE_SUBJECT_FIELD);
|
|
|
|
|
$criteria->addSelectColumn(AbeConfigurationPeer::ABE_MAILSERVER_OR_MAILCURRENT);
|
|
|
|
|
$criteria->addSelectColumn(AbeConfigurationPeer::ABE_CUSTOM_GRID);
|
|
|
|
|
$criteria->addSelectColumn(DynaformPeer::DYN_CONTENT);
|
|
|
|
|
$criteria->addJoin( AbeConfigurationPeer::DYN_UID, DynaformPeer::DYN_UID, Criteria::LEFT_JOIN );
|
|
|
|
|
$criteria->addJoin(AbeConfigurationPeer::TAS_UID, TaskPeer::TAS_UID, Criteria::LEFT_JOIN);
|
|
|
|
|
$criteria->addJoin(AbeConfigurationPeer::PRO_UID, ProcessPeer::PRO_UID, Criteria::LEFT_JOIN);
|
|
|
|
|
$criteria->add(AbeConfigurationPeer::PRO_UID, $proUid);
|
|
|
|
|
$criteria->add(AbeConfigurationPeer::TAS_UID, $tasUid);
|
|
|
|
|
$criteria->setLimit(1);
|
|
|
|
|
$result = AbeConfigurationPeer::doSelectRS($criteria);
|
|
|
|
|
$result->setFetchmode(ResultSet::FETCHMODE_ASSOC);
|
|
|
|
|
$result->next();
|
|
|
|
|
$configuration = $result->getRow();
|
|
|
|
|
|
|
|
|
|
return $configuration;
|
|
|
|
|
}
|
2015-03-13 09:58:54 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// AbeConfiguration
|
|
|
|
|
|