From 0ab9258f3bca85c3c313646396b503d55bb58802 Mon Sep 17 00:00:00 2001 From: Bob Mottram Date: Mon, 25 May 2020 17:21:53 +0100 Subject: [PATCH] Process fonts earlier --- daemon.py | 88 +++++++++++++++++++++++++++---------------------------- 1 file changed, 44 insertions(+), 44 deletions(-) diff --git a/daemon.py b/daemon.py index 3db386cf..23fb3661 100644 --- a/daemon.py +++ b/daemon.py @@ -917,7 +917,7 @@ class PubServer(BaseHTTPRequestHandler): return False # token based authenticated used by the web interface - if self.headers.get('Cookie') and '/fonts/' not in self.path: + if self.headers.get('Cookie'): if self.headers['Cookie'].startswith('epicyon='): tokenStr = self.headers['Cookie'].split('=', 1)[1].strip() if ';' in tokenStr: @@ -1098,6 +1098,49 @@ class PubServer(BaseHTTPRequestHandler): if self.server.debug: print(str(self.headers)) + # get fonts + if '/fonts/' in self.path: + fontStr = self.path.split('/fonts/')[1] + if fontStr.endswith('.otf') or \ + fontStr.endswith('.ttf') or \ + fontStr.endswith('.woff') or \ + fontStr.endswith('.woff2'): + if fontStr.endswith('.otf'): + fontType = 'application/x-font-opentype' + elif fontStr.endswith('.ttf'): + fontType = 'application/x-font-truetype' + elif fontStr.endswith('.woff'): + fontType = 'application/font-woff' + else: + fontType = 'application/font-woff2' + fontFilename = \ + self.server.baseDir + '/fonts/' + fontStr + if self._etag_exists(fontFilename): + # The file has not changed + self._304() + return + if self.server.fontsCache.get(fontStr): + fontBinary = self.server.fontsCache[fontStr] + self._set_headers_etag(fontFilename, + fontType, + fontBinary, cookie, + callingDomain) + self._write(fontBinary) + return + else: + if os.path.isfile(fontFilename): + with open(fontFilename, 'rb') as avFile: + fontBinary = avFile.read() + self._set_headers_etag(fontFilename, + fontType, + fontBinary, cookie, + callingDomain) + self._write(fontBinary) + self.server.fontsCache[fontStr] = fontBinary + return + self._404() + return + cookie = None if self.headers.get('Cookie'): cookie = self.headers['Cookie'] @@ -1738,49 +1781,6 @@ class PubServer(BaseHTTPRequestHandler): self._benchmarkGETtimings(GETstartTime, GETtimings, 21) - # get fonts - if '/fonts/' in self.path: - fontStr = self.path.split('/fonts/')[1] - if fontStr.endswith('.otf') or \ - fontStr.endswith('.ttf') or \ - fontStr.endswith('.woff') or \ - fontStr.endswith('.woff2'): - if fontStr.endswith('.otf'): - fontType = 'application/x-font-opentype' - elif fontStr.endswith('.ttf'): - fontType = 'application/x-font-truetype' - elif fontStr.endswith('.woff'): - fontType = 'application/font-woff' - else: - fontType = 'application/font-woff2' - fontFilename = \ - self.server.baseDir + '/fonts/' + fontStr - if self._etag_exists(fontFilename): - # The file has not changed - self._304() - return - if self.server.fontsCache.get(fontStr): - fontBinary = self.server.fontsCache[fontStr] - self._set_headers_etag(fontFilename, - fontType, - fontBinary, cookie, - callingDomain) - self._write(fontBinary) - return - else: - if os.path.isfile(fontFilename): - with open(fontFilename, 'rb') as avFile: - fontBinary = avFile.read() - self._set_headers_etag(fontFilename, - fontType, - fontBinary, cookie, - callingDomain) - self._write(fontBinary) - self.server.fontsCache[fontStr] = fontBinary - return - self._404() - return - # icon images # Note that this comes before the busy flag to avoid conflicts if self.path.startswith('/icons/'):