summaryrefslogtreecommitdiff
path: root/web.py
diff options
context:
space:
mode:
Diffstat (limited to 'web.py')
-rw-r--r--web.py23
1 files changed, 5 insertions, 18 deletions
diff --git a/web.py b/web.py
index 007e93d..e2d7fdf 100644
--- a/web.py
+++ b/web.py
@@ -1,36 +1,23 @@
import re
-import aiohttp
from fastapi import FastAPI, Response
from fastapi.responses import FileResponse
-import main
+import htmlcache
import texgen
app = FastAPI()
utaten_pattern = re.compile(r'[a-z0-9]+')
tex_generator = texgen.TexGenerator('pdf_cache', 'temp', 20)
-
-
-class TexSourceGenerationError(Exception):
- pass
-
-
-async def _get_utaten_tex_source(item_id: str) -> str:
- async with aiohttp.ClientSession() as ses:
- async with ses.get(f'https://utaten.com/lyric/{item_id}/') as r:
- if not r.ok:
- raise TexSourceGenerationError('HTTP request failed when reading page source')
- html = await r.text()
- return main.html_to_tex(html)
+html_cache = htmlcache.HtmlCache('html_cache')
@app.get("/utaten/{item_id}.pdf")
async def get_utaten_lyric_pdf(item_id: str):
try:
print('_get_utaten_tex_source')
- tex = await _get_utaten_tex_source(item_id)
+ tex = await html_cache.get_utaten_tex_source(item_id)
print('xelatex')
pdf_path = await tex_generator.xelatex(tex)
return FileResponse(pdf_path, media_type='application/pdf')
@@ -41,7 +28,7 @@ async def get_utaten_lyric_pdf(item_id: str):
@app.get("/utaten/{item_id}.tex")
async def get_utaten_lyric_tex(item_id: str):
try:
- tex = await _get_utaten_tex_source(item_id)
+ tex = await html_cache.get_utaten_tex_source(item_id)
return Response(content=tex, media_type='application/x-tex')
- except TexSourceGenerationError as e:
+ except htmlcache.TexSourceGenerationError as e:
return Response(content=str(e), status_code=503)