forked from indymedia/epicyon
Process fonts earlier
parent
95722d127e
commit
0ab9258f3b
88
daemon.py
88
daemon.py
|
@ -917,7 +917,7 @@ class PubServer(BaseHTTPRequestHandler):
|
||||||
return False
|
return False
|
||||||
|
|
||||||
# token based authenticated used by the web interface
|
# 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='):
|
if self.headers['Cookie'].startswith('epicyon='):
|
||||||
tokenStr = self.headers['Cookie'].split('=', 1)[1].strip()
|
tokenStr = self.headers['Cookie'].split('=', 1)[1].strip()
|
||||||
if ';' in tokenStr:
|
if ';' in tokenStr:
|
||||||
|
@ -1098,6 +1098,49 @@ class PubServer(BaseHTTPRequestHandler):
|
||||||
if self.server.debug:
|
if self.server.debug:
|
||||||
print(str(self.headers))
|
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
|
cookie = None
|
||||||
if self.headers.get('Cookie'):
|
if self.headers.get('Cookie'):
|
||||||
cookie = self.headers['Cookie']
|
cookie = self.headers['Cookie']
|
||||||
|
@ -1738,49 +1781,6 @@ class PubServer(BaseHTTPRequestHandler):
|
||||||
|
|
||||||
self._benchmarkGETtimings(GETstartTime, GETtimings, 21)
|
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
|
# icon images
|
||||||
# Note that this comes before the busy flag to avoid conflicts
|
# Note that this comes before the busy flag to avoid conflicts
|
||||||
if self.path.startswith('/icons/'):
|
if self.path.startswith('/icons/'):
|
||||||
|
|
Loading…
Reference in New Issue