/** * This function performs the validation work for complex object models. * * In addition to checking the current object, all related objects will * also be validated. If all pass then <code>true</code> is returned; otherwise * an aggreagated array of ValidationFailed objects will be returned. * * @param array $columns Array of column names to validate. * @return mixed <code>true</code> if all validations pass; array of <code>ValidationFailed</code> objets otherwise. */ protected function doValidate($columns = null) { if (!$this->alreadyInValidation) { $this->alreadyInValidation = true; $retval = null; $failureMap = array(); // We call the validate method on the following object(s) if they // were passed to this object by their coresponding set // method. This object relates to these object(s) by a // foreign key reference. if ($this->aGrupoTrabajoSc !== null) { if (!$this->aGrupoTrabajoSc->validate($columns)) { $failureMap = array_merge($failureMap, $this->aGrupoTrabajoSc->getValidationFailures()); } } if ($this->aUserSc !== null) { if (!$this->aUserSc->validate($columns)) { $failureMap = array_merge($failureMap, $this->aUserSc->getValidationFailures()); } } if (($retval = SolicitudGrupoTrabajoScPeer::doValidate($this, $columns)) !== true) { $failureMap = array_merge($failureMap, $retval); } $this->alreadyInValidation = false; } return !empty($failureMap) ? $failureMap : true; }
/** * This function performs the validation work for complex object models. * * In addition to checking the current object, all related objects will * also be validated. If all pass then <code>true</code> is returned; otherwise * an aggreagated array of ValidationFailed objects will be returned. * * @param array $columns Array of column names to validate. * @return mixed <code>true</code> if all validations pass; array of <code>ValidationFailed</code> objets otherwise. */ protected function doValidate($columns = null) { if (!$this->alreadyInValidation) { $this->alreadyInValidation = true; $retval = null; $failureMap = array(); // We call the validate method on the following object(s) if they // were passed to this object by their coresponding set // method. This object relates to these object(s) by a // foreign key reference. if ($this->aUserScRelatedByUserId !== null) { if (!$this->aUserScRelatedByUserId->validate($columns)) { $failureMap = array_merge($failureMap, $this->aUserScRelatedByUserId->getValidationFailures()); } } if ($this->aGrupoTrabajoSc !== null) { if (!$this->aGrupoTrabajoSc->validate($columns)) { $failureMap = array_merge($failureMap, $this->aGrupoTrabajoSc->getValidationFailures()); } } if ($this->aPeriodoSc !== null) { if (!$this->aPeriodoSc->validate($columns)) { $failureMap = array_merge($failureMap, $this->aPeriodoSc->getValidationFailures()); } } if ($this->aUserScRelatedByResponsableId !== null) { if (!$this->aUserScRelatedByResponsableId->validate($columns)) { $failureMap = array_merge($failureMap, $this->aUserScRelatedByResponsableId->getValidationFailures()); } } if (($retval = TreeScPeer::doValidate($this, $columns)) !== true) { $failureMap = array_merge($failureMap, $retval); } if ($this->collTreeUsers !== null) { foreach ($this->collTreeUsers as $referrerFK) { if (!$referrerFK->validate($columns)) { $failureMap = array_merge($failureMap, $referrerFK->getValidationFailures()); } } } if ($this->collIndicatorsScs !== null) { foreach ($this->collIndicatorsScs as $referrerFK) { if (!$referrerFK->validate($columns)) { $failureMap = array_merge($failureMap, $referrerFK->getValidationFailures()); } } } if ($this->collAsignacionScs !== null) { foreach ($this->collAsignacionScs as $referrerFK) { if (!$referrerFK->validate($columns)) { $failureMap = array_merge($failureMap, $referrerFK->getValidationFailures()); } } } $this->alreadyInValidation = false; } return !empty($failureMap) ? $failureMap : true; }