mirror of
https://github.com/bellingcat/auto-archiver-api.git
synced 2026-06-11 21:18:35 +03:00
Format and lint web directory (#67)
This commit is contained in:
@@ -1,4 +1,5 @@
|
||||
import json
|
||||
from http import HTTPStatus
|
||||
|
||||
import sqlalchemy
|
||||
from auto_archiver.core import Metadata
|
||||
@@ -16,26 +17,39 @@ from app.web.config import ALLOW_ANY_EMAIL
|
||||
from app.web.security import token_api_key_auth
|
||||
|
||||
|
||||
interoperability_router = APIRouter(prefix="/interop", tags=["Interoperability endpoints."])
|
||||
interoperability_router = APIRouter(
|
||||
prefix="/interop", tags=["Interoperability endpoints."]
|
||||
)
|
||||
|
||||
|
||||
# ----- endpoint to submit data archived elsewhere
|
||||
@interoperability_router.post("/submit-archive", status_code=201, summary="Submit a manual archive entry, for data that was archived elsewhere.")
|
||||
@interoperability_router.post(
|
||||
"/submit-archive",
|
||||
status_code=HTTPStatus.CREATED,
|
||||
summary="Submit a manual archive entry, for data that was archived elsewhere.",
|
||||
)
|
||||
def submit_manual_archive(
|
||||
manual: schemas.SubmitManualArchive,
|
||||
auth=Depends(token_api_key_auth),
|
||||
db: Session = Depends(get_db_dependency)
|
||||
db: Session = Depends(get_db_dependency),
|
||||
):
|
||||
try:
|
||||
result: Metadata = Metadata.from_json(manual.result)
|
||||
except json.JSONDecodeError as e:
|
||||
log_error(e)
|
||||
raise HTTPException(status_code=422, detail="Invalid JSON in result field.")
|
||||
raise HTTPException(
|
||||
status_code=HTTPStatus.UNPROCESSABLE_ENTITY,
|
||||
detail="Invalid JSON in result field.",
|
||||
) from e
|
||||
manual.author_id = manual.author_id or ALLOW_ANY_EMAIL
|
||||
manual.tags.add("manual")
|
||||
|
||||
store_until = business_logic.get_store_archive_until_or_never(db, manual.group_id)
|
||||
logger.debug(f"[MANUAL ARCHIVE] {manual.author_id} {manual.url} {store_until}")
|
||||
store_until = business_logic.get_store_archive_until_or_never(
|
||||
db, manual.group_id
|
||||
)
|
||||
logger.debug(
|
||||
f"[MANUAL ARCHIVE] {manual.author_id} {manual.url} {store_until}"
|
||||
)
|
||||
|
||||
try:
|
||||
archive = schemas.ArchiveCreate(
|
||||
@@ -51,8 +65,15 @@ def submit_manual_archive(
|
||||
)
|
||||
|
||||
db_archive = worker_crud.store_archived_url(db, archive)
|
||||
logger.debug(f"[MANUAL ARCHIVE STORED] {db_archive.author_id} {db_archive.url}")
|
||||
return JSONResponse({"id": db_archive.id}, status_code=201)
|
||||
logger.debug(
|
||||
f"[MANUAL ARCHIVE STORED] {db_archive.author_id} {db_archive.url}"
|
||||
)
|
||||
return JSONResponse(
|
||||
{"id": db_archive.id}, status_code=HTTPStatus.CREATED
|
||||
)
|
||||
except sqlalchemy.exc.IntegrityError as e:
|
||||
log_error(e)
|
||||
raise HTTPException(status_code=422, detail=f"Cannot insert into DB due to integrity error, likely duplicate urls.")
|
||||
raise HTTPException(
|
||||
status_code=HTTPStatus.UNPROCESSABLE_ENTITY,
|
||||
detail="Cannot insert into DB due to integrity error, likely duplicate urls.",
|
||||
) from e
|
||||
|
||||
Reference in New Issue
Block a user