2018-04-27 22:25:47 +00:00
|
|
|
import datetime
|
2018-04-02 16:07:46 +00:00
|
|
|
import logging
|
2018-03-31 13:47:21 +00:00
|
|
|
|
|
|
|
from django.conf import settings
|
2018-04-02 16:07:46 +00:00
|
|
|
from django.utils import timezone
|
2018-04-01 20:11:46 +00:00
|
|
|
|
2018-06-10 08:55:16 +00:00
|
|
|
from funkwhale_api.common import preferences, session
|
2018-04-07 14:20:34 +00:00
|
|
|
|
2018-09-28 20:47:05 +00:00
|
|
|
from . import models, serializers
|
2018-03-31 13:47:21 +00:00
|
|
|
|
2018-04-02 16:07:46 +00:00
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
2018-03-31 13:47:21 +00:00
|
|
|
|
|
|
|
def get_actor_data(actor_url):
|
2018-04-07 14:20:34 +00:00
|
|
|
response = session.get_session().get(
|
2018-03-31 16:41:35 +00:00
|
|
|
actor_url,
|
2018-04-08 11:33:36 +00:00
|
|
|
timeout=5,
|
2018-04-08 16:24:07 +00:00
|
|
|
verify=settings.EXTERNAL_REQUESTS_VERIFY_SSL,
|
2018-06-09 13:36:16 +00:00
|
|
|
headers={"Accept": "application/activity+json"},
|
2018-03-31 16:41:35 +00:00
|
|
|
)
|
2018-03-31 13:47:21 +00:00
|
|
|
response.raise_for_status()
|
2018-03-31 16:41:35 +00:00
|
|
|
try:
|
|
|
|
return response.json()
|
2018-06-10 10:06:46 +00:00
|
|
|
except Exception:
|
2018-06-09 13:36:16 +00:00
|
|
|
raise ValueError("Invalid actor payload: {}".format(response.text))
|
2018-03-31 13:47:21 +00:00
|
|
|
|
2018-04-08 11:33:36 +00:00
|
|
|
|
2018-09-06 18:35:02 +00:00
|
|
|
def get_actor(fid):
|
2018-04-27 22:25:47 +00:00
|
|
|
try:
|
2018-09-06 18:35:02 +00:00
|
|
|
actor = models.Actor.objects.get(fid=fid)
|
2018-04-27 22:25:47 +00:00
|
|
|
except models.Actor.DoesNotExist:
|
|
|
|
actor = None
|
|
|
|
fetch_delta = datetime.timedelta(
|
2018-06-09 13:36:16 +00:00
|
|
|
minutes=preferences.get("federation__actor_fetch_delay")
|
|
|
|
)
|
2018-04-27 22:25:47 +00:00
|
|
|
if actor and actor.last_fetch_date > timezone.now() - fetch_delta:
|
|
|
|
# cache is hot, we can return as is
|
|
|
|
return actor
|
2018-09-06 18:35:02 +00:00
|
|
|
data = get_actor_data(fid)
|
2018-04-02 16:07:46 +00:00
|
|
|
serializer = serializers.ActorSerializer(data=data)
|
|
|
|
serializer.is_valid(raise_exception=True)
|
|
|
|
|
2018-04-27 22:25:47 +00:00
|
|
|
return serializer.save(last_fetch_date=timezone.now())
|