/** * Create Script-Task for a Project * * @param string $projectUid Unique id of Project * @param array $arrayData Data * * return array Return data of the new Script-Task created */ public function create($projectUid, array $arrayData) { try { //Verify data $process = new \ProcessMaker\BusinessModel\Process(); $validator = new \ProcessMaker\BusinessModel\Validator(); $validator->throwExceptionIfDataIsNotArray($arrayData, "\$arrayData"); $validator->throwExceptionIfDataIsEmpty($arrayData, "\$arrayData"); //Set data $arrayData = array_change_key_case($arrayData, CASE_UPPER); unset($arrayData["SCRTAS_UID"]); unset($arrayData["PRJ_UID"]); //Verify data $process->throwExceptionIfNotExistsProcess($projectUid, $this->arrayFieldNameForException["projectUid"]); $this->throwExceptionIfDataIsInvalid("", $projectUid, $arrayData); //Create $cnn = \Propel::getConnection("workflow"); try { $scriptTask = new \ScriptTask(); $scriptTask->fromArray($arrayData, \BasePeer::TYPE_FIELDNAME); $scriptTaskUid = \ProcessMaker\Util\Common::generateUID(); $scriptTask->setScrtasUid($scriptTaskUid); $scriptTask->setPrjUid($projectUid); if ($scriptTask->validate()) { $cnn->begin(); $result = $scriptTask->save(); $cnn->commit(); //Return return $this->getScriptTask($scriptTaskUid); } else { $msg = ""; foreach ($scriptTask->getValidationFailures() as $validationFailure) { $msg = $msg . ($msg != "" ? "\n" : "") . $validationFailure->getMessage(); } throw new \Exception(\G::LoadTranslation("ID_RECORD_CANNOT_BE_CREATED") . ($msg != "" ? "\n" . $msg : "")); } } catch (\Exception $e) { $cnn->rollback(); throw $e; } } catch (\Exception $e) { throw $e; } }
/** * Validates all modified columns of given ScriptTask object. * If parameter $columns is either a single column name or an array of column names * than only those columns are validated. * * NOTICE: This does not apply to primary or foreign keys for now. * * @param ScriptTask $obj The object to validate. * @param mixed $cols Column name or array of column names. * * @return mixed TRUE if all columns are valid or the error message of the first invalid column. */ public static function doValidate(ScriptTask $obj, $cols = null) { $columns = array(); if ($cols) { $dbMap = Propel::getDatabaseMap(ScriptTaskPeer::DATABASE_NAME); $tableMap = $dbMap->getTable(ScriptTaskPeer::TABLE_NAME); if (!is_array($cols)) { $cols = array($cols); } foreach ($cols as $colName) { if ($tableMap->containsColumn($colName)) { $get = 'get' . $tableMap->getColumn($colName)->getPhpName(); $columns[$colName] = $obj->{$get}(); } } } else { if ($obj->isNew() || $obj->isColumnModified(ScriptTaskPeer::SCRTAS_OBJ_TYPE)) { $columns[ScriptTaskPeer::SCRTAS_OBJ_TYPE] = $obj->getScrtasObjType(); } } return BasePeer::doValidate(ScriptTaskPeer::DATABASE_NAME, ScriptTaskPeer::TABLE_NAME, $columns); }