]> BookStack Code Mirror - bookstack/blobdiff - tests/Api/TestsApi.php
Opensearch: Fixed XML declaration when php short tags enabled
[bookstack] / tests / Api / TestsApi.php
index 623fa6969a7128bf9652f9e50e16fa710d29ac54..466acbffbe0b207f77882649ad56bb70a997e3b2 100644 (file)
@@ -1,17 +1,42 @@
-<?php namespace Tests\Api;
+<?php
+
+namespace Tests\Api;
+
+use BookStack\Users\Models\User;
 
 trait TestsApi
 {
+    protected string $apiTokenId = 'apitoken';
+    protected string $apiTokenSecret = 'password';
 
-    protected $apiTokenId = 'apitoken';
-    protected $apiTokenSecret = 'password';
+    /**
+     * Set the given user as the current logged-in user via the API driver.
+     * This does not ensure API access. The user may still lack required role permissions.
+     */
+    protected function actingAsForApi(User $user): static
+    {
+        parent::actingAs($user, 'api');
+
+        return $this;
+    }
 
     /**
      * Set the API editor role as the current user via the API driver.
      */
-    protected function actingAsApiEditor()
+    protected function actingAsApiEditor(): static
+    {
+        $this->actingAs($this->users->editor(), 'api');
+
+        return $this;
+    }
+
+    /**
+     * Set the API admin role as the current user via the API driver.
+     */
+    protected function actingAsApiAdmin(): static
     {
-        $this->actingAs($this->getEditor(), 'api');
+        $this->actingAs($this->users->admin(), 'api');
+
         return $this;
     }
 
@@ -20,7 +45,27 @@ trait TestsApi
      */
     protected function errorResponse(string $message, int $code): array
     {
-        return ["error" => ["code" => $code, "message" => $message]];
+        return ['error' => ['code' => $code, 'message' => $message]];
+    }
+
+    /**
+     * Get the structure that matches a permission error response.
+     */
+    protected function permissionErrorResponse(): array
+    {
+        return $this->errorResponse('You do not have permission to perform the requested action.', 403);
+    }
+
+    /**
+     * Format the given (field_name => ["messages"]) array
+     * into a standard validation response format.
+     */
+    protected function validationResponse(array $messages): array
+    {
+        $err = $this->errorResponse('The given data was invalid.', 422);
+        $err['error']['validation'] = $messages;
+
+        return $err;
     }
 
     /**
@@ -29,8 +74,7 @@ trait TestsApi
     protected function apiAuthHeader(): array
     {
         return [
-            "Authorization" => "Token {$this->apiTokenId}:{$this->apiTokenSecret}"
+            'Authorization' => "Token {$this->apiTokenId}:{$this->apiTokenSecret}",
         ];
     }
-
-}
\ No newline at end of file
+}