| 
									
										
										
										
											2020-11-22 01:52:49 +08:00
										 |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace BookStack\Providers; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | use Illuminate\Support\Facades\Validator; | 
					
						
							|  |  |  | use Illuminate\Support\ServiceProvider; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class CustomValidationServiceProvider extends ServiceProvider | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Register our custom validation rules when the application boots. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function boot(): void | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         Validator::extend('image_extension', function ($attribute, $value, $parameters, $validator) { | 
					
						
							|  |  |  |             $validImageExtensions = ['png', 'jpg', 'jpeg', 'gif', 'webp']; | 
					
						
							| 
									
										
										
										
											2021-06-26 23:23:15 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-22 01:52:49 +08:00
										 |  |  |             return in_array(strtolower($value->getClientOriginalExtension()), $validImageExtensions); | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         Validator::extend('safe_url', function ($attribute, $value, $parameters, $validator) { | 
					
						
							|  |  |  |             $cleanLinkName = strtolower(trim($value)); | 
					
						
							|  |  |  |             $isJs = strpos($cleanLinkName, 'javascript:') === 0; | 
					
						
							|  |  |  |             $isData = strpos($cleanLinkName, 'data:') === 0; | 
					
						
							| 
									
										
										
										
											2021-06-26 23:23:15 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-22 01:52:49 +08:00
										 |  |  |             return !$isJs && !$isData; | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } |