Skip to content

Commit

Permalink
Support service-defined payloads for partial sync triggers
Browse files Browse the repository at this point in the history
  • Loading branch information
cpfair committed Jul 17, 2019
1 parent 1a2275e commit 1081891
Show file tree
Hide file tree
Showing 4 changed files with 19 additions and 7 deletions.
20 changes: 16 additions & 4 deletions sync_remote_triggers.py
Original file line number Diff line number Diff line change
Expand Up @@ -19,13 +19,25 @@ def celery_shutdown(**kwargs):
close_connections()

@celery_app.task(acks_late=True)
def trigger_remote(service_id, affected_connection_external_ids):
def trigger_remote(service_id, affected_connection_external_ids_with_payloads):
from tapiriik.auth import User
from tapiriik.services import Service
svc = Service.FromID(service_id)
db.connections.update({"Service": svc.ID, "ExternalID": {"$in": affected_connection_external_ids}}, {"$set":{"TriggerPartialSync": True, "TriggerPartialSyncTimestamp": datetime.utcnow()}}, multi=True, w=MONGO_FULL_WRITE_CONCERN)
affected_connection_ids = db.connections.find({"Service": svc.ID, "ExternalID": {"$in": affected_connection_external_ids}}, {"_id": 1})
affected_connection_ids = [x["_id"] for x in affected_connection_ids]
affected_connection_ids = list()

for item in affected_connection_external_ids_with_payloads:
if isinstance(item, list):
external_id, payload = item
else:
external_id = item
payload = None
update_connection_query = {"$set":{"TriggerPartialSync": True, "TriggerPartialSyncTimestamp": datetime.utcnow()}}
if payload is not None:
update_connection_query.update({"$push": {"TriggerPartialSyncPayloads": payload, "$slice": -90}})
record = db.connections.find_and_modify({"Service": svc.ID, "ExternalID": external_id}, update_connection_query, w=MONGO_FULL_WRITE_CONCERN)
if record is not None:
affected_connection_ids.append(record["_id"])

trigger_users_query = User.PaidUserMongoQuery()
trigger_users_query.update({"ConnectedServices.ID": {"$in": affected_connection_ids}})
trigger_users_query.update({"Config.suppress_auto_sync": {"$ne": True}})
Expand Down
2 changes: 1 addition & 1 deletion tapiriik/services/Endomondo/endomondo.py
Original file line number Diff line number Diff line change
Expand Up @@ -244,7 +244,7 @@ def UnsubscribeFromPartialSyncTrigger(self, serviceRecord):

def ExternalIDsForPartialSyncTrigger(self, req):
data = json.loads(req.body.decode("UTF-8"))
delta_external_ids = [int(x["id"]) for x in data["data"]]
delta_external_ids = [(int(x["id"]), None) for x in data["data"]]
return delta_external_ids

def DownloadActivity(self, serviceRecord, activity):
Expand Down
2 changes: 1 addition & 1 deletion tapiriik/services/Strava/strava.py
Original file line number Diff line number Diff line change
Expand Up @@ -230,7 +230,7 @@ def UnsubscribeFromPartialSyncTrigger(self, serviceRecord):

def ExternalIDsForPartialSyncTrigger(self, req):
data = json.loads(req.body.decode("UTF-8"))
return [data["owner_id"]]
return [(data["owner_id"], None)]

def PartialSyncTriggerGET(self, req):
# Strava requires this endpoint to echo back a challenge.
Expand Down
2 changes: 1 addition & 1 deletion tapiriik/sync/sync.py
Original file line number Diff line number Diff line change
Expand Up @@ -295,7 +295,7 @@ def _writeBackSyncErrorsAndExclusions(self):

if not self._isServiceExcluded(conn) and not self._shouldPersistServiceTrigger(conn):
# Only reset the trigger if we succesfully got through the entire sync without bailing on this particular connection
update_values["$unset"] = {"TriggerPartialSync": None}
update_values["$unset"] = {"TriggerPartialSync": None, "TriggerPartialSyncPayloads": None}

try:
db.connections.update({"_id": conn._id}, update_values)
Expand Down

0 comments on commit 1081891

Please sign in to comment.