| 
									
										
										
										
											2015-08-16 21:51:45 +08:00
										 |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-11 02:31:09 +08:00
										 |  |  | namespace BookStack; | 
					
						
							| 
									
										
										
										
											2015-08-16 21:51:45 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | use Illuminate\Database\Eloquent\Model; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-05 00:50:52 +08:00
										 |  |  | abstract class Entity extends Model | 
					
						
							| 
									
										
										
										
											2015-08-16 21:51:45 +08:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2015-11-22 01:22:14 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-10 03:50:17 +08:00
										 |  |  |     use Ownable; | 
					
						
							| 
									
										
										
										
											2015-08-16 21:51:45 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Compares this entity to another given entity. | 
					
						
							|  |  |  |      * Matches by comparing class and id. | 
					
						
							|  |  |  |      * @param $entity | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function matches($entity) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return [get_class($this), $this->id] === [get_class($entity), $entity->id]; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-08-17 01:59:23 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-11-30 02:06:55 +08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Checks if an entity matches or contains another given entity. | 
					
						
							|  |  |  |      * @param Entity $entity | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function matchesOrContains(Entity $entity) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $matches = [get_class($this), $this->id] === [get_class($entity), $entity->id]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if ($matches) return true; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if ($entity->isA('chapter') && $this->isA('book')) { | 
					
						
							|  |  |  |             return $entity->book_id === $this->id; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if ($entity->isA('page') && $this->isA('book')) { | 
					
						
							|  |  |  |             return $entity->book_id === $this->id; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if ($entity->isA('page') && $this->isA('chapter')) { | 
					
						
							|  |  |  |             return $entity->chapter_id === $this->id; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return false; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-17 01:59:23 +08:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2015-11-22 01:22:14 +08:00
										 |  |  |      * Gets the activity objects for this entity. | 
					
						
							| 
									
										
										
										
											2015-08-17 01:59:23 +08:00
										 |  |  |      * @return \Illuminate\Database\Eloquent\Relations\MorphMany | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function activity() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-09-11 02:31:09 +08:00
										 |  |  |         return $this->morphMany('BookStack\Activity', 'entity')->orderBy('created_at', 'desc'); | 
					
						
							| 
									
										
										
										
											2015-08-17 01:59:23 +08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-11-22 01:22:14 +08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Get View objects for this entity. | 
					
						
							|  |  |  |      * @return mixed | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function views() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->morphMany('BookStack\View', 'viewable'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Get just the views for the current user. | 
					
						
							|  |  |  |      * @return mixed | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function userViews() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->views()->where('user_id', '=', auth()->user()->id); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-31 18:43:28 +08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Allows checking of the exact class, Used to check entity type. | 
					
						
							|  |  |  |      * Cleaner method for is_a. | 
					
						
							|  |  |  |      * @param $type | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-11-30 01:33:25 +08:00
										 |  |  |     public static function isA($type) | 
					
						
							| 
									
										
										
										
											2015-08-31 18:43:28 +08:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-12-05 22:41:51 +08:00
										 |  |  |         return static::getClassName() === strtolower($type); | 
					
						
							| 
									
										
										
										
											2015-08-31 18:43:28 +08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-01 03:11:44 +08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Gets the class name. | 
					
						
							|  |  |  |      * @return string | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-12-05 22:41:51 +08:00
										 |  |  |     public static function getClassName() | 
					
						
							| 
									
										
										
										
											2015-08-31 18:43:28 +08:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-11-30 01:33:25 +08:00
										 |  |  |         return strtolower(array_slice(explode('\\', static::class), -1, 1)[0]); | 
					
						
							| 
									
										
										
										
											2015-08-31 18:43:28 +08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-05 22:41:51 +08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      *Gets a limited-length version of the entities name. | 
					
						
							|  |  |  |      * @param int $length | 
					
						
							|  |  |  |      * @return string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getShortName($length = 25) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if(strlen($this->name) <= $length) return $this->name; | 
					
						
							|  |  |  |         return substr($this->name, 0, $length-3) . '...'; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-01 03:11:44 +08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Perform a full-text search on this entity. | 
					
						
							|  |  |  |      * @param string[] $fieldsToSearch | 
					
						
							|  |  |  |      * @param string[] $terms | 
					
						
							| 
									
										
										
										
											2015-09-01 22:35:11 +08:00
										 |  |  |      * @param string[] array $wheres | 
					
						
							| 
									
										
										
										
											2015-09-01 03:11:44 +08:00
										 |  |  |      * @return mixed | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-09-01 22:35:11 +08:00
										 |  |  |     public static function fullTextSearch($fieldsToSearch, $terms, $wheres = []) | 
					
						
							| 
									
										
										
										
											2015-09-01 03:11:44 +08:00
										 |  |  |     { | 
					
						
							|  |  |  |         $termString = ''; | 
					
						
							| 
									
										
										
										
											2015-09-01 22:35:11 +08:00
										 |  |  |         foreach ($terms as $term) { | 
					
						
							| 
									
										
										
										
											2015-12-29 23:37:13 +08:00
										 |  |  |             $termString .= htmlentities($term) . '* '; | 
					
						
							| 
									
										
										
										
											2015-09-01 03:11:44 +08:00
										 |  |  |         } | 
					
						
							|  |  |  |         $fields = implode(',', $fieldsToSearch); | 
					
						
							| 
									
										
										
										
											2015-12-05 23:11:48 +08:00
										 |  |  |         $termStringEscaped = \DB::connection()->getPdo()->quote($termString); | 
					
						
							|  |  |  |         $search = static::addSelect(\DB::raw('*, MATCH(name) AGAINST('.$termStringEscaped.' IN BOOLEAN MODE) AS title_relevance')); | 
					
						
							| 
									
										
										
										
											2015-12-29 23:37:13 +08:00
										 |  |  |         $search = $search->whereRaw('MATCH(' . $fields . ') AGAINST(? IN BOOLEAN MODE)', [$termStringEscaped]); | 
					
						
							| 
									
										
										
										
											2015-12-05 23:11:48 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // Add additional where terms
 | 
					
						
							| 
									
										
										
										
											2015-09-01 22:35:11 +08:00
										 |  |  |         foreach ($wheres as $whereTerm) { | 
					
						
							|  |  |  |             $search->where($whereTerm[0], $whereTerm[1], $whereTerm[2]); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2015-11-30 01:33:25 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-05 23:11:48 +08:00
										 |  |  |         // Load in relations
 | 
					
						
							|  |  |  |         if (!static::isA('book')) $search = $search->with('book'); | 
					
						
							|  |  |  |         if (static::isA('page'))  $search = $search->with('chapter'); | 
					
						
							| 
									
										
										
										
											2015-11-30 01:33:25 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-05 23:11:48 +08:00
										 |  |  |         return $search->orderBy('title_relevance', 'desc')->get(); | 
					
						
							| 
									
										
										
										
											2015-09-01 03:11:44 +08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-05 00:50:52 +08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Get the url for this item. | 
					
						
							|  |  |  |      * @return string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     abstract public function getUrl(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-16 21:51:45 +08:00
										 |  |  | } |