2015-11-21 12:22:14 -05:00
|
|
|
<?php namespace BookStack\Services;
|
|
|
|
|
|
|
|
use BookStack\Entity;
|
|
|
|
use BookStack\View;
|
|
|
|
|
|
|
|
class ViewService
|
|
|
|
{
|
|
|
|
|
|
|
|
protected $view;
|
|
|
|
protected $user;
|
2016-05-01 16:20:50 -04:00
|
|
|
protected $permissionService;
|
2015-11-21 12:22:14 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
* ViewService constructor.
|
2016-02-28 14:03:04 -05:00
|
|
|
* @param View $view
|
2016-05-01 16:20:50 -04:00
|
|
|
* @param PermissionService $permissionService
|
2015-11-21 12:22:14 -05:00
|
|
|
*/
|
2016-05-01 16:20:50 -04:00
|
|
|
public function __construct(View $view, PermissionService $permissionService)
|
2015-11-21 12:22:14 -05:00
|
|
|
{
|
|
|
|
$this->view = $view;
|
|
|
|
$this->user = auth()->user();
|
2016-05-01 16:20:50 -04:00
|
|
|
$this->permissionService = $permissionService;
|
2015-11-21 12:22:14 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add a view to the given entity.
|
|
|
|
* @param Entity $entity
|
|
|
|
* @return int
|
|
|
|
*/
|
|
|
|
public function add(Entity $entity)
|
|
|
|
{
|
2016-02-28 14:03:04 -05:00
|
|
|
if ($this->user === null) return 0;
|
2015-11-21 12:22:14 -05:00
|
|
|
$view = $entity->views()->where('user_id', '=', $this->user->id)->first();
|
|
|
|
// Add view if model exists
|
|
|
|
if ($view) {
|
|
|
|
$view->increment('views');
|
|
|
|
return $view->views;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Otherwise create new view count
|
|
|
|
$entity->views()->save($this->view->create([
|
|
|
|
'user_id' => $this->user->id,
|
|
|
|
'views' => 1
|
|
|
|
]));
|
|
|
|
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
2015-12-02 15:22:41 -05:00
|
|
|
/**
|
|
|
|
* Get the entities with the most views.
|
2016-02-28 14:03:04 -05:00
|
|
|
* @param int $count
|
|
|
|
* @param int $page
|
2016-06-12 07:14:14 -04:00
|
|
|
* @param bool|false|array $filterModel
|
2015-12-02 15:22:41 -05:00
|
|
|
*/
|
|
|
|
public function getPopular($count = 10, $page = 0, $filterModel = false)
|
|
|
|
{
|
|
|
|
$skipCount = $count * $page;
|
2016-05-01 16:20:50 -04:00
|
|
|
$query = $this->permissionService->filterRestrictedEntityRelations($this->view, 'views', 'viewable_id', 'viewable_type')
|
2016-04-09 09:26:42 -04:00
|
|
|
->select('*', 'viewable_id', 'viewable_type', \DB::raw('SUM(views) as view_count'))
|
2015-12-02 15:22:41 -05:00
|
|
|
->groupBy('viewable_id', 'viewable_type')
|
|
|
|
->orderBy('view_count', 'desc');
|
|
|
|
|
2016-06-12 07:14:14 -04:00
|
|
|
if ($filterModel && is_array($filterModel)) {
|
|
|
|
$query->whereIn('viewable_type', $filterModel);
|
|
|
|
} else if ($filterModel) {
|
|
|
|
$query->where('viewable_type', '=', get_class($filterModel));
|
|
|
|
};
|
2015-12-02 15:22:41 -05:00
|
|
|
|
2016-04-09 09:26:42 -04:00
|
|
|
return $query->with('viewable')->skip($skipCount)->take($count)->get()->pluck('viewable');
|
2015-12-02 15:22:41 -05:00
|
|
|
}
|
|
|
|
|
2015-11-21 12:22:14 -05:00
|
|
|
/**
|
|
|
|
* Get all recently viewed entities for the current user.
|
2016-02-28 14:03:04 -05:00
|
|
|
* @param int $count
|
|
|
|
* @param int $page
|
2015-11-21 12:22:14 -05:00
|
|
|
* @param Entity|bool $filterModel
|
|
|
|
* @return mixed
|
|
|
|
*/
|
|
|
|
public function getUserRecentlyViewed($count = 10, $page = 0, $filterModel = false)
|
|
|
|
{
|
2016-02-28 14:03:04 -05:00
|
|
|
if ($this->user === null) return collect();
|
2016-04-09 09:26:42 -04:00
|
|
|
|
2016-05-01 16:20:50 -04:00
|
|
|
$query = $this->permissionService
|
2016-02-28 14:03:04 -05:00
|
|
|
->filterRestrictedEntityRelations($this->view, 'views', 'viewable_id', 'viewable_type');
|
2015-11-21 12:22:14 -05:00
|
|
|
|
2016-02-28 14:03:04 -05:00
|
|
|
if ($filterModel) $query = $query->where('viewable_type', '=', get_class($filterModel));
|
|
|
|
$query = $query->where('user_id', '=', auth()->user()->id);
|
2015-11-21 12:22:14 -05:00
|
|
|
|
2016-04-09 09:26:42 -04:00
|
|
|
$viewables = $query->with('viewable')->orderBy('updated_at', 'desc')
|
|
|
|
->skip($count * $page)->take($count)->get()->pluck('viewable');
|
|
|
|
return $viewables;
|
2015-11-21 12:22:14 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Reset all view counts by deleting all views.
|
|
|
|
*/
|
|
|
|
public function resetAll()
|
|
|
|
{
|
|
|
|
$this->view->truncate();
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|