mirror of
https://github.com/ansible/awx.git
synced 2024-11-02 09:51:09 +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
|
from rest_framework.filters import BaseFilterBackend
|
||||||
|
|
||||||
# Ansible Tower
|
# Ansible Tower
|
||||||
from awx.main.utils import camelcase_to_underscore
|
from awx.main.utils import get_type_for_model
|
||||||
|
|
||||||
class ActiveOnlyBackend(BaseFilterBackend):
|
class ActiveOnlyBackend(BaseFilterBackend):
|
||||||
'''
|
'''
|
||||||
@ -52,10 +52,10 @@ class TypeFilterBackend(BaseFilterBackend):
|
|||||||
ct_model = ct.model_class()
|
ct_model = ct.model_class()
|
||||||
if not ct_model:
|
if not ct_model:
|
||||||
continue
|
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
|
types_map[ct_type] = ct.pk
|
||||||
model = queryset.model
|
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():
|
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])
|
types_pks = set([v for k,v in types_map.items() if k in types])
|
||||||
queryset = queryset.filter(polymorphic_ctype_id__in=types_pks)
|
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.
|
# appropriate metadata about the fields that should be supplied.
|
||||||
serializer = self.get_serializer()
|
serializer = self.get_serializer()
|
||||||
actions['GET'] = serializer.metadata()
|
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()
|
ret['types'] = serializer.get_types()
|
||||||
if actions:
|
if actions:
|
||||||
ret['actions'] = actions
|
ret['actions'] = actions
|
||||||
|
@ -30,7 +30,7 @@ from rest_framework import serializers
|
|||||||
|
|
||||||
# AWX
|
# AWX
|
||||||
from awx.main.models import *
|
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')
|
logger = logging.getLogger('awx.api.serializers')
|
||||||
|
|
||||||
@ -214,8 +214,7 @@ class BaseSerializer(serializers.ModelSerializer):
|
|||||||
return ret
|
return ret
|
||||||
|
|
||||||
def get_type(self, obj):
|
def get_type(self, obj):
|
||||||
opts = get_concrete_model(self.opts.model)._meta
|
return get_type_for_model(self.opts.model)
|
||||||
return camelcase_to_underscore(opts.object_name)
|
|
||||||
|
|
||||||
def get_types(self):
|
def get_types(self):
|
||||||
return [self.get_type(None)]
|
return [self.get_type(None)]
|
||||||
|
@ -17,7 +17,8 @@ from rest_framework.exceptions import ParseError, PermissionDenied
|
|||||||
from Crypto.Cipher import AES
|
from Crypto.Cipher import AES
|
||||||
|
|
||||||
__all__ = ['get_object_or_400', 'get_object_or_403', 'camelcase_to_underscore',
|
__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):
|
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"
|
attr_d[field.name] = "hidden"
|
||||||
return attr_d
|
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():
|
def get_system_task_capacity():
|
||||||
from django.conf import settings
|
from django.conf import settings
|
||||||
if hasattr(settings, 'SYSTEM_TASK_CAPACITY'):
|
if hasattr(settings, 'SYSTEM_TASK_CAPACITY'):
|
||||||
|
Loading…
Reference in New Issue
Block a user