]> source.dussan.org Git - nextcloud-server.git/commitdiff
fix(a11y): Add OTF font loading check bugfix/noid/fix-otf-loading 48063/head
authorJoas Schilling <coding@schilljs.com>
Mon, 16 Sep 2024 07:58:54 +0000 (09:58 +0200)
committerJoas Schilling <coding@schilljs.com>
Mon, 16 Sep 2024 07:59:21 +0000 (09:59 +0200)
Signed-off-by: Joas Schilling <coding@schilljs.com>
.htaccess
apps/settings/lib/SetupChecks/Woff2Loading.php
lib/private/Setup.php

index f9908fe0b69fce642c36650c4a51b0ee87b794ca..1406448db0a1b2325442491e640c4b0b33ce0362 100644 (file)
--- a/.htaccess
+++ b/.htaccess
@@ -49,8 +49,8 @@
     </Else>
   </FilesMatch>
 
-  # Let browsers cache WOFF files for a week
-  <FilesMatch "\.woff2?$">
+  # Let browsers cache OTF and WOFF files for a week
+  <FilesMatch "\.(otf|woff2?)$">
     Header set Cache-Control "max-age=604800"
   </FilesMatch>
 </IfModule>
   SetEnvIf Transfer-Encoding "chunked" proxy-sendcl=1
 </IfModule>
 
-# Apache disabled the sending of the server-side content-length header 
+# Apache disabled the sending of the server-side content-length header
 # in their 2.4.59 patch updated which breaks some use-cases in Nextcloud.
 # Setting ap_trust_cgilike_cl allows to bring back the usual behaviour.
 # See https://bz.apache.org/bugzilla/show_bug.cgi?id=68973
index 5d8f23338e336d8f6216202c41838823b7d97592..769653c46180dc62673eadb684efdfbd030eab3b 100644 (file)
@@ -17,7 +17,7 @@ use OCP\SetupCheck\SetupResult;
 use Psr\Log\LoggerInterface;
 
 /**
- * Check whether the WOFF2 URLs works
+ * Check whether the OTF and WOFF2 URLs works
  */
 class Woff2Loading implements ISetupCheck {
        use CheckServerResponseTrait;
@@ -36,11 +36,18 @@ class Woff2Loading implements ISetupCheck {
        }
 
        public function getName(): string {
-               return $this->l10n->t('WOFF2 file loading');
+               return $this->l10n->t('Font file loading');
        }
 
        public function run(): SetupResult {
-               $url = $this->urlGenerator->linkTo('', 'core/fonts/NotoSans-Regular-latin.woff2');
+               $result = $this->checkFont('otf', $this->urlGenerator->linkTo('theming', 'fonts/OpenDyslexic-Regular.otf'));
+               if ($result->getSeverity() !== SetupResult::SUCCESS) {
+                       return $result;
+               }
+               return $this->checkFont('woff2', $this->urlGenerator->linkTo('', 'core/fonts/NotoSans-Regular-latin.woff2'));
+       }
+
+       protected function checkFont(string $fileExtension, string $url): SetupResult {
                $noResponse = true;
                $responses = $this->runHEAD($url);
                foreach ($responses as $response) {
@@ -52,14 +59,22 @@ class Woff2Loading implements ISetupCheck {
 
                if ($noResponse) {
                        return SetupResult::info(
-                               $this->l10n->t('Could not check for WOFF2 loading support. Please check manually if your webserver serves `.woff2` files.') . "\n" . $this->serverConfigHelp(),
+                               str_replace(
+                                       '{extension}',
+                                       $fileExtension,
+                                       $this->l10n->t('Could not check for {extension} loading support. Please check manually if your webserver serves `.{extension}` files.') . "\n" . $this->serverConfigHelp(),
+                               ),
                                $this->urlGenerator->linkToDocs('admin-nginx'),
                        );
                }
                return SetupResult::warning(
-                       $this->l10n->t('Your web server is not properly set up to deliver .woff2 files. This is typically an issue with the Nginx configuration. For Nextcloud 15 it needs an adjustement to also deliver .woff2 files. Compare your Nginx configuration to the recommended configuration in our documentation.'),
+                       str_replace(
+                               '{extension}',
+                               $fileExtension,
+                               $this->l10n->t('Your web server is not properly set up to deliver .{extension} files. This is typically an issue with the Nginx configuration. For Nextcloud 15 it needs an adjustment to also deliver .{extension} files. Compare your Nginx configuration to the recommended configuration in our documentation.'),
+                       ),
                        $this->urlGenerator->linkToDocs('admin-nginx'),
                );
-               
+
        }
 }
index 6212a561abb717feafb444e375f12aa5831c111f..fb054bca4e025dc47fb4a936867092390ab55cf7 100644 (file)
@@ -484,7 +484,7 @@ class Setup {
                        $content .= "\n  Options -MultiViews";
                        $content .= "\n  RewriteRule ^core/js/oc.js$ index.php [PT,E=PATH_INFO:$1]";
                        $content .= "\n  RewriteRule ^core/preview.png$ index.php [PT,E=PATH_INFO:$1]";
-                       $content .= "\n  RewriteCond %{REQUEST_FILENAME} !\\.(css|js|mjs|svg|gif|ico|jpg|jpeg|png|webp|html|ttf|woff2?|map|webm|mp4|mp3|ogg|wav|flac|wasm|tflite)$";
+                       $content .= "\n  RewriteCond %{REQUEST_FILENAME} !\\.(css|js|mjs|svg|gif|ico|jpg|jpeg|png|webp|html|otf|ttf|woff2?|map|webm|mp4|mp3|ogg|wav|flac|wasm|tflite)$";
                        $content .= "\n  RewriteCond %{REQUEST_FILENAME} !/core/ajax/update\\.php";
                        $content .= "\n  RewriteCond %{REQUEST_FILENAME} !/core/img/(favicon\\.ico|manifest\\.json)$";
                        $content .= "\n  RewriteCond %{REQUEST_FILENAME} !/(cron|public|remote|status)\\.php";