mirror of
https://github.com/ynput/ayon-core.git
synced 2026-01-01 16:34:53 +01:00
handled situations when ftrack entities are not queried yet
This commit is contained in:
parent
ef88497512
commit
2b8ecae2ad
1 changed files with 19 additions and 0 deletions
|
|
@ -1544,12 +1544,31 @@ class SyncToAvalonEvent(BaseEvent):
|
||||||
|
|
||||||
# Parents preparation ***
|
# Parents preparation ***
|
||||||
mongo_to_ftrack_parents = {}
|
mongo_to_ftrack_parents = {}
|
||||||
|
missing_ftrack_ents = {}
|
||||||
for mongo_id in parent_changes:
|
for mongo_id in parent_changes:
|
||||||
avalon_ent = self.avalon_ents_by_id[mongo_id]
|
avalon_ent = self.avalon_ents_by_id[mongo_id]
|
||||||
ftrack_id = avalon_ent["data"]["ftrackId"]
|
ftrack_id = avalon_ent["data"]["ftrackId"]
|
||||||
|
if ftrack_id not in self.ftrack_ents_by_id:
|
||||||
|
missing_ftrack_ents[ftrack_id] = mongo_id
|
||||||
|
continue
|
||||||
ftrack_ent = self.ftrack_ents_by_id[ftrack_id]
|
ftrack_ent = self.ftrack_ents_by_id[ftrack_id]
|
||||||
mongo_to_ftrack_parents[mongo_id] = len(ftrack_ent["link"])
|
mongo_to_ftrack_parents[mongo_id] = len(ftrack_ent["link"])
|
||||||
|
|
||||||
|
if missing_ftrack_ents:
|
||||||
|
joine_ids = ", ".join(
|
||||||
|
["\"{}\"".format(id) for id in missing_ftrack_ents.keys()]
|
||||||
|
)
|
||||||
|
entities = self.process_session.query(
|
||||||
|
self.entities_query_by_id.format(
|
||||||
|
self.cur_project["id"], joine_ids
|
||||||
|
)
|
||||||
|
).all()
|
||||||
|
for entity in entities:
|
||||||
|
ftrack_id = entity["id"]
|
||||||
|
self.ftrack_ents_by_id[ftrack_id] = entity
|
||||||
|
mongo_id = missing_ftrack_ents[ftrack_id]
|
||||||
|
mongo_to_ftrack_parents[mongo_id] = len(entity["link"])
|
||||||
|
|
||||||
stored_parents_by_mongo = {}
|
stored_parents_by_mongo = {}
|
||||||
# sort by hierarchy level
|
# sort by hierarchy level
|
||||||
mongo_to_ftrack_parents = [k for k, v in sorted(
|
mongo_to_ftrack_parents = [k for k, v in sorted(
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue