Fixed hidden book children for admins on upgrade

This commit is contained in:
Dan Brown 2017-01-22 12:02:30 +00:00
parent 8f19231ed5
commit 989de47f22
No known key found for this signature in database
GPG key ID: 46D9F943C24A2EF9

View file

@ -486,6 +486,10 @@ class PermissionService
} }
}); });
$chapterSelect = $this->db->table('chapters')->selectRaw("'BookStack\\\\Chapter' as entity_type, id, slug, name, '' as text, description, book_id, priority, 0 as chapter_id, 0 as draft")->where('book_id', '=', $book_id); $chapterSelect = $this->db->table('chapters')->selectRaw("'BookStack\\\\Chapter' as entity_type, id, slug, name, '' as text, description, book_id, priority, 0 as chapter_id, 0 as draft")->where('book_id', '=', $book_id);
$query = $this->db->query()->select('*')->from($this->db->raw("({$pageSelect->toSql()} UNION {$chapterSelect->toSql()}) AS U"))
->mergeBindings($pageSelect)->mergeBindings($chapterSelect);
if (!$this->isAdmin()) {
$whereQuery = $this->db->table('joint_permissions as jp')->selectRaw('COUNT(*)') $whereQuery = $this->db->table('joint_permissions as jp')->selectRaw('COUNT(*)')
->whereRaw('jp.entity_id=U.id')->whereRaw('jp.entity_type=U.entity_type') ->whereRaw('jp.entity_id=U.id')->whereRaw('jp.entity_type=U.entity_type')
->where('jp.action', '=', 'view')->whereIn('jp.role_id', $this->getRoles()) ->where('jp.action', '=', 'view')->whereIn('jp.role_id', $this->getRoles())
@ -494,9 +498,10 @@ class PermissionService
$query->where('jp.has_permission_own', '=', 1)->where('jp.created_by', '=', $this->currentUser()->id); $query->where('jp.has_permission_own', '=', 1)->where('jp.created_by', '=', $this->currentUser()->id);
}); });
}); });
$query = $this->db->query()->select('*')->from($this->db->raw("({$pageSelect->toSql()} UNION {$chapterSelect->toSql()}) AS U")) $query->whereRaw("({$whereQuery->toSql()}) > 0")->mergeBindings($whereQuery);
->mergeBindings($pageSelect)->mergeBindings($chapterSelect) }
->whereRaw("({$whereQuery->toSql()}) > 0")->mergeBindings($whereQuery)->orderBy('draft', 'desc')->orderBy('priority', 'asc');
$query->orderBy('draft', 'desc')->orderBy('priority', 'asc');
$this->clean(); $this->clean();
return $query; return $query;
} }