/** * Validates all modified columns of given Dynaform 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 Dynaform $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(Dynaform $obj, $cols = null) { $columns = array(); if ($cols) { $dbMap = Propel::getDatabaseMap(DynaformPeer::DATABASE_NAME); $tableMap = $dbMap->getTable(DynaformPeer::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(DynaformPeer::DYN_TYPE)) $columns[DynaformPeer::DYN_TYPE] = $obj->getDynType(); } return BasePeer::doValidate(DynaformPeer::DATABASE_NAME, DynaformPeer::TABLE_NAME, $columns); }