]> BookStack Code Mirror - bookstack/commitdiff
Fixed disabling of avatar urls, Removed id from gravatar image name
authorDan Brown <redacted>
Tue, 26 Jul 2022 11:10:19 +0000 (12:10 +0100)
committerDan Brown <redacted>
Tue, 26 Jul 2022 11:10:19 +0000 (12:10 +0100)
Included test to cover avatar url disabling.
Related to #1835

app/Uploads/UserAvatars.php
tests/Uploads/AvatarTest.php

index f5b085a35d5cf802a45de6710034421f4c653716..49a54bbbbb9b387dfa3e964bbe004f62e42e274b 100644 (file)
@@ -6,6 +6,7 @@ use BookStack\Auth\User;
 use BookStack\Exceptions\HttpFetchException;
 use Exception;
 use Illuminate\Support\Facades\Log;
+use Illuminate\Support\Str;
 
 class UserAvatars
 {
@@ -93,7 +94,7 @@ class UserAvatars
      */
     protected function createAvatarImageFromData(User $user, string $imageData, string $extension): Image
     {
-        $imageName = str_replace(' ', '-', $user->id . '-avatar.' . $extension);
+        $imageName = Str::random(10) . '-avatar.' . $extension;
 
         $image = $this->imageService->saveNew($imageName, $imageData, 'user', $user->id);
         $image->created_by = $user->id;
@@ -134,7 +135,12 @@ class UserAvatars
      */
     protected function getAvatarUrl(): string
     {
-        $url = trim(config('services.avatar_url'));
+        $configOption = config('services.avatar_url');
+        if ($configOption === false) {
+            return '';
+        }
+
+        $url = trim($configOption);
 
         if (empty($url) && !config('services.disable_services')) {
             $url = 'https://www.gravatar.com/avatar/${hash}?s=${size}&d=identicon';
index 650f5b4ea359ac5dd02929c9780cb67a13031157..3e27e53446b9046cea4a429ec7241f59b73ea3be 100644 (file)
@@ -82,6 +82,21 @@ class AvatarTest extends TestCase
         $this->createUserRequest($user);
     }
 
+    public function test_avatar_not_fetched_if_avatar_url_option_set_to_false()
+    {
+        config()->set([
+            'services.disable_services' => false,
+            'services.avatar_url' => false,
+        ]);
+
+        $user = User::factory()->make();
+
+        $http = $this->mock(HttpFetcher::class);
+        $http->shouldNotReceive('fetch');
+
+        $this->createUserRequest($user);
+    }
+
     public function test_no_failure_but_error_logged_on_failed_avatar_fetch()
     {
         config()->set([