aboutsummaryrefslogtreecommitdiffstats
path: root/mediagoblin/tools/federation.py
diff options
context:
space:
mode:
authorJessica Tallon <tsyesika@tsyesika.se>2015-06-24 21:45:39 +0200
committerJessica Tallon <tsyesika@tsyesika.se>2015-06-24 21:45:39 +0200
commit380ea91dab370940d29e292029a6da97b6c5db27 (patch)
tree92d45dca2f816e1d61f1ee88e7c79b5208d46700 /mediagoblin/tools/federation.py
parent39da9940581c8fea274c026df889069a60bf2cf5 (diff)
parentddc2db746f3291dbe11393a814eed9a0fd651365 (diff)
downloadmediagoblin-380ea91dab370940d29e292029a6da97b6c5db27.tar.lz
mediagoblin-380ea91dab370940d29e292029a6da97b6c5db27.tar.xz
mediagoblin-380ea91dab370940d29e292029a6da97b6c5db27.zip
Merge branch Generic Foreign Key changes
Diffstat (limited to 'mediagoblin/tools/federation.py')
-rw-r--r--mediagoblin/tools/federation.py14
1 files changed, 9 insertions, 5 deletions
diff --git a/mediagoblin/tools/federation.py b/mediagoblin/tools/federation.py
index 6c2d27da..39b465bf 100644
--- a/mediagoblin/tools/federation.py
+++ b/mediagoblin/tools/federation.py
@@ -26,7 +26,7 @@ def create_generator(request):
return None
client = request.access_token.get_requesttoken.get_client
-
+
# Check if there is a generator already
generator = Generator.query.filter_by(
name=client.application_name,
@@ -40,8 +40,8 @@ def create_generator(request):
generator.save()
return generator
-
-
+
+
def create_activity(verb, obj, actor, target=None, generator=None):
"""
@@ -71,11 +71,15 @@ def create_activity(verb, obj, actor, target=None, generator=None):
)
generator.save()
+ # Ensure the object has an ID which is needed by the activity.
+ obj.save(commit=False)
+
+ # Create the activity
activity = Activity(verb=verb)
- activity.set_object(obj)
+ activity.object = obj
if target is not None:
- activity.set_target(target)
+ activity.target = target
# If they've set it override the actor from the obj.
activity.actor = actor.id if isinstance(actor, User) else actor