| 
									
										
										
										
											2023-07-31 23:08:29 +08:00
										 |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace BookStack\Activity\Controllers; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-09 21:53:31 +08:00
										 |  |  | use BookStack\Activity\Tools\UserEntityWatchOptions; | 
					
						
							| 
									
										
										
										
											2023-07-31 23:08:29 +08:00
										 |  |  | use BookStack\App\Model; | 
					
						
							|  |  |  | use BookStack\Entities\Models\Entity; | 
					
						
							|  |  |  | use BookStack\Http\Controller; | 
					
						
							|  |  |  | use Exception; | 
					
						
							|  |  |  | use Illuminate\Http\Request; | 
					
						
							|  |  |  | use Illuminate\Validation\ValidationException; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class WatchController extends Controller | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     public function update(Request $request) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2023-08-16 23:02:00 +08:00
										 |  |  |         $this->checkPermission('receive-notifications'); | 
					
						
							|  |  |  |         $this->preventGuestAccess(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-31 23:08:29 +08:00
										 |  |  |         $requestData = $this->validate($request, [ | 
					
						
							|  |  |  |             'level' => ['required', 'string'], | 
					
						
							|  |  |  |         ]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $watchable = $this->getValidatedModelFromRequest($request); | 
					
						
							| 
									
										
										
										
											2023-08-09 21:53:31 +08:00
										 |  |  |         $watchOptions = new UserEntityWatchOptions(user(), $watchable); | 
					
						
							| 
									
										
										
										
											2023-08-18 01:10:34 +08:00
										 |  |  |         $watchOptions->updateLevelByName($requestData['level']); | 
					
						
							| 
									
										
										
										
											2023-07-31 23:08:29 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-02 20:14:00 +08:00
										 |  |  |         $this->showSuccessNotification(trans('activities.watch_update_level_notification')); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return redirect()->back(); | 
					
						
							| 
									
										
										
										
											2023-07-31 23:08:29 +08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @throws ValidationException | 
					
						
							|  |  |  |      * @throws Exception | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     protected function getValidatedModelFromRequest(Request $request): Entity | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $modelInfo = $this->validate($request, [ | 
					
						
							|  |  |  |             'type' => ['required', 'string'], | 
					
						
							|  |  |  |             'id'   => ['required', 'integer'], | 
					
						
							|  |  |  |         ]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (!class_exists($modelInfo['type'])) { | 
					
						
							|  |  |  |             throw new Exception('Model not found'); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         /** @var Model $model */ | 
					
						
							|  |  |  |         $model = new $modelInfo['type'](); | 
					
						
							|  |  |  |         if (!$model instanceof Entity) { | 
					
						
							|  |  |  |             throw new Exception('Model not an entity'); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $modelInstance = $model->newQuery() | 
					
						
							|  |  |  |             ->where('id', '=', $modelInfo['id']) | 
					
						
							|  |  |  |             ->first(['id', 'name', 'owned_by']); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $inaccessibleEntity = ($modelInstance instanceof Entity && !userCan('view', $modelInstance)); | 
					
						
							|  |  |  |         if (is_null($modelInstance) || $inaccessibleEntity) { | 
					
						
							|  |  |  |             throw new Exception('Model instance not found'); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $modelInstance; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } |