mirror of
https://github.com/ansible/awx.git
synced 2026-01-14 11:20:39 -03:30
Merge pull request #4213 from cchurch/optimize-job-events
Optimize query for job events to speed up loading job details page.
This commit is contained in:
commit
0cf5b025ec
@ -2504,16 +2504,15 @@ class JobEventSerializer(BaseSerializer):
|
||||
def get_related(self, obj):
|
||||
res = super(JobEventSerializer, self).get_related(obj)
|
||||
res.update(dict(
|
||||
job = reverse('api:job_detail', args=(obj.job.pk,)),
|
||||
#children = reverse('api:job_event_children_list', args=(obj.pk,)),
|
||||
job = reverse('api:job_detail', args=(obj.job_id,)),
|
||||
))
|
||||
if obj.parent:
|
||||
res['parent'] = reverse('api:job_event_detail', args=(obj.parent.pk,))
|
||||
if obj.children.count():
|
||||
if obj.parent_id:
|
||||
res['parent'] = reverse('api:job_event_detail', args=(obj.parent_id,))
|
||||
if obj.children.exists():
|
||||
res['children'] = reverse('api:job_event_children_list', args=(obj.pk,))
|
||||
if obj.host:
|
||||
res['host'] = reverse('api:host_detail', args=(obj.host.pk,))
|
||||
if obj.hosts.count():
|
||||
if obj.host_id:
|
||||
res['host'] = reverse('api:host_detail', args=(obj.host_id,))
|
||||
if obj.hosts.exists():
|
||||
res['hosts'] = reverse('api:job_event_hosts_list', args=(obj.pk,))
|
||||
return res
|
||||
|
||||
|
||||
@ -3504,6 +3504,17 @@ class JobJobEventsList(BaseJobEventsList):
|
||||
|
||||
parent_model = Job
|
||||
|
||||
def get_queryset(self):
|
||||
job = self.get_parent_object()
|
||||
self.check_parent_access(job)
|
||||
qs = job.job_events.all()
|
||||
qs = qs.select_related('host')
|
||||
qs = qs.prefetch_related('hosts', 'children')
|
||||
if self.request.user.is_superuser or self.request.user.is_system_auditor:
|
||||
return qs.all()
|
||||
host_qs = self.request.user.get_queryset(Host)
|
||||
return qs.filter(Q(host__isnull=True) | Q(host__in=host_qs))
|
||||
|
||||
|
||||
class JobJobPlaysList(BaseJobEventsList):
|
||||
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user