325 lines
11 KiB
PHP
325 lines
11 KiB
PHP
<?php
|
|
/**
|
|
* StepTrigger.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.
|
|
*
|
|
*/
|
|
|
|
require_once 'classes/model/om/BaseStepTrigger.php';
|
|
|
|
|
|
/**
|
|
* Skeleton subclass for representing a row from the 'STEP_TRIGGER' 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 StepTrigger extends BaseStepTrigger {
|
|
function create($aData)
|
|
{
|
|
$con = Propel::getConnection(StepTriggerPeer::DATABASE_NAME);
|
|
try
|
|
{
|
|
//delete old StepTrigger Rows, because is not safe insert previous verify old rows.
|
|
$criteria = new Criteria();
|
|
$criteria->add(StepTriggerPeer::STEP_UID, $aData['STEP_UID'] );
|
|
$criteria->add(StepTriggerPeer::TAS_UID, $aData['TAS_UID'] );
|
|
$criteria->add(StepTriggerPeer::TRI_UID, $aData['TRI_UID'] );
|
|
$criteria->add(StepTriggerPeer::ST_TYPE, $aData['ST_TYPE'] );
|
|
$objects = StepTriggerPeer::doSelect($criteria, $con);
|
|
$con->begin();
|
|
foreach($objects as $row) {
|
|
$this->remove($row->getStepUid(), $row->getTasUid(), $row->getTriUid(), $row->getStType() );
|
|
}
|
|
$con->commit();
|
|
|
|
$con->begin();
|
|
$this->setStepUid($aData['STEP_UID']);
|
|
$this->setTasUid($aData['TAS_UID']);
|
|
$this->setTriUid($aData['TRI_UID']);
|
|
$this->setStType($aData['ST_TYPE']);
|
|
$this->setStCondition("");
|
|
$this->setStPosition("");
|
|
if($this->validate())
|
|
{
|
|
$result=$this->save();
|
|
$con->commit();
|
|
return $result;
|
|
}
|
|
else
|
|
{
|
|
$con->rollback();
|
|
throw( new Exception("Failed Validation in class ".get_class($this)."."));
|
|
}
|
|
}
|
|
catch(Exception $e)
|
|
{
|
|
$con->rollback();
|
|
throw($e);
|
|
}
|
|
}
|
|
public function load($StepUid, $TasUid, $TriUid, $StType)
|
|
{
|
|
try {
|
|
$oRow = StepTriggerPeer::retrieveByPK( $StepUid, $TasUid, $TriUid, $StType );
|
|
if (!is_null($oRow))
|
|
{
|
|
$aFields = $oRow->toArray(BasePeer::TYPE_FIELDNAME);
|
|
$this->fromArray($aFields,BasePeer::TYPE_FIELDNAME);
|
|
$this->setNew(false);
|
|
return $aFields;
|
|
}
|
|
else {
|
|
throw(new Exception( "The row '$StepUid, $TasUid, $TriUid, $StType' in table StepTrigger doesn't exist!" ));
|
|
}
|
|
}
|
|
catch (Exception $oError) {
|
|
throw($oError);
|
|
}
|
|
}
|
|
function update($fields)
|
|
{
|
|
$con = Propel::getConnection(StepTriggerPeer::DATABASE_NAME);
|
|
try
|
|
{
|
|
$con->begin();
|
|
$this->load($fields['STEP_UID'],$fields['TAS_UID'],$fields['TRI_UID'],$fields['ST_TYPE']);
|
|
$this->fromArray($fields,BasePeer::TYPE_FIELDNAME);
|
|
if($this->validate())
|
|
{
|
|
$result=$this->save();
|
|
$con->commit();
|
|
return $result;
|
|
}
|
|
else
|
|
{
|
|
$con->rollback();
|
|
throw(new Exception("Failed Validation in class ".get_class($this)."."));
|
|
}
|
|
}
|
|
catch(Exception $e)
|
|
{
|
|
$con->rollback();
|
|
throw($e);
|
|
}
|
|
}
|
|
function remove($StepUid, $TasUid, $TriUid, $StType)
|
|
{
|
|
$oConnection = Propel::getConnection(StepTriggerPeer::DATABASE_NAME);
|
|
try {
|
|
$oStepTrigger = StepTriggerPeer::retrieveByPK($StepUid, $TasUid, $TriUid, $StType);
|
|
if (!is_null($oStepTrigger))
|
|
{
|
|
$oConnection->begin();
|
|
$iResult = $oStepTrigger->delete();
|
|
$oConnection->commit();
|
|
return $iResult;
|
|
}
|
|
else {
|
|
throw(new Exception( "The row '$StepUid, $TasUid, $TriUid, $StType' in table StepTrigger doesn't exist!" ));
|
|
}
|
|
}
|
|
catch (Exception $oError) {
|
|
$oConnection->rollback();
|
|
throw($oError);
|
|
}
|
|
}
|
|
|
|
function stepTriggerExists ($StepUid, $TasUid, $TriUid, $StType) {
|
|
$con = Propel::getConnection(StepTriggerPeer::DATABASE_NAME);
|
|
try {
|
|
$oObj = StepTriggerPeer::retrieveByPk($StepUid, $TasUid, $TriUid, $StType);
|
|
if ( get_class ($oObj) == 'StepTrigger' ) {
|
|
return true;
|
|
}
|
|
else {
|
|
return false;
|
|
}
|
|
}
|
|
catch (Exception $oError) {
|
|
throw($oError);
|
|
}
|
|
}
|
|
|
|
function removeTrigger($TriUid)
|
|
{
|
|
$con = Propel::getConnection(StepTriggerPeer::DATABASE_NAME);
|
|
try
|
|
{
|
|
$criteria = new Criteria();
|
|
//$criteria->add(StepTriggerPeer::STEP_UID, $step_uid);
|
|
//$criteria->add(StepTriggerPeer::TAS_UID, $tas_uid);
|
|
$criteria->add(StepTriggerPeer::TRI_UID, $TriUid);
|
|
//$criteria->add(StepTriggerPeer::ST_TYPE, $st_type);
|
|
$objects = StepTriggerPeer::doSelect($criteria, $con);
|
|
$con->begin();
|
|
foreach($objects as $v)
|
|
{
|
|
$this->remove($v->getStepUid,$v->getTasUid,$v->getTriUid,$v->getStType);
|
|
}
|
|
$con->commit();
|
|
return count($objects);
|
|
}
|
|
catch(Exception $e)
|
|
{
|
|
$con->rollback();
|
|
throw($e);
|
|
}
|
|
}
|
|
function getNextPosition($sStepUID, $sType) {
|
|
try {
|
|
$oCriteria = new Criteria('workflow');
|
|
$oCriteria->addSelectColumn('(COUNT(*) + 1) AS POSITION');
|
|
$oCriteria->add(StepTriggerPeer::STEP_UID, $sStepUID);
|
|
$oCriteria->add(StepTriggerPeer::ST_TYPE, $sType);
|
|
$oDataset = StepTriggerPeer::doSelectRS($oCriteria);
|
|
$oDataset->setFetchmode(ResultSet::FETCHMODE_ASSOC);
|
|
$oDataset->next();
|
|
$aRow = $oDataset->getRow();
|
|
return (int)$aRow['POSITION'];
|
|
}
|
|
catch (Exception $oException) {
|
|
throw $oException;
|
|
}
|
|
}
|
|
function reOrder($sStepUID, $sTaskUID, $sType, $iPosition) {
|
|
try {
|
|
$oCriteria = new Criteria('workflow');
|
|
$oCriteria->add(StepTriggerPeer::STEP_UID, $sStepUID);
|
|
$oCriteria->add(StepTriggerPeer::TAS_UID, $sTaskUID);
|
|
$oCriteria->add(StepTriggerPeer::ST_TYPE, $sType);
|
|
$oCriteria->add(StepTriggerPeer::ST_POSITION, $iPosition, '>');
|
|
$oDataset = StepTriggerPeer::doSelectRS($oCriteria);
|
|
$oDataset->setFetchmode(ResultSet::FETCHMODE_ASSOC);
|
|
$oDataset->next();
|
|
while ($aRow = $oDataset->getRow()) {
|
|
$oStep = StepTriggerPeer::retrieveByPK($aRow['STEP_UID'], $aRow['TAS_UID'], $aRow['TRI_UID'], $aRow['ST_TYPE']);
|
|
$oStep->setStPosition(($aRow['ST_POSITION']) - 1);
|
|
$oStep->save();
|
|
$oDataset->next();
|
|
}
|
|
}
|
|
catch (Exception $oException) {
|
|
throw $oException;
|
|
}
|
|
}
|
|
function up($sStepUID = '', $sTaskUID = '', $sTriggerUID = '', $sType = '', $iPosition = 0) {
|
|
try {
|
|
if ($iPosition > 1) {
|
|
$oCriteria1 = new Criteria('workflow');
|
|
$oCriteria1->add(StepTriggerPeer::ST_POSITION, $iPosition);
|
|
$oCriteria2 = new Criteria('workflow');
|
|
$oCriteria2->add(StepTriggerPeer::STEP_UID, $sStepUID);
|
|
$oCriteria2->add(StepTriggerPeer::TAS_UID, $sTaskUID);
|
|
$oCriteria2->add(StepTriggerPeer::ST_TYPE, $sType);
|
|
$oCriteria2->add(StepTriggerPeer::ST_POSITION, ($iPosition - 1));
|
|
BasePeer::doUpdate($oCriteria2, $oCriteria1, Propel::getConnection('workflow'));
|
|
$oCriteria1 = new Criteria('workflow');
|
|
$oCriteria1->add(StepTriggerPeer::ST_POSITION, ($iPosition - 1));
|
|
$oCriteria2 = new Criteria('workflow');
|
|
$oCriteria2->add(StepTriggerPeer::STEP_UID, $sStepUID);
|
|
$oCriteria2->add(StepTriggerPeer::TAS_UID, $sTaskUID);
|
|
$oCriteria2->add(StepTriggerPeer::TRI_UID, $sTriggerUID);
|
|
$oCriteria2->add(StepTriggerPeer::ST_TYPE, $sType);
|
|
BasePeer::doUpdate($oCriteria2, $oCriteria1, Propel::getConnection('workflow'));
|
|
}
|
|
}
|
|
catch (Exception $oException) {
|
|
throw $oException;
|
|
}
|
|
}
|
|
|
|
function down($sStepUID = '', $sTaskUID = '', $sTriggerUID = '', $sType = '', $iPosition = 0) {
|
|
try {
|
|
$oCriteria = new Criteria('workflow');
|
|
$oCriteria->addSelectColumn('COUNT(*) AS MAX_POSITION');
|
|
$oCriteria->add(StepTriggerPeer::STEP_UID, $sStepUID);
|
|
$oCriteria->add(StepTriggerPeer::TAS_UID, $sTaskUID);
|
|
$oCriteria->add(StepTriggerPeer::ST_TYPE, $sType);
|
|
$oDataset = StepTriggerPeer::doSelectRS($oCriteria);
|
|
$oDataset->setFetchmode(ResultSet::FETCHMODE_ASSOC);
|
|
$oDataset->next();
|
|
$aRow = $oDataset->getRow();
|
|
if ($iPosition < (int)$aRow['MAX_POSITION']) {
|
|
$oCriteria1 = new Criteria('workflow');
|
|
$oCriteria1->add(StepTriggerPeer::ST_POSITION, $iPosition);
|
|
$oCriteria2 = new Criteria('workflow');
|
|
$oCriteria2->add(StepTriggerPeer::STEP_UID, $sStepUID);
|
|
$oCriteria2->add(StepTriggerPeer::TAS_UID, $sTaskUID);
|
|
$oCriteria2->add(StepTriggerPeer::ST_TYPE, $sType);
|
|
$oCriteria2->add(StepTriggerPeer::ST_POSITION, ($iPosition + 1));
|
|
BasePeer::doUpdate($oCriteria2, $oCriteria1, Propel::getConnection('workflow'));
|
|
$oCriteria1 = new Criteria('workflow');
|
|
$oCriteria1->add(StepTriggerPeer::ST_POSITION, ($iPosition + 1));
|
|
$oCriteria2 = new Criteria('workflow');
|
|
$oCriteria2->add(StepTriggerPeer::STEP_UID, $sStepUID);
|
|
$oCriteria2->add(StepTriggerPeer::TAS_UID, $sTaskUID);
|
|
$oCriteria2->add(StepTriggerPeer::TRI_UID, $sTriggerUID);
|
|
$oCriteria2->add(StepTriggerPeer::ST_TYPE, $sType);
|
|
BasePeer::doUpdate($oCriteria2, $oCriteria1, Propel::getConnection('workflow'));
|
|
}
|
|
}
|
|
catch (Exception $oException) {
|
|
throw $oException;
|
|
}
|
|
}
|
|
|
|
function createRow($aData)
|
|
{
|
|
$con = Propel::getConnection(StepTriggerPeer::DATABASE_NAME);
|
|
try
|
|
{
|
|
$con->begin();
|
|
$this->fromArray($aData,BasePeer::TYPE_FIELDNAME);
|
|
if($this->validate())
|
|
{
|
|
$this->setStepUid($aData['STEP_UID']);
|
|
$this->setTasUid($aData['TAS_UID']);
|
|
$this->setTriUid($aData['TRI_UID']);
|
|
$this->setStType($aData['ST_TYPE']);
|
|
$this->setStCondition($aData['ST_CONDITION']);
|
|
$this->setStPosition($aData['ST_POSITION']);
|
|
|
|
$result=$this->save();
|
|
$con->commit();
|
|
return $result;
|
|
}
|
|
else
|
|
{
|
|
$con->rollback();
|
|
throw( new Exception("Failed Validation in class ".get_class($this)."."));
|
|
$e->aValidationFailures=$this->getValidationFailures();
|
|
throw($e);
|
|
}
|
|
}
|
|
catch(Exception $e)
|
|
{
|
|
$con->rollback();
|
|
throw($e);
|
|
}
|
|
}
|
|
} // StepTrigger
|