toArray( BasePeer::TYPE_FIELDNAME ); $this->fromArray( $aFields, BasePeer::TYPE_FIELDNAME ); $this->setNew( false ); return $aFields; } else { throw (new Exception( "The row '$Uid' in table StepSupervisor doesn't exist!" )); } } catch (Exception $oError) { throw ($oError); } } public function Exists ($Uid) { try { $oPro = StepSupervisorPeer::retrieveByPk( $Uid ); if (is_object( $oPro ) && get_class( $oPro ) == 'StepSupervisor') { return true; } else { return false; } } catch (Exception $oError) { throw ($oError); } } /** * Create the step supervisor registry * * @param array $aData * @return boolean * */ public function create ($aData) { $oConnection = Propel::getConnection( StepSupervisorPeer::DATABASE_NAME ); try { if (isset( $aData['STEP_UID'] ) && $aData['STEP_UID'] == '') { unset( $aData['STEP_UID'] ); } if (! isset( $aData['STEP_UID'] )) { $aData['STEP_UID'] = G::generateUniqueID(); } $oStepSupervisor = new StepSupervisor(); $oStepSupervisor->fromArray( $aData, BasePeer::TYPE_FIELDNAME ); if ($oStepSupervisor->validate()) { $oConnection->begin(); $iResult = $oStepSupervisor->save(); $oConnection->commit(); return true; } else { $sMessage = ''; $aValidationFailures = $oStepSupervisor->getValidationFailures(); foreach ($aValidationFailures as $oValidationFailure) { $sMessage .= $oValidationFailure->getMessage() . '
'; } throw (new Exception( 'The registry cannot be created!
' . $sMessage )); } } catch (Exception $oError) { $oConnection->rollback(); throw ($oError); } } /** * Update the step supervisor registry * * @param array $aData * @return integer * */ public function update ($aData) { $oConnection = Propel::getConnection( StepSupervisorPeer::DATABASE_NAME ); try { $oStepSupervisor = StepSupervisorPeer::retrieveByPK( $aData['STEP_UID'] ); if (! is_null( $oStepSupervisor )) { $oStepSupervisor->fromArray( $aData, BasePeer::TYPE_FIELDNAME ); if ($oStepSupervisor->validate()) { $oConnection->begin(); $iResult = $oStepSupervisor->save(); $oConnection->commit(); return $iResult; } else { $sMessage = ''; $aValidationFailures = $oStepSupervisor->getValidationFailures(); foreach ($aValidationFailures as $oValidationFailure) { $sMessage .= $oValidationFailure->getMessage() . '
'; } throw (new Exception( 'The registry cannot be updated!
' . $sMessage )); } } else { throw (new Exception( 'This row doesn\'t exist!' )); } } catch (Exception $oError) { $oConnection->rollback(); throw ($oError); } } /** * Remove the step supervisor registry * * @param string $sStepUID * @return integer * */ public function remove ($sStepUID) { $oConnection = Propel::getConnection( StepSupervisorPeer::DATABASE_NAME ); try { $oConnection->begin(); $this->setStepUid( $sStepUID ); $iResult = $this->delete(); $oConnection->commit(); return $iResult; } catch (Exception $oError) { $oConnection->rollback(); throw ($oError); } } /** * Get the next position for a atep * * @param string $sProcessUID * @return integer * */ public function getNextPosition ($sProcessUID, $sType) { try { $oCriteria = new Criteria( 'workflow' ); $oCriteria->addSelectColumn( '(COUNT(*) + 1) AS POSITION' ); $oCriteria->add( StepSupervisorPeer::PRO_UID, $sProcessUID ); $oCriteria->add( StepSupervisorPeer::STEP_TYPE_OBJ, $sType ); $oDataset = StepSupervisorPeer::doSelectRS( $oCriteria ); $oDataset->setFetchmode( ResultSet::FETCHMODE_ASSOC ); $oDataset->next(); $aRow = $oDataset->getRow(); return (int) $aRow['POSITION']; } catch (Exception $oException) { throw $Exception; } } /** * Get the next position for a atep * * @param string $sProcessUID * @return integer * */ public function getNextPositionAll ($sProcessUID) { try { $oCriteria = new Criteria( 'workflow' ); $oCriteria->addSelectColumn( '(COUNT(*) + 1) AS POSITION' ); $oCriteria->add( StepSupervisorPeer::PRO_UID, $sProcessUID ); $oDataset = StepSupervisorPeer::doSelectRS( $oCriteria ); $oDataset->setFetchmode( ResultSet::FETCHMODE_ASSOC ); $oDataset->next(); $aRow = $oDataset->getRow(); return (int) $aRow['POSITION']; } catch (Exception $oException) { throw $Exception; } } /** * Reorder the steps positions * * @param string $sProcessUID * @param string $iPosition * */ public function reorderPositions ($sProcessUID, $iPosition, $sType) { try { $oCriteria = new Criteria( 'workflow' ); $oCriteria->add( StepSupervisorPeer::PRO_UID, $sProcessUID ); $oCriteria->add( StepSupervisorPeer::STEP_TYPE_OBJ, $sType ); $oCriteria->add( StepSupervisorPeer::STEP_POSITION, $iPosition, '>' ); $oDataset = StepSupervisorPeer::doSelectRS( $oCriteria ); $oDataset->setFetchmode( ResultSet::FETCHMODE_ASSOC ); while ($oDataset->next()) { $aRow = $oDataset->getRow(); $this->update( array ('STEP_UID' => $aRow['STEP_UID'],'PRO_UID' => $aRow['PRO_UID'],'STEP_TYPE_OBJ' => $aRow['STEP_TYPE_OBJ'],'STEP_UID_OBJ' => $aRow['STEP_UID_OBJ'],'STEP_POSITION' => $aRow['STEP_POSITION'] - 1 ) ); } } catch (Exception $oException) { throw $Exception; } } public function removeByObject ($sType, $sObjUid) { try { $oCriteria = new Criteria( 'workflow' ); $oCriteria->add( StepSupervisorPeer::STEP_TYPE_OBJ, $sType ); $oCriteria->add( StepSupervisorPeer::STEP_UID_OBJ, $sObjUid ); StepSupervisorPeer::doDelete( $oCriteria ); } catch (Exception $e) { throw ($e); } } public function loadInfo ($sObjUID) { $oCriteria = new Criteria( 'workflow' ); $oCriteria->add( StepSupervisorPeer::STEP_UID_OBJ, $sObjUID ); $oDataset = StepSupervisorPeer::doSelectRS( $oCriteria ); $oDataset->setFetchmode( ResultSet::FETCHMODE_ASSOC ); $oDataset->next(); $aRow = $oDataset->getRow(); return ($aRow); } /** * verify if a dynaform is assigned some steps * * @param string $proUid the uid of the process * @param string $dynUid the uid of the dynaform * * @return array */ public function verifyDynaformAssigStepSupervisor ($dynUid, $proUid) { $res = array(); $oCriteria = new Criteria(); $oCriteria->addSelectColumn( StepSupervisorPeer::STEP_UID ); $oCriteria->add( StepSupervisorPeer::PRO_UID, $proUid ); $oCriteria->add( StepSupervisorPeer::STEP_UID_OBJ, $dynUid ); $oCriteria->add( StepSupervisorPeer::STEP_TYPE_OBJ, 'DYNAFORM' ); $oDataset = StepSupervisorPeer::doSelectRS( $oCriteria ); $oDataset->setFetchmode( ResultSet::FETCHMODE_ASSOC ); while ($oDataset->next()) { $res[] = $oDataset->getRow(); } return $res; } }