ruff reformat
This commit is contained in:
parent
6acfd2fc83
commit
abe521927e
3 changed files with 42 additions and 35 deletions
|
@ -104,7 +104,7 @@ class ArchiveBackend:
|
||||||
|
|
||||||
|
|
||||||
def get_todo(args) -> list[dict]:
|
def get_todo(args) -> list[dict]:
|
||||||
resp = requests.get(args.private_url + '/api/todo/archive.org').json()
|
resp = requests.get(args.private_url + "/api/todo/archive.org").json()
|
||||||
return resp["files"]
|
return resp["files"]
|
||||||
|
|
||||||
|
|
||||||
|
@ -120,12 +120,12 @@ def loop(args):
|
||||||
|
|
||||||
def process(file, args):
|
def process(file, args):
|
||||||
backend = ArchiveBackend(
|
backend = ArchiveBackend(
|
||||||
args.config['auth']['accesskey'],
|
args.config["auth"]["accesskey"],
|
||||||
args.config['auth']['secretkey'],
|
args.config["auth"]["secretkey"],
|
||||||
)
|
)
|
||||||
print(file)
|
print(file)
|
||||||
|
|
||||||
real_file = Path(CONFIG['general']['files']) / file['filepath']
|
real_file = Path(CONFIG["general"]["files"]) / file["filepath"]
|
||||||
print(real_file)
|
print(real_file)
|
||||||
if not real_file.exists():
|
if not real_file.exists():
|
||||||
LOG.warn("File not found: %s", real_file)
|
LOG.warn("File not found: %s", real_file)
|
||||||
|
@ -135,30 +135,38 @@ def process(file, args):
|
||||||
url = backend.copy(real_file)
|
url = backend.copy(real_file)
|
||||||
|
|
||||||
archived = database.Archived(
|
archived = database.Archived(
|
||||||
original_id=file['id'],
|
original_id=file["id"],
|
||||||
link=url,
|
link=url,
|
||||||
archive='archive.org',
|
archive="archive.org",
|
||||||
archive_time=int(datetime.datetime.now().strftime('%s')),
|
archive_time=int(datetime.datetime.now().strftime("%s")),
|
||||||
# all this is possibly wrong: we should look at the real metadata
|
# all this is possibly wrong: we should look at the real metadata
|
||||||
sha256=file['sha256'],
|
sha256=file["sha256"],
|
||||||
size=file['size'],
|
size=file["size"],
|
||||||
format=file['mime'],
|
format=file["mime"],
|
||||||
)
|
)
|
||||||
return archived
|
return archived
|
||||||
|
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
p = ArgumentParser()
|
p = ArgumentParser()
|
||||||
p.add_argument('--private-url', default='http://127.0.0.1:8000',
|
p.add_argument(
|
||||||
help='URL of the private web server providing the /api/todo endpoint')
|
"--private-url",
|
||||||
p.add_argument('--period', default=30, type=int)
|
default="http://127.0.0.1:8000",
|
||||||
p.add_argument('--config', type=lambda fname: toml.load(open(fname)), required=True,
|
help="URL of the private web server providing the /api/todo endpoint",
|
||||||
help='config specific to the archiveorg uploader. Not to be confused with CARICARI_CONFIG')
|
)
|
||||||
|
p.add_argument("--period", default=30, type=int)
|
||||||
|
p.add_argument(
|
||||||
|
"--config",
|
||||||
|
type=lambda fname: toml.load(open(fname)),
|
||||||
|
required=True,
|
||||||
|
help="config specific to the archiveorg uploader. Not to be confused with CARICARI_CONFIG",
|
||||||
|
)
|
||||||
args = p.parse_args()
|
args = p.parse_args()
|
||||||
|
|
||||||
while True:
|
while True:
|
||||||
loop(args)
|
loop(args)
|
||||||
time.sleep(args.period)
|
time.sleep(args.period)
|
||||||
|
|
||||||
if __name__ == '__main__':
|
|
||||||
|
if __name__ == "__main__":
|
||||||
main()
|
main()
|
||||||
|
|
|
@ -30,9 +30,11 @@ engine = create_engine(CONFIG["general"]["db"])
|
||||||
database.metadata.create_all(engine)
|
database.metadata.create_all(engine)
|
||||||
session_pool = sessionmaker(bind=engine)
|
session_pool = sessionmaker(bind=engine)
|
||||||
|
|
||||||
app.mount("/static",
|
app.mount(
|
||||||
|
"/static",
|
||||||
StaticFiles(directory=str(Path(__file__).parent / "static")),
|
StaticFiles(directory=str(Path(__file__).parent / "static")),
|
||||||
name="static")
|
name="static",
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
@app.get("/")
|
@app.get("/")
|
||||||
|
@ -61,10 +63,8 @@ def normalize_filename(filename: str):
|
||||||
>>> normalize_filename("Hey, do you want to hear my story?" * 10)
|
>>> normalize_filename("Hey, do you want to hear my story?" * 10)
|
||||||
'HeydoyouwanttohearmystoryHeydo'
|
'HeydoyouwanttohearmystoryHeydo'
|
||||||
"""
|
"""
|
||||||
return "".join(
|
return "".join(c for c in filename if c.isalnum() or c in "-_")[:40]
|
||||||
c for c in filename
|
|
||||||
if c.isalnum() or c in '-_'
|
|
||||||
)[:40]
|
|
||||||
|
|
||||||
@app.post("/upload")
|
@app.post("/upload")
|
||||||
async def upload(
|
async def upload(
|
||||||
|
@ -150,9 +150,8 @@ def list(request: Request):
|
||||||
|
|
||||||
if "application/json" in request.headers.get("accept", ""):
|
if "application/json" in request.headers.get("accept", ""):
|
||||||
return data
|
return data
|
||||||
return templates.TemplateResponse(
|
return templates.TemplateResponse(name="list.html", request=request, context=data)
|
||||||
name="list.html", request=request, context=data
|
|
||||||
)
|
|
||||||
|
|
||||||
@app.get("/api/todo/{archive}")
|
@app.get("/api/todo/{archive}")
|
||||||
def todo(request: Request, archive: str):
|
def todo(request: Request, archive: str):
|
||||||
|
|
|
@ -24,14 +24,15 @@ session_pool = sessionmaker(bind=engine)
|
||||||
def home():
|
def home():
|
||||||
return "public archive"
|
return "public archive"
|
||||||
|
|
||||||
|
|
||||||
def get_format(path: str, request: Request) -> str:
|
def get_format(path: str, request: Request) -> str:
|
||||||
# XXX: add some logic involving Accept, user-agent, etc.
|
# XXX: add some logic involving Accept, user-agent, etc.
|
||||||
return path.split('.')[-1]
|
return path.split(".")[-1]
|
||||||
|
|
||||||
|
|
||||||
@app.get("/dl/{path:path}")
|
@app.get("/dl/{path:path}")
|
||||||
async def get_file(request: Request, path: str, fmt: str = 'auto'):
|
async def get_file(request: Request, path: str, fmt: str = "auto"):
|
||||||
if fmt == 'auto':
|
if fmt == "auto":
|
||||||
fmt = get_format(path, request)
|
fmt = get_format(path, request)
|
||||||
with session_pool() as conn:
|
with session_pool() as conn:
|
||||||
original = (
|
original = (
|
||||||
|
@ -56,8 +57,7 @@ async def get_file(request: Request, path: str, fmt: str = 'auto'):
|
||||||
return 404
|
return 404
|
||||||
|
|
||||||
# look for the "best" archived version
|
# look for the "best" archived version
|
||||||
right_format = [arc for arc in original.archived
|
right_format = [arc for arc in original.archived if arc.format == fmt]
|
||||||
if arc.format == fmt]
|
|
||||||
if right_format:
|
if right_format:
|
||||||
return RedirectResponse(right_format[0].link)
|
return RedirectResponse(right_format[0].link)
|
||||||
return RedirectResponse(original.archived[0].link)
|
return RedirectResponse(original.archived[0].link)
|
||||||
|
|
Loading…
Reference in a new issue