mirror of
https://github.com/bellingcat/auto-archiver-api.git
synced 2026-06-12 21:48:35 +03:00
adds logic to test if archive is needed, if specified by the user
This commit is contained in:
@@ -23,14 +23,17 @@ def get_task(db: Session, task_id: str, email: str):
|
|||||||
return query.first()
|
return query.first()
|
||||||
|
|
||||||
|
|
||||||
def search_tasks_by_url(db: Session, url: str, email: str, skip: int = 0, limit: int = 100, archived_after: datetime = None, archived_before: datetime = None):
|
def search_tasks_by_url(db: Session, url: str, email: str, skip: int = 0, limit: int = 100, archived_after: datetime = None, archived_before: datetime = None, absolute_search: bool = False):
|
||||||
# searches for partial URLs, if email is * no ownership filtering happens
|
# searches for partial URLs, if email is * no ownership filtering happens
|
||||||
query = base_query(db)
|
query = base_query(db)
|
||||||
if email != ALLOW_ANY_EMAIL:
|
if email != ALLOW_ANY_EMAIL:
|
||||||
email = email.lower()
|
email = email.lower()
|
||||||
groups = get_user_groups(db, email)
|
groups = get_user_groups(db, email)
|
||||||
query = query.filter(or_(models.Archive.public == True, models.Archive.author_id == email, models.Archive.group_id.in_(groups)))
|
query = query.filter(or_(models.Archive.public == True, models.Archive.author_id == email, models.Archive.group_id.in_(groups)))
|
||||||
query = query.filter(models.Archive.url.like(f'%{url}%'))
|
if absolute_search:
|
||||||
|
query = query.filter(models.Archive.url == url)
|
||||||
|
else:
|
||||||
|
query = query.filter(models.Archive.url.like(f'%{url}%'))
|
||||||
if archived_after:
|
if archived_after:
|
||||||
query = query.filter(models.Archive.created_at >= archived_after)
|
query = query.filter(models.Archive.created_at >= archived_after)
|
||||||
if archived_before:
|
if archived_before:
|
||||||
|
|||||||
@@ -10,6 +10,7 @@ class ArchiveCreate(BaseModel):
|
|||||||
author_id: str | None = None
|
author_id: str | None = None
|
||||||
group_id: str | None = None
|
group_id: str | None = None
|
||||||
tags: set = set()
|
tags: set = set()
|
||||||
|
rearchive: bool = True
|
||||||
# urls: list = []
|
# urls: list = []
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -13,6 +13,8 @@ from db.database import SessionLocal
|
|||||||
from contextlib import contextmanager
|
from contextlib import contextmanager
|
||||||
import json
|
import json
|
||||||
|
|
||||||
|
from security import ALLOW_ANY_EMAIL
|
||||||
|
|
||||||
celery = Celery(__name__)
|
celery = Celery(__name__)
|
||||||
celery.conf.broker_url = os.environ.get("CELERY_BROKER_URL", "redis://localhost:6379")
|
celery.conf.broker_url = os.environ.get("CELERY_BROKER_URL", "redis://localhost:6379")
|
||||||
celery.conf.result_backend = os.environ.get("CELERY_RESULT_BACKEND", "redis://localhost:6379")
|
celery.conf.result_backend = os.environ.get("CELERY_RESULT_BACKEND", "redis://localhost:6379")
|
||||||
@@ -26,7 +28,7 @@ def get_db():
|
|||||||
finally: session.close()
|
finally: session.close()
|
||||||
|
|
||||||
|
|
||||||
@celery.task(name="create_archive_task", bind=True, autoretry_for=(Exception,), retry_backoff=True, retry_kwargs={'max_retries': 5})
|
@celery.task(name="create_archive_task", bind=True, autoretry_for=(Exception,), retry_backoff=True, retry_kwargs={'max_retries': 3})
|
||||||
def create_archive_task(self, archive_json: str):
|
def create_archive_task(self, archive_json: str):
|
||||||
archive = schemas.ArchiveCreate.parse_raw(archive_json)
|
archive = schemas.ArchiveCreate.parse_raw(archive_json)
|
||||||
|
|
||||||
@@ -36,6 +38,15 @@ def create_archive_task(self, archive_json: str):
|
|||||||
|
|
||||||
url = archive.url
|
url = archive.url
|
||||||
logger.info(f"{url=} {archive=}")
|
logger.info(f"{url=} {archive=}")
|
||||||
|
|
||||||
|
if not archive.rearchive:
|
||||||
|
with get_db() as session:
|
||||||
|
archives = crud.search_tasks_by_url(session, url, ALLOW_ANY_EMAIL, absolute_search=True)
|
||||||
|
if len(archives):
|
||||||
|
logger.info(f"Skipping {url=} as it was already archived")
|
||||||
|
# TODO: can we achieve something better than the last result?
|
||||||
|
return archives[0].result
|
||||||
|
|
||||||
orchestrator = choose_orchestrator(archive.group_id, archive.author_id)
|
orchestrator = choose_orchestrator(archive.group_id, archive.author_id)
|
||||||
result = orchestrator.feed_item(Metadata().set_url(url))
|
result = orchestrator.feed_item(Metadata().set_url(url))
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user