mirror of
https://github.com/ansible/awx.git
synced 2024-11-02 01:21:21 +03:00
AC-1040 Exposed list of choices for type field.
This commit is contained in:
parent
5ad0282495
commit
fe5d154d76
@ -17,7 +17,7 @@ from rest_framework.exceptions import ParseError
|
||||
from rest_framework.filters import BaseFilterBackend
|
||||
|
||||
# Ansible Tower
|
||||
from awx.main.utils import camelcase_to_underscore
|
||||
from awx.main.utils import get_type_for_model
|
||||
|
||||
class ActiveOnlyBackend(BaseFilterBackend):
|
||||
'''
|
||||
@ -52,10 +52,10 @@ class TypeFilterBackend(BaseFilterBackend):
|
||||
ct_model = ct.model_class()
|
||||
if not ct_model:
|
||||
continue
|
||||
ct_type = camelcase_to_underscore(ct_model._meta.object_name)
|
||||
ct_type = get_type_for_model(ct_model)
|
||||
types_map[ct_type] = ct.pk
|
||||
model = queryset.model
|
||||
model_type = camelcase_to_underscore(model._meta.object_name)
|
||||
model_type = get_type_for_model(model)
|
||||
if 'polymorphic_ctype' in model._meta.get_all_field_names():
|
||||
types_pks = set([v for k,v in types_map.items() if k in types])
|
||||
queryset = queryset.filter(polymorphic_ctype_id__in=types_pks)
|
||||
|
@ -197,6 +197,14 @@ class GenericAPIView(generics.GenericAPIView, APIView):
|
||||
# appropriate metadata about the fields that should be supplied.
|
||||
serializer = self.get_serializer()
|
||||
actions['GET'] = serializer.metadata()
|
||||
# Inject the type field choices into GET options as well as on
|
||||
# the metadata itself.
|
||||
if 'type' in actions['GET']:
|
||||
actions['GET']['type']['type'] = 'multiple choice'
|
||||
actions['GET']['type']['choices'] = [
|
||||
(x, unicode(get_model_for_type(x)._meta.verbose_name))
|
||||
for x in serializer.get_types()
|
||||
]
|
||||
ret['types'] = serializer.get_types()
|
||||
if actions:
|
||||
ret['actions'] = actions
|
||||
|
@ -30,7 +30,7 @@ from rest_framework import serializers
|
||||
|
||||
# AWX
|
||||
from awx.main.models import *
|
||||
from awx.main.utils import update_scm_url, camelcase_to_underscore
|
||||
from awx.main.utils import update_scm_url, get_type_for_model
|
||||
|
||||
logger = logging.getLogger('awx.api.serializers')
|
||||
|
||||
@ -214,8 +214,7 @@ class BaseSerializer(serializers.ModelSerializer):
|
||||
return ret
|
||||
|
||||
def get_type(self, obj):
|
||||
opts = get_concrete_model(self.opts.model)._meta
|
||||
return camelcase_to_underscore(opts.object_name)
|
||||
return get_type_for_model(self.opts.model)
|
||||
|
||||
def get_types(self):
|
||||
return [self.get_type(None)]
|
||||
|
@ -17,7 +17,8 @@ from rest_framework.exceptions import ParseError, PermissionDenied
|
||||
from Crypto.Cipher import AES
|
||||
|
||||
__all__ = ['get_object_or_400', 'get_object_or_403', 'camelcase_to_underscore',
|
||||
'get_ansible_version', 'get_awx_version', 'update_scm_url']
|
||||
'get_ansible_version', 'get_awx_version', 'update_scm_url',
|
||||
'get_type_for_model', 'get_model_for_type']
|
||||
|
||||
def get_object_or_400(klass, *args, **kwargs):
|
||||
'''
|
||||
@ -301,6 +302,28 @@ def model_to_dict(obj, serializer_mapping=None):
|
||||
attr_d[field.name] = "hidden"
|
||||
return attr_d
|
||||
|
||||
def get_type_for_model(model):
|
||||
'''
|
||||
Return type name for a given model class.
|
||||
'''
|
||||
from rest_framework.compat import get_concrete_model
|
||||
opts = get_concrete_model(model)._meta
|
||||
return camelcase_to_underscore(opts.object_name)
|
||||
|
||||
def get_model_for_type(type):
|
||||
'''
|
||||
Return model class for a given type name.
|
||||
'''
|
||||
from django.db.models import Q
|
||||
from django.contrib.contenttypes.models import ContentType
|
||||
for ct in ContentType.objects.filter(Q(app_label='main') | Q(app_label='auth', model='user')):
|
||||
ct_model = ct.model_class()
|
||||
if not ct_model:
|
||||
continue
|
||||
ct_type = get_type_for_model(ct_model)
|
||||
if type == ct_type:
|
||||
return ct_model
|
||||
|
||||
def get_system_task_capacity():
|
||||
from django.conf import settings
|
||||
if hasattr(settings, 'SYSTEM_TASK_CAPACITY'):
|
||||
|
Loading…
Reference in New Issue
Block a user