mirror of
				https://github.com/pelican-dev/panel.git
				synced 2025-10-26 06:06:52 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			36 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			36 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace Pterodactyl\Traits\Services;
 | |
| 
 | |
| use BadMethodCallException;
 | |
| use Illuminate\Support\Str;
 | |
| use Illuminate\Contracts\Validation\Factory;
 | |
| use Pterodactyl\Exceptions\Service\Egg\Variable\BadValidationRuleException;
 | |
| 
 | |
| trait ValidatesValidationRules
 | |
| {
 | |
|     abstract protected function getValidator(): Factory;
 | |
| 
 | |
|     /**
 | |
|      * Validate that the rules being provided are valid for Laravel and can
 | |
|      * be resolved.
 | |
|      *
 | |
|      * @param array|string $rules
 | |
|      *
 | |
|      * @throws \Pterodactyl\Exceptions\Service\Egg\Variable\BadValidationRuleException
 | |
|      */
 | |
|     public function validateRules($rules)
 | |
|     {
 | |
|         try {
 | |
|             $this->getValidator()->make(['__TEST' => 'test'], ['__TEST' => $rules])->fails();
 | |
|         } catch (BadMethodCallException $exception) {
 | |
|             $matches = [];
 | |
|             if (preg_match('/Method \[(.+)\] does not exist\./', $exception->getMessage(), $matches)) {
 | |
|                 throw new BadValidationRuleException(trans('exceptions.nest.variables.bad_validation_rule', ['rule' => Str::snake(str_replace('validate', '', array_get($matches, 1, 'unknownRule')))]), $exception);
 | |
|             }
 | |
| 
 | |
|             throw $exception;
 | |
|         }
 | |
|     }
 | |
| }
 | 
