* @var string
*/
protected $baseUrl = 'http://localhost';
+
+ // Local user instances
private $admin;
+ private $editor;
/**
* Creates the application.
return $app;
}
+ /**
+ * Set the current user context to be an admin.
+ * @return $this
+ */
public function asAdmin()
{
+ return $this->actingAs($this->getAdmin());
+ }
+
+ /**
+ * Get the current admin user.
+ * @return mixed
+ */
+ public function getAdmin() {
if($this->admin === null) {
$adminRole = \BookStack\Role::getRole('admin');
$this->admin = $adminRole->users->first();
}
- return $this->actingAs($this->admin);
+ return $this->admin;
+ }
+
+ /**
+ * Set the current editor context to be an editor.
+ * @return $this
+ */
+ public function asEditor()
+ {
+ if($this->editor === null) {
+ $this->editor = $this->getEditor();
+ }
+ return $this->actingAs($this->editor);
+ }
+
+ /**
+ * Get a user that's not a system user such as the guest user.
+ */
+ public function getNormalUser()
+ {
+ return \BookStack\User::where('system_name', '=', null)->get()->last();
}
/**
$page = factory(BookStack\Page::class)->create(['created_by' => $creatorUser->id, 'updated_by' => $updaterUser->id, 'book_id' => $book->id]);
$book->chapters()->saveMany([$chapter]);
$chapter->pages()->saveMany([$page]);
- $restrictionService = $this->app[\BookStack\Services\RestrictionService::class];
- $restrictionService->buildEntityPermissionsForEntity($book);
+ $restrictionService = $this->app[\BookStack\Services\PermissionService::class];
+ $restrictionService->buildJointPermissionsForEntity($book);
return [
'book' => $book,
'chapter' => $chapter,
* @param array $attributes
* @return mixed
*/
- protected function getNewUser($attributes = [])
+ protected function getEditor($attributes = [])
{
$user = factory(\BookStack\User::class)->create($attributes);
$role = \BookStack\Role::getRole('editor');