tklustig  
          
              
                January 14, 2018,  2:44am
               
              1 
           
         
        
          Hi guys,
following code in Controller prevents writing data into database. If I negate boolean variable $valid to !valid, everything is gonna all right. However, I am concerned about not validating my input.
What do you think: Should I remove code,which is validating data or shouldn’t I?
            if ($model->load(Yii::$app->request->post()) && $model_person->load(Yii::$app->request->post())) {
                $valid = $model->validate();
                $isValid = $model_person->validate();
                $isValid = $valid & $isValid;
                if ($isValid) { //will be true after having pushed submittButton
   				$model_person->id_person_art = 3;
                    $model_person->save();
                    $model->id_person = $model_person->id;
                    $model->save();
                    return $this->redirect(['view', 'id' => $model->id]);
                } else {
   				$error_person = $model_person->getErrors();
                    $error_bewerber = $model->getErrors();
   				foreach ($error_person as $values) {
                        foreach ($values as $ausgabe) {
                            echo"<p>" . $ausgabe . "</p>";
                        }
                    }
                    foreach ($error_bewerber as $values) {
                        foreach ($values as $ausgabe) {
                            echo"<p>" . $ausgabe . "</p>";
                        }
                    }
                    echo Growl::widget([
                        'type' => Growl::TYPE_DANGER,
   					'title' => 'Oh snap!',
                        'icon' => 'glyphicon glyphicon-remove-sign',
[                        'body' => 'for unknown reasons,your input could not be validated...',
                        'showSeparator' => true,
                        'delay' => 2000,
                        'pluginOptions' => [
   						'showProgressbar' => true,
                            'placement' => [
                                'from' => 'top',
                                'align' => 'center',
                            ]
                        ]
                    ]);
   				return $this->render('create', [
                                'model' => $model,
                                'model_person' => $model_person,
                    ]);
                }
            } else {
                return $this->render('create', [
                            'model' => $model,
                            'model_person' => $model_person,
   			]);
            }
P.S.:
echo"<p>" . $ausgabe . "</p>";
in loop won’t show any errors. $valid just is false
         
        
           
         
            
       
      
        
          
          
            achertovsky  
          
              
                January 14, 2018,  6:49am
               
              2 
           
         
        
          $valid & $isValid seem weird onlg to me?
And in php look like && as i remember 
If no errors inside of models - u have syntax issue. Also maybe weird override of beforeSave.
         
        
           
         
            
       
      
        
          
          
            alirz23  
          
              
                January 14, 2018,  8:14am
               
              3 
           
         
        
          you are using a unary and (&) to combine model and person model validation result
$isValid = $valid & $isValid;
// should be
$isValid = $valid && $isValid;
 
        
           
         
            
       
      
        
          
          
            softark  
          
              
                January 14, 2018, 12:27pm
               
              4 
           
         
        
          
I would also use the logical operator ‘&&’ instead of the bitwise operator ‘&’ here.
But if $valid is ‘true’ and $isValid is ‘true’, then ‘$valid & $isValid’ should be ‘true’, shouldn’t it?
         
        
           
         
            
       
      
        
          
          
            tklustig  
          
              
                January 14, 2018,  1:52pm
               
              5 
           
         
        
          
 softark:
 
I would also use the logical operator ‘&&’ instead of the bitwise operator ‘&’ here.
But if $valid is ‘true’ and $isValid is ‘true’, then ‘$valid & $isValid’ should be ‘true’, shouldn’t it?
 
 
U are right, all of you. No idea why using bitoperator. That’s nonsens,of course.
I changed operator as suggested but didn’t succeed. Nevertheless,validation is failing. I assume faulty <div> tags in formular is causing this failing. Publishing formular is not possible, 'cause it’s simply to extensive (<760 lines of code)
Because data will be saved into database negating $valid, I will do it. Any statements about my proposal of yii2-experts are urgently required!
P.S.: Publishing code via Copy&Paste is a hard thing in this forum. I always have to remove tags like below  at each line of code, manually. That’s annoying me.
Any ideas how to avoid this curiosity?
Here  an example of same code in terms of this curiosity
[size=3]          if ($model->load(Yii::$app->request->post()) && $model_person->load(Yii::$app->request->post())) {[/size]
[size=3]                $valid = $model->validate();[/size]
[size=3]                $isValid = $model_person->validate();[/size]
[size=3]                $isValid = $valid && $isValid;[/size] //changed operator,without succeeding
[size=3]                if (!$isValid) {[/size]  //negating boolean will save data into database
[size=3]                    $model_person->id_person_art = 3;[/size]
[size=3]                    $model_person->save();[/size]
[size=3]                    $model->id_person = $model_person->id;[/size]
[size=3]                    $model->save();[/size]
[size=3]                    return $this->redirect(['view', 'id' => $model->id]);[/size]
[size=3]                } else {[/size]
[size=3]                    $error_person = $model_person->getErrors();[/size]
[size=3]                    $error_bewerber = $model->getErrors();[/size]
[size=3]                    foreach ($error_person as $values) {[/size]
[size=3]                        foreach ($values as $ausgabe) {[/size]
[size=3]                            echo"<p>" . $ausgabe . "</p>";[/size]
[size=3]                        }[/size]
[size=3]                    }[/size]
[size=3]                    foreach ($error_bewerber as $values) {[/size]
[size=3]                        foreach ($values as $ausgabe) {[/size]
[size=3]                            echo"<p>" . $ausgabe . "</p>";[/size]
[size=3]                        }[/size]
[size=3]                    }[/size]
[size=3]                    echo Growl::widget([[/size]
[size=3]                        'type' => Growl::TYPE_DANGER,[/size]
[size=3]                        'title' => 'Oh snap!',[/size]
[size=3]                        'icon' => 'glyphicon glyphicon-remove-sign',[/size]
[size=3]                        'body' => 'Aus unbekannten Gründen konnten die Tabellen nicht validiert werden<br>Bitte informieren Sie den Hersteller gemäß obiger Angaben!',[/size]
[size=3]                        'showSeparator' => true,[/size]
[size=3]                        'delay' => 2000,[/size]
[size=3]                        'pluginOptions' => [[/size]
[size=3]                            'showProgressbar' => true,[/size]
[size=3]                            'placement' => [[/size]
[size=3]                                'from' => 'top',[/size]
[size=3]                                'align' => 'center',[/size]
[size=3]                            ][/size]
[size=3]                        ][/size]
[size=3]                    ]);[/size]
[size=3]                    return $this->render('create', [[/size]
[size=3]                                'model' => $model,[/size]
[size=3]                                'model_person' => $model_person,[/size]
[size=3]                    ]);[/size]
[size=3]                }[/size]
[size=3]            } else {[/size]
[size=3]                return $this->render('create', [[/size]
[size=3]                            'model' => $model,[/size]
[size=3]                            'model_person' => $model_person,[/size]
[size=3]                ]);[/size]
[size=3]            }[/size]
 
        
           
         
            
       
      
        
          
          
            softark  
          
              
                January 14, 2018, 11:09pm
               
              6 
           
         
        
          
No, you should not do it. It’s a worst kind of practice.
I would try to find out what causes the validation error.
    if ($model->load(Yii::$app->request->post()) && $model_person->load(Yii::$app->request->post())) {
        $valid = $model->validate();
        if (!$valid) {
            $error_bewerber = $model->getErrors();
            foreach ($error_bewerber as $attr => $errors) {
                echo "<p>attribute = $attr</p>";
                foreach ($errors as $error) {
                    echo "<p>$error</p>";
                }
            }
        }
        $isValid = $model_person->validate();
        if (!$isValid) {
            $error_person = $model_person->getErrors();
            foreach ($error_person as $attr => $errors) {
                echo "<p>attribute = $attr</p>";
                foreach ($errors as $error) {
                    echo "<p>$error</p>";
                }
            }
        }
        if ($valid && $isValid) {
            ...
I noticed that you misunderstand the format of model errors.
http://www.yiiframework.com/doc-2.0/yii-base-model.html#getErrors()-detail 
         
        
           
         
            
       
      
        
          
          
            tklustig  
          
              
                January 17, 2018, 11:42am
               
              7 
           
         
        
          
So, I did in understanding [color=#1C2837][size=2] format of model errors.[/size][/color], finally.
var_dump($model_person->getErrors());
die();
showed up an attribute,which was in required rules, but not in formular. I write this attribute statically into database, so I returned it from rules. Validating still is in use.
So,this thread can be succesfully closed!
         
        
           
         
            
       
      
        
          
          
            softark  
          
              
                January 17, 2018, 12:59pm
               
              8 
           
         
        
          Yeah, you’ve got the right solution.