mirror of
https://github.com/ynput/ayon-core.git
synced 2025-12-24 21:04:40 +01:00
Merged in bugfix/fix_status_changes_on_app (pull request #369)
Bugfix/fix status changes on app Approved-by: Milan Kolar <milan@orbi.tools>
This commit is contained in:
commit
e561384eae
3 changed files with 32 additions and 10 deletions
|
|
@ -49,7 +49,10 @@ class ThumbnailEvents(BaseEvent):
|
||||||
|
|
||||||
self.log.info(msg)
|
self.log.info(msg)
|
||||||
|
|
||||||
session.commit()
|
try:
|
||||||
|
session.commit()
|
||||||
|
except Exception:
|
||||||
|
session.rollback()
|
||||||
|
|
||||||
|
|
||||||
def register(session, plugins_presets):
|
def register(session, plugins_presets):
|
||||||
|
|
|
||||||
|
|
@ -6,7 +6,6 @@ class VersionToTaskStatus(BaseEvent):
|
||||||
|
|
||||||
def launch(self, session, event):
|
def launch(self, session, event):
|
||||||
'''Propagates status from version to task when changed'''
|
'''Propagates status from version to task when changed'''
|
||||||
session.commit()
|
|
||||||
|
|
||||||
# start of event procedure ----------------------------------
|
# start of event procedure ----------------------------------
|
||||||
for entity in event['data'].get('entities', []):
|
for entity in event['data'].get('entities', []):
|
||||||
|
|
@ -65,6 +64,7 @@ class VersionToTaskStatus(BaseEvent):
|
||||||
session.rollback()
|
session.rollback()
|
||||||
self.log.warning('!!! [ {} ] status couldnt be set:\
|
self.log.warning('!!! [ {} ] status couldnt be set:\
|
||||||
[ {} ]'.format(path, e))
|
[ {} ]'.format(path, e))
|
||||||
|
session.rollback()
|
||||||
else:
|
else:
|
||||||
self.log.info('>>> [ {} ] updated to [ {} ]'.format(
|
self.log.info('>>> [ {} ] updated to [ {} ]'.format(
|
||||||
path, task_status['name']))
|
path, task_status['name']))
|
||||||
|
|
|
||||||
|
|
@ -345,25 +345,44 @@ class AppAction(BaseHandler):
|
||||||
statuses = presets['status_update']
|
statuses = presets['status_update']
|
||||||
|
|
||||||
actual_status = entity['status']['name'].lower()
|
actual_status = entity['status']['name'].lower()
|
||||||
next_status_name = None
|
already_tested = []
|
||||||
for key, value in statuses.items():
|
ent_path = "/".join(
|
||||||
if actual_status in value or '_any_' in value:
|
[ent["name"] for ent in entity['link']]
|
||||||
if key != '_ignore_':
|
)
|
||||||
next_status_name = key
|
while True:
|
||||||
|
next_status_name = None
|
||||||
|
for key, value in statuses.items():
|
||||||
|
if key in already_tested:
|
||||||
|
continue
|
||||||
|
if actual_status in value or '_any_' in value:
|
||||||
|
if key != '_ignore_':
|
||||||
|
next_status_name = key
|
||||||
|
already_tested.append(key)
|
||||||
|
break
|
||||||
|
already_tested.append(key)
|
||||||
|
|
||||||
|
if next_status_name is None:
|
||||||
break
|
break
|
||||||
|
|
||||||
if next_status_name is not None:
|
|
||||||
try:
|
try:
|
||||||
query = 'Status where name is "{}"'.format(
|
query = 'Status where name is "{}"'.format(
|
||||||
next_status_name
|
next_status_name
|
||||||
)
|
)
|
||||||
status = session.query(query).one()
|
status = session.query(query).one()
|
||||||
|
|
||||||
entity['status'] = status
|
entity['status'] = status
|
||||||
session.commit()
|
session.commit()
|
||||||
|
self.log.debug("Changing status to \"{}\" <{}>".format(
|
||||||
|
next_status_name, ent_path
|
||||||
|
))
|
||||||
|
break
|
||||||
|
|
||||||
except Exception:
|
except Exception:
|
||||||
|
session.rollback()
|
||||||
msg = (
|
msg = (
|
||||||
'Status "{}" in presets wasn\'t found on Ftrack'
|
'Status "{}" in presets wasn\'t found'
|
||||||
).format(next_status_name)
|
' on Ftrack entity type "{}"'
|
||||||
|
).format(next_status_name, entity.entity_type)
|
||||||
self.log.warning(msg)
|
self.log.warning(msg)
|
||||||
|
|
||||||
# Set origin avalon environments
|
# Set origin avalon environments
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue